:root{
  --bg:#f3f7fb; --card:#fff; --text:#0f172a; --muted:#64748b; --line:#e2e8f0;
  --primary:#0f766e; --primary2:#14b8a6; --blue:#2563eb; --purple:#7c3aed;
  --danger:#dc2626; --warning:#d97706; --success:#16a34a; --dark:#0f172a;
  --shadow:0 20px 55px rgba(15,23,42,.11); --radius:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  min-height:100vh;font-family:Inter,Segoe UI,Tahoma,Arial,sans-serif;color:var(--text);
  background:radial-gradient(circle at 10% 0%,rgba(20,184,166,.18),transparent 26%),
  radial-gradient(circle at 90% 0%,rgba(37,99,235,.15),transparent 28%),linear-gradient(135deg,#ecfeff,#f8fafc 45%,#f0fdf4);
}
button,input,select,textarea{font-family:inherit}.hide{display:none!important}.mt10{margin-top:10px}.mt16{margin-top:16px}
.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-wrap{width:min(1130px,100%);display:grid;grid-template-columns:1.05fr .95fr;gap:22px}
.hero{position:relative;overflow:hidden;border-radius:30px;padding:36px;color:white;background:linear-gradient(135deg,#0f766e,#2563eb);box-shadow:var(--shadow)}
.hero:before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;right:-90px;top:-90px;background:rgba(255,255,255,.12)}
.hero:after{content:"";position:absolute;width:210px;height:210px;border-radius:50%;left:-70px;bottom:-80px;background:rgba(255,255,255,.1)}
.hero>*{position:relative;z-index:2}.brand-row{display:flex;gap:14px;align-items:center;margin-bottom:30px}.brand-logo{width:62px;height:62px;border-radius:22px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:27px;border:1px solid rgba(255,255,255,.25)}
.brand-row h1{font-size:25px}.brand-row p{opacity:.84;margin-top:4px}.hero h2{font-size:38px;line-height:1.08;letter-spacing:-.05em;margin:15px 0}.hero .desc{font-size:16px;opacity:.9;line-height:1.65;max-width:620px}
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:28px}.feature{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:14px;display:flex;gap:11px;align-items:center}.feature i{font-size:19px}
.login-card{background:rgba(255,255,255,.9);border:1px solid rgba(226,232,240,.9);box-shadow:var(--shadow);border-radius:30px;padding:30px;backdrop-filter:blur(16px)}
.login-card h3{font-size:26px;margin-bottom:7px}.login-card>p{color:var(--muted);line-height:1.5;margin-bottom:22px}
.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:900;color:#334155;margin-bottom:7px}.input,.select,.textarea{width:100%;border:1px solid var(--line);border-radius:15px;padding:13px 14px;background:white;font-size:15px;outline:none}.textarea{resize:vertical;min-height:86px}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary2);box-shadow:0 0 0 4px rgba(20,184,166,.12)}
.btn{border:0;border-radius:15px;padding:12px 15px;font-weight:900;cursor:pointer;display:inline-flex;gap:9px;align-items:center;justify-content:center;background:#e2e8f0;color:#0f172a;transition:.15s;text-decoration:none}.btn:hover{filter:brightness(.98);transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:white}.btn.blue{background:#dbeafe;color:#1d4ed8}.btn.danger{background:#fee2e2;color:#991b1b}.btn.warn{background:#fef3c7;color:#92400e}.btn.success{background:#dcfce7;color:#166534}.btn.dark{background:#0f172a;color:white}.btn.block{width:100%}.btn.small{padding:8px 10px;border-radius:12px;font-size:12px}
.demo-login{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px;margin-top:16px;color:#475569;line-height:1.55;font-size:13px}
.app{display:grid;grid-template-columns:292px 1fr;min-height:100vh}.sidebar{background:rgba(15,23,42,.97);color:white;padding:22px;position:sticky;top:0;height:100vh;overflow:auto}.side-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}.side-logo{width:50px;height:50px;border-radius:18px;background:linear-gradient(135deg,var(--primary2),#22c55e);display:grid;place-items:center;font-size:21px}.side-brand h2{font-size:18px}.side-brand p{font-size:12px;color:#cbd5e1;margin-top:3px}.user-box{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:14px;margin-bottom:18px}.user-box b{display:block}.user-box span{color:#cbd5e1;font-size:13px}.nav{display:grid;gap:8px}.nav button{border:0;background:transparent;color:#cbd5e1;padding:13px 14px;border-radius:15px;text-align:left;cursor:pointer;font-weight:800;display:flex;align-items:center;gap:11px}.nav button:hover,.nav button.active{background:rgba(20,184,166,.18);color:white}.nav button.locked{opacity:.45;pointer-events:none}.logout-btn{margin-top:18px}
.main{padding:25px;overflow:auto}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:20px}.title h1{font-size:30px;letter-spacing:-.045em}.title p{color:var(--muted);margin-top:5px;line-height:1.5}.actions{display:flex;gap:10px;flex-wrap:wrap}
.grid{display:grid;gap:16px}.stats{grid-template-columns:repeat(5,minmax(0,1fr));margin-bottom:18px}.card{background:rgba(255,255,255,.88);border:1px solid rgba(226,232,240,.9);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;backdrop-filter:blur(14px)}.stat{display:flex;justify-content:space-between;align-items:center}.stat small{color:var(--muted);font-weight:900}.stat b{display:block;font-size:26px;margin-top:6px}.stat i{width:43px;height:43px;border-radius:15px;display:grid;place-items:center;background:#ccfbf1;color:#0f766e}.stat.blue i{background:#dbeafe;color:#1d4ed8}.stat.warn i{background:#fef3c7;color:#92400e}.stat.purple i{background:#ede9fe;color:#6d28d9}.stat.red i{background:#fee2e2;color:#991b1b}
.panel-title{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.panel-title h3{font-size:19px}.panel-title span{font-size:13px;color:var(--muted);font-weight:800}.filters{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:11px;margin-bottom:15px}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.form-grid .full{grid-column:1/-1}.form-grid .half{grid-column:span 2}.two-mini{grid-template-columns:1fr 1fr}.settings-grid{grid-template-columns:1fr}.mini-label{font-weight:900;font-size:13px;display:block;margin-bottom:7px;color:#334155}
.upload-box{border:1.5px dashed #94a3b8;background:#f8fafc;border-radius:18px;padding:16px}.hint{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.45}.resident-photo-wrap{display:grid;grid-template-columns:170px 1fr;gap:16px;align-items:start}.photo-preview{width:170px;height:220px;border-radius:20px;background:#f8fafc;border:1px dashed #94a3b8;display:grid;place-items:center;overflow:hidden;text-align:center;color:#64748b}.photo-preview img{width:100%;height:100%;object-fit:cover}.file-list{display:grid;gap:9px;margin-top:12px}.file-item{background:white;border:1px solid var(--line);border-radius:14px;padding:10px 12px;display:flex;justify-content:space-between;gap:12px;align-items:center}.file-item a{color:var(--primary);font-weight:900;text-decoration:none}.file-item small{color:var(--muted)}
.checkbox-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;background:#f8fafc;border:1px solid var(--line);padding:14px;border-radius:16px}.checkbox-grid label{font-size:14px;font-weight:800;color:#334155;display:flex;gap:8px;align-items:center}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px}table{width:100%;border-collapse:collapse;background:white;min-width:1100px}th,td{padding:12px 13px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;vertical-align:middle}th{background:#f8fafc;color:#334155;font-size:12px;text-transform:uppercase;letter-spacing:.06em}tr:hover td{background:#f0fdfa}.avatar{width:44px;height:54px;border-radius:12px;background:#e2e8f0;object-fit:cover}.badge{padding:6px 9px;border-radius:999px;font-size:12px;font-weight:900;white-space:nowrap}.ok{background:#dcfce7;color:#166534}.bad{background:#fee2e2;color:#991b1b}.warnb{background:#fef3c7;color:#92400e}.infob{background:#dbeafe;color:#1d4ed8}.purpleb{background:#ede9fe;color:#6d28d9}.empty{padding:30px;text-align:center;color:var(--muted)}.two-col{grid-template-columns:1.1fr .9fr}.three-col{grid-template-columns:repeat(3,1fr)}.detail-list{display:grid;gap:10px}.detail-row{display:flex;justify-content:space-between;gap:12px;padding:12px;border-radius:14px;background:#f8fafc;border:1px solid var(--line)}.detail-row span:first-child{font-weight:900;color:#64748b}
.modal{position:fixed;inset:0;background:rgba(15,23,42,.56);z-index:90;display:none;place-items:center;padding:20px}.modal.show{display:grid}.modal-card{width:min(1100px,100%);max-height:92vh;overflow:auto;background:white;border-radius:24px;box-shadow:var(--shadow);padding:20px}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal-head h3{font-size:22px}.close{width:38px;height:38px;border:0;border-radius:14px;background:#fee2e2;color:#991b1b;font-weight:900;cursor:pointer}.profile-head{display:grid;grid-template-columns:170px 1fr;gap:18px}.profile-photo{width:170px;height:220px;border-radius:20px;background:#f1f5f9;object-fit:cover;border:1px solid var(--line)}
.print-area{display:none}.toast{position:fixed;right:20px;bottom:20px;z-index:100;background:#0f172a;color:white;padding:14px 16px;border-radius:15px;box-shadow:var(--shadow);display:none;max-width:420px}.toast.show{display:block}.loading{position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:110;display:none;place-items:center}.loading.show{display:grid}.loader{background:white;padding:22px 26px;border-radius:18px;display:flex;gap:12px;align-items:center;font-weight:900}.spin{width:22px;height:22px;border:3px solid #ccfbf1;border-top-color:#0f766e;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sql-box{min-height:250px;font-family:Consolas,monospace;font-size:13px;white-space:pre}.config-box{background:#fff7ed;color:#7c2d12;border:1px solid #fed7aa;border-radius:18px;padding:15px;margin-bottom:16px;line-height:1.55}

/* PHIEU IN GIONG MAU */
.receipt-a4{
  width:210mm; min-height:297mm; margin:0 auto; background:white; color:#000;
  padding:13mm 12mm; font-family:"Times New Roman",serif; font-size:14px; line-height:1.25;
}
.receipt-top{position:relative;text-align:center;margin-bottom:8px}
.receipt-top h2{font-size:18px;text-transform:uppercase;margin:0;font-weight:800}
.receipt-top h3{font-size:15px;text-transform:uppercase;margin:2px 0 6px;font-weight:800}
.receipt-no{position:absolute;right:0;top:0;border:1px solid #000;padding:3px 8px;font-size:13px}
.receipt-note{font-size:13px;text-align:left;font-style:italic;margin:3px 0 6px 0}
.receipt-section-title{font-size:16px;text-transform:uppercase;font-weight:800;margin:5px 0}
.form-line{display:flex;align-items:flex-end;gap:6px;margin:5px 0;min-height:22px}
.form-line b{white-space:nowrap}.fill{border-bottom:1px dotted #000;min-height:18px;flex:1;padding:0 4px;font-weight:700}
.fill.short{flex:0 0 70px}.fill.mid{flex:0 0 150px}.fill.long{flex:1}
.code-boxes{display:inline-flex;gap:2px;vertical-align:middle}
.code-boxes span{width:22px;height:20px;border:1px solid #000;display:inline-grid;place-items:center;font-weight:700;font-size:13px}
.small-under{font-size:11px;font-style:italic;color:#000;margin-left:110px;display:flex;gap:55px}
.photo-print{position:absolute;right:10px;top:60px;width:86px;height:112px;border:1px solid #000;display:grid;place-items:center;text-align:center;font-size:12px;background:white;overflow:hidden}
.photo-print img{width:100%;height:100%;object-fit:cover}.photo-caption{position:absolute;right:29px;top:174px;font-size:11px}
.two-print-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.print-check-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:9px;margin:5px 0}.print-check{display:flex;align-items:center;gap:7px}.box{width:19px;height:19px;border:1px solid #000;display:inline-grid;place-items:center;font-weight:800}
.sign-print{display:grid;grid-template-columns:1fr 1fr;gap:40px;text-align:center;margin-top:18px}.sign-print b{text-transform:uppercase}.sign-space{height:42px}
@media(max-width:1200px){.stats{grid-template-columns:repeat(2,1fr)}.filters{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:repeat(2,1fr)}.two-col,.three-col{grid-template-columns:1fr}.login-wrap{grid-template-columns:1fr}.hero{display:none}.checkbox-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.app{grid-template-columns:1fr}.sidebar{height:auto;position:relative}.main{padding:16px}.topbar{flex-direction:column}.actions,.btn{width:100%}.stats,.filters,.form-grid{grid-template-columns:1fr}.form-grid .half{grid-column:auto}.resident-photo-wrap,.profile-head{grid-template-columns:1fr}.photo-preview,.profile-photo{width:150px;height:190px}.checkbox-grid{grid-template-columns:1fr}.feature-grid{grid-template-columns:1fr}}
@media print{
  body{background:white!important}.login-screen,.app,.modal,.toast,.loading{display:none!important}
  .print-area{display:block!important}.receipt-a4{box-shadow:none;margin:0;padding:8mm 9mm;width:210mm;min-height:297mm}
  @page{size:A4;margin:0}
}

/* V2 PRO */
.public-lookup-box{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px;margin-top:16px}
.public-lookup-box h4{font-size:16px;margin-bottom:5px;color:#0f172a}
.public-lookup-box p{font-size:13px;color:var(--muted);line-height:1.45;margin-bottom:10px}
.lookup-row{display:grid;grid-template-columns:1fr auto;gap:9px}
.public-result{margin-top:12px}
.public-mini-card{background:white;border:1px solid var(--line);border-radius:16px;padding:13px}
.public-mini-card h4{font-size:17px;margin-bottom:8px}
.public-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.public-info-grid div{background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:9px}
.facility-info-box{background:#f8fafc;border:1px solid var(--line);border-radius:15px;padding:12px;color:#334155;line-height:1.5;font-weight:700}
.scan-reader{width:100%;min-height:320px;background:#f8fafc;border:1px dashed #94a3b8;border-radius:18px;overflow:hidden;display:grid;place-items:center}
.phone-qr-box{background:#f8fafc;border:1px dashed #94a3b8;border-radius:18px;padding:16px;text-align:center;color:#334155}
.phone-qr-box img{width:220px;height:220px;border-radius:14px;background:white;border:1px solid var(--line);padding:8px}
.quick-badge{display:inline-block;background:#ecfeff;border:1px solid #99f6e4;color:#0f766e;border-radius:999px;padding:6px 9px;font-weight:900;font-size:12px}
@media(max-width:760px){.lookup-row,.public-info-grid{grid-template-columns:1fr}}

/* V6 inline document scan */
.doc-upload-grid{grid-template-columns:1.1fr 1.1fr .8fr}
.inline-control{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.inline-scan-box{margin-top:12px;background:#ecfeff;border:1px solid #99f6e4;border-radius:18px;padding:14px;color:#0f172a}
.inline-scan-content{display:grid;grid-template-columns:190px 1fr;gap:14px;align-items:center}
.inline-scan-content img{width:180px;height:180px;border-radius:14px;background:white;border:1px solid #ccfbf1;padding:8px}
.pending-doc-card{background:white;border:1px solid var(--line);border-radius:14px;padding:10px 12px;display:grid;grid-template-columns:72px 1fr auto;gap:10px;align-items:center}
.pending-doc-card img{width:72px;height:92px;object-fit:cover;border-radius:10px;border:1px solid var(--line);background:#f8fafc}
.pending-doc-card b{display:block}.pending-doc-card small{color:var(--muted)}
@media(max-width:900px){.doc-upload-grid,.inline-scan-content{grid-template-columns:1fr}.inline-scan-content img{margin:auto}}

/* V7 GOV STYLE */
.gov-ribbon{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:8px 13px;font-weight:900;font-size:12px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.gov-status-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;background:#fff;border-left:6px solid #b91c1c;border-radius:16px;padding:12px 14px;margin-bottom:16px;box-shadow:0 10px 30px rgba(15,23,42,.06);color:#334155}
.gov-status-strip b{color:#0f172a}
.sidebar{background:linear-gradient(180deg,#7f1d1d,#0f172a 38%,#0f172a)!important}
.side-logo,.brand-logo{background:linear-gradient(135deg,#b91c1c,#f59e0b)!important}
.btn.primary{background:linear-gradient(135deg,#b91c1c,#dc2626)!important}
.btn.blue{background:#dbeafe;color:#1d4ed8}
.nav button:hover,.nav button.active{background:rgba(248,250,252,.16)!important;border-left:4px solid #fbbf24}
.card.gov-card{border-top:5px solid #b91c1c}
.gov-card h3{color:#334155;font-size:15px}.gov-card b{font-size:34px;color:#b91c1c;display:block;margin:8px 0}.gov-card p{color:#64748b;font-size:13px;line-height:1.45}
.process-line{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.process-line div{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:12px;text-align:center;font-weight:900;color:#334155}
.process-line span{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:#b91c1c;color:white;margin:0 auto 8px}
.role-layout-note{background:#fef3c7;border:1px solid #fde68a;border-radius:14px;padding:12px;margin-bottom:12px;color:#78350f;line-height:1.5;font-size:13px}
.priority-high{background:#fef3c7;color:#92400e}.priority-urgent{background:#fee2e2;color:#991b1b}
@media(max-width:900px){.gov-status-strip,.process-line{grid-template-columns:1fr}}



/* =========================================================
   V8 FIX OVERFLOW / RESPONSIVE LAYOUT
   Sửa lỗi một số trang bị tràn ngang, đặc biệt Tài khoản / Phân quyền
   ========================================================= */

/* Không cho toàn trang bị kéo ngang */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

/* Grid chính cho phép cột content co lại thay vì đẩy tràn */
.app {
  grid-template-columns: 292px minmax(0, 1fr) !important;
}

.main,
.card,
.tabpage,
.grid,
.table-wrap {
  min-width: 0;
  max-width: 100%;
}

/* Topbar tự xuống dòng khi thiếu chỗ */
.topbar {
  flex-wrap: wrap;
}

.topbar .title {
  min-width: 260px;
  flex: 1 1 420px;
}

.topbar .actions {
  flex: 0 1 auto;
}

/* Các layout 2/3 cột tự co theo container */
.two-col {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
}

.three-col {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.stats {
  grid-template-columns: repeat(5, minmax(150px, 1fr)) !important;
}

/* Form không vượt khung */
.form-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.form-grid.two-mini,
.two-mini {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.form-grid .full,
.full {
  grid-column: 1 / -1;
}

.input,
.select,
.textarea,
button {
  max-width: 100%;
}

/* Bảng chỉ cuộn trong khung, không làm tràn body */
.table-wrap {
  width: 100%;
  overflow-x: auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.table-wrap table {
  width: 100%;
  min-width: 860px;
}

/* Riêng trang tài khoản/phân quyền: tránh bảng quyền quá rộng */
#users .two-col {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr) !important;
  align-items: start;
}

#users .card {
  overflow: hidden;
}

#users .table-wrap {
  max-height: 520px;
}

#users table {
  min-width: 720px;
}

/* Form thêm tài khoản trong ảnh bị tràn: cho mỗi input co đúng */
#users .form-grid.two-mini {
  grid-template-columns: repeat(2, minmax(180px, 1fr)) !important;
}

/* Cột phân quyền cho phép xuống dòng, không ép ngang */
#permissionRows td,
#permissionRows th {
  white-space: normal;
}

/* Ghi chú phân quyền không làm rộng card */
.role-layout-note {
  overflow-wrap: anywhere;
}

/* Bảng danh sách hồ sơ lớn thì để min-width đủ dùng nhưng không kéo trang */
#records table,
#documents table,
#approvals table,
#intake table,
#logs table {
  min-width: 980px;
}

/* Khối upload scan inline không làm vỡ layout */
.doc-upload-grid {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.1fr) minmax(180px, .8fr) !important;
}

.inline-control {
  grid-template-columns: minmax(0, 1fr) auto !important;
}

/* Ẩn scrollbar ngang của body, chỉ cho table-wrap cuộn */
body {
  overflow-x: hidden !important;
}

/* Responsive mượt hơn theo từng mức */
@media (max-width: 1400px) {
  .stats {
    grid-template-columns: repeat(3, minmax(150px, 1fr)) !important;
  }

  .form-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  #users .two-col {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 1180px) {
  .app {
    grid-template-columns: 260px minmax(0, 1fr) !important;
  }

  .main {
    padding: 18px;
  }

  .two-col,
  .three-col {
    grid-template-columns: 1fr !important;
  }

  .stats {
    grid-template-columns: repeat(2, minmax(150px, 1fr)) !important;
  }

  .form-grid,
  .form-grid.two-mini,
  .two-mini,
  .doc-upload-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .filters {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  .app {
    grid-template-columns: 1fr !important;
  }

  .sidebar {
    position: relative !important;
    height: auto !important;
    width: 100%;
  }

  .main {
    padding: 14px;
  }

  .topbar {
    flex-direction: column;
  }

  .topbar .actions {
    width: 100%;
  }

  .topbar .actions .btn {
    flex: 1 1 160px;
  }

  .gov-status-strip {
    grid-template-columns: 1fr !important;
  }

  .stats,
  .form-grid,
  .form-grid.two-mini,
  .two-mini,
  .doc-upload-grid,
  .filters,
  #users .form-grid.two-mini {
    grid-template-columns: 1fr !important;
  }

  .resident-photo-wrap,
  .inline-scan-content {
    grid-template-columns: 1fr !important;
  }

  .photo-preview {
    margin: 0 auto;
  }

  .checkbox-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 520px) {
  .main {
    padding: 10px;
  }

  .card {
    padding: 14px;
    border-radius: 16px;
  }

  .title h1 {
    font-size: 23px;
  }

  .btn {
    width: 100%;
  }

  .actions {
    width: 100%;
  }

  .table-wrap table {
    min-width: 760px;
  }
}

/* V9 ADDRESS PLUS */
.manual-ward{background:#fff7ed!important;border-color:#fed7aa!important}
.ward-select option[value="MANUAL"]{font-weight:900}
.btn.success{background:#dcfce7!important;color:#166534!important}
.btn.warn{background:#fef3c7!important;color:#92400e!important}
.auto-tools-note{background:#ecfeff;border:1px solid #99f6e4;color:#0f766e;border-radius:14px;padding:10px;margin-top:10px;font-weight:800}

/* V11 EXCEL IMPORT */
.excel-import-box{
  background:linear-gradient(135deg,#ecfdf5,#f8fafc);
  border:1px solid #bbf7d0;
  border-radius:18px;
  padding:18px;
  text-align:center;
}
.excel-icon{
  width:70px;height:70px;
  border-radius:22px;
  background:#dcfce7;
  color:#15803d;
  display:grid;
  place-items:center;
  font-size:34px;
  margin:0 auto 12px;
}
.excel-import-box h3{margin-bottom:6px}
.excel-import-box p{color:#64748b;line-height:1.5;margin-bottom:14px}
.excel-ok{background:#dcfce7;color:#166534}
.excel-error{background:#fee2e2;color:#991b1b}

/* V12 full address code on printed receipt */
.code-full-line{
  font-size:12px;
  font-weight:700;
  border-bottom:1px dotted #000;
  color:#000;
}
.code-full-line span{
  display:block;
  width:100%;
  padding:2px 4px;
}

/* V13 MANAGEMENT PRO */
.bulk-actions{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  background:#f8fafc;border:1px solid var(--line);border-radius:16px;
  padding:10px;margin-bottom:12px
}
.bulk-count{font-weight:900;color:#334155;font-size:13px}
.lookup-big{display:grid;grid-template-columns:1fr auto;gap:10px}
.lookup-result{margin-top:16px}
.lookup-profile-card{background:white;border:1px solid var(--line);border-radius:20px;padding:18px}
.lookup-profile-grid{display:grid;grid-template-columns:170px 1fr;gap:18px;align-items:start}
.lookup-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.permission-click-panel{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px;margin-bottom:14px}
.permission-click-panel h4{font-size:17px;margin-bottom:6px}
.permission-click-panel p{font-size:13px;color:var(--muted);margin-bottom:12px}
.permission-matrix{display:grid;gap:10px;margin-top:12px}
.perm-module-row{display:grid;grid-template-columns:1.2fr repeat(6,90px);gap:8px;align-items:center;background:white;border:1px solid var(--line);border-radius:14px;padding:10px;overflow:auto}
.perm-module-row b{font-size:14px}
.perm-module-row label{display:flex;align-items:center;justify-content:center;gap:5px;font-size:12px;font-weight:800;color:#334155}
.action-cell{display:flex;gap:6px;flex-wrap:wrap}
@media(max-width:900px){
  .lookup-big,.lookup-profile-grid{grid-template-columns:1fr}
  .perm-module-row{grid-template-columns:1fr repeat(3,90px)}
}



/* =========================================================
   V15 - GIỮ PHIẾU CŨ + QR MRZ + SỬA XÓA HÀNG LOẠT
   ========================================================= */

/* Khôi phục bố cục phiếu cũ nếu trước đó có bản 4x6 */
.receipt-top{
  position:relative !important;
  display:block !important;
  text-align:center !important;
  min-height:auto !important;
  margin-bottom:8px !important;
  padding-right:0 !important;
}

.photo-print{
  position:absolute !important;
  right:10px !important;
  top:60px !important;
  width:86px !important;
  height:112px !important;
  border:1px solid #000 !important;
  display:grid !important;
  place-items:center !important;
  text-align:center !important;
  font-size:12px !important;
  background:white !important;
  overflow:hidden !important;
  margin:0 !important;
}

.photo-caption{
  position:absolute !important;
  right:29px !important;
  top:174px !important;
  font-size:11px !important;
  margin:0 !important;
}

/* QR MRZ cuối phiếu bên trái */
.receipt-footer-tools{
  display:flex;
  justify-content:flex-start;
  align-items:flex-start;
  margin-top:8px;
  min-height:38mm;
}

.mrz-qr-box{
  width:36mm;
  text-align:center;
  font-family:"Times New Roman",serif;
  font-size:11px;
  color:#000;
}

.mrz-qr-box img{
  width:30mm;
  height:30mm;
  border:1px solid #000;
  padding:2px;
  background:white;
  object-fit:contain;
}

.qr-title{
  font-weight:800;
  text-transform:uppercase;
  margin-bottom:2px;
}

.qr-note{
  font-size:10px;
  margin-top:2px;
}

/* Xóa hàng loạt hiện rõ */
.bulk-actions{
  position:sticky;
  top:0;
  z-index:5;
  background:#fff7ed !important;
  border:2px solid #fb923c !important;
  box-shadow:0 8px 24px rgba(15,23,42,.08);
}

.bulk-delete-big{
  font-size:13px !important;
  padding:10px 14px !important;
  background:#dc2626 !important;
  color:white !important;
  border:2px solid #991b1b !important;
}

.bulk-count{
  background:#fee2e2;
  color:#991b1b;
  padding:8px 10px;
  border-radius:999px;
  font-weight:900;
}

/* Cho cột checkbox dễ thấy */
.record-select-checkbox{
  width:18px;
  height:18px;
  cursor:pointer;
}

@media print{
  .receipt-footer-tools{
    page-break-inside:avoid;
  }
  .mrz-qr-box img{
    print-color-adjust:exact;
    -webkit-print-color-adjust:exact;
  }
}

/* =========================================================
   V16 - HIỆN RÕ XÓA HÀNG LOẠT
   ========================================================= */
.bulk-actions-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  padding:14px;
  margin:12px 0 16px;
  border:2px solid #f97316;
  background:linear-gradient(135deg,#fff7ed,#fffbeb);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(15,23,42,.08);
}

.bulk-actions-top b{
  display:block;
  color:#9a3412;
  font-size:15px;
}

.bulk-actions-top span{
  display:inline-block;
  margin-top:4px;
  background:#fee2e2;
  color:#991b1b;
  font-weight:900;
  padding:6px 10px;
  border-radius:999px;
}

.bulk-actions-buttons{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.floating-bulk-delete-bar{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%) translateY(130%);
  width:min(980px,calc(100% - 28px));
  z-index:9999;
  background:#111827;
  color:white;
  border:2px solid #f97316;
  border-radius:22px;
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  opacity:0;
  pointer-events:none;
  transition:.22s ease;
}

.floating-bulk-delete-bar.show{
  transform:translateX(-50%) translateY(0);
  opacity:1;
  pointer-events:auto;
}

.floating-bulk-delete-bar b{
  display:block;
  font-size:16px;
  color:#fff;
}

.floating-bulk-delete-bar span{
  display:block;
  color:#cbd5e1;
  font-size:13px;
  margin-top:3px;
}

.floating-bulk-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.floating-bulk-actions .btn.danger,
.bulk-actions-buttons .btn.danger{
  background:#dc2626!important;
  color:#fff!important;
  border:2px solid #ef4444!important;
  font-weight:1000!important;
}

.record-select-checkbox{
  width:20px!important;
  height:20px!important;
  cursor:pointer!important;
  accent-color:#dc2626;
}

@media(max-width:760px){
  .floating-bulk-delete-bar{
    flex-direction:column;
    align-items:stretch;
  }
  .floating-bulk-actions .btn{
    width:100%;
  }
}



/* =========================================================
   V17 - CUỐI PHIẾU: QR NHỎ + CHỈ XÁC NHẬN CHỦ CƠ SỞ
   ========================================================= */

/* Ẩn/không dùng layout cam đoan cũ nếu còn sót */
.sign-print{
  display:none !important;
}

/* Dòng cuối phiếu: QR bên trái, xác nhận chủ cơ sở bên phải, ngang hàng */
.receipt-bottom-row{
  display:grid !important;
  grid-template-columns: 34mm 1fr !important;
  gap: 28mm !important;
  align-items:start !important;
  margin-top:8mm !important;
  page-break-inside:avoid !important;
}

/* QR nhỏ lại */
.mrz-qr-box.compact{
  width:30mm !important;
  text-align:center !important;
  font-family:"Times New Roman",serif !important;
  color:#000 !important;
  font-size:10px !important;
  margin:0 !important;
}

.mrz-qr-box.compact img{
  width:24mm !important;
  height:24mm !important;
  border:1px solid #000 !important;
  padding:1.5px !important;
  background:white !important;
  object-fit:contain !important;
}

.mrz-qr-box.compact .qr-title{
  font-weight:800 !important;
  text-transform:uppercase !important;
  margin-bottom:2px !important;
  font-size:10px !important;
}

.mrz-qr-box.compact .qr-note{
  font-size:9px !important;
  line-height:1.1 !important;
  margin-top:2px !important;
}

/* Xác nhận chủ cơ sở giữ ở bên phải */
.owner-confirm-only{
  text-align:center !important;
  font-family:"Times New Roman",serif !important;
  color:#000 !important;
  max-width:95mm !important;
  justify-self:end !important;
}

.owner-confirm-only b{
  text-transform:uppercase !important;
  font-size:15px !important;
}

.owner-confirm-only p{
  margin:4px 0 !important;
  line-height:1.25 !important;
}

.owner-confirm-only i{
  display:block !important;
  margin-top:2px !important;
}

.owner-confirm-only .sign-space{
  height:22mm !important;
}

@media print{
  .receipt-bottom-row{
    margin-top:6mm !important;
    grid-template-columns: 32mm 1fr !important;
    gap:24mm !important;
  }
  .mrz-qr-box.compact img{
    width:23mm !important;
    height:23mm !important;
    print-color-adjust:exact;
    -webkit-print-color-adjust:exact;
  }
}

/* V18 AUTO FORM NUMBER */
input[name="form_no"][readonly]{
  background:#f8fafc!important;
  color:#334155!important;
  font-weight:900!important;
  border-style:dashed!important;
}
.form-no-hint{
  font-size:12px;
  color:#64748b;
  margin-top:4px;
}

/* =========================================================
   V19 - FIX QR MRZ KHÔNG HIỆN
   ========================================================= */
.qr-render{
  width:24mm!important;
  height:24mm!important;
  display:grid!important;
  place-items:center!important;
  background:#fff!important;
  border:1px solid #000!important;
  padding:1px!important;
  margin:0 auto!important;
  box-sizing:border-box!important;
}

.qr-render canvas,
.qr-render img{
  width:22mm!important;
  height:22mm!important;
  display:block!important;
  image-rendering:pixelated;
}

@media print{
  .qr-render,
  .qr-render canvas,
  .qr-render img{
    print-color-adjust:exact;
    -webkit-print-color-adjust:exact;
  }
}

/* V20 FIX LOGIN CODE */
.login-clear-btn{
  margin-top:10px;
  width:100%;
  border:1px solid #fecaca;
  background:#fff1f2;
  color:#991b1b;
  border-radius:14px;
  padding:12px;
  font-weight:900;
  cursor:pointer;
}
.login-clear-btn:hover{background:#fee2e2}
.login-error-box{
  background:#fee2e2;
  color:#991b1b;
  border:1px solid #fecaca;
  border-radius:14px;
  padding:10px 12px;
  margin-top:10px;
  font-weight:800;
  line-height:1.45;
}

/* V21 LOGIN FIX */
.login-clear-btn{
  margin-top:10px;
  width:100%;
  border:1px solid #fecaca;
  background:#fff1f2;
  color:#991b1b;
  border-radius:14px;
  padding:12px;
  font-weight:900;
  cursor:pointer;
}
.login-clear-btn:hover{background:#fee2e2}
.login-error-box{
  background:#fee2e2;
  color:#991b1b;
  border:1px solid #fecaca;
  border-radius:14px;
  padding:10px 12px;
  margin-top:10px;
  font-weight:800;
  line-height:1.45;
}

/* V22 FIX PRINT/PDF */
.pdf-render-holder .receipt-a4{
  display:block!important;
  background:#fff!important;
}
.qr-fallback-text{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  font-weight:900;
  border:1px solid #000;
}
@media print{
  #printArea{
    display:block!important;
  }
  .receipt-a4{
    display:block!important;
  }
}



/* =========================================================
   V24 FINAL PRINT/PDF RECEIPT
   ========================================================= */
.v24-receipt{
  font-family:"Times New Roman",serif!important;
  color:#000!important;
  background:#fff!important;
  width:210mm!important;
  min-height:297mm!important;
  padding:9mm 10mm!important;
  box-sizing:border-box!important;
  font-size:13.5px!important;
  line-height:1.22!important;
}

.v24-receipt .receipt-top{
  position:relative!important;
  display:block!important;
  text-align:center!important;
  min-height:40mm!important;
}

.v24-receipt .receipt-top h2{
  font-size:20px!important;
  margin:8px 0 0!important;
}

.v24-receipt .receipt-top h3{
  font-size:15px!important;
  margin:2px 0 8px!important;
}

.v24-receipt .receipt-no{
  position:absolute!important;
  right:0!important;
  top:0!important;
  border:1px solid #000!important;
  padding:3px 8px!important;
  font-size:12px!important;
}

.v24-receipt .photo-print{
  position:absolute!important;
  right:0!important;
  top:22mm!important;
  width:28mm!important;
  height:36mm!important;
  border:1px solid #000!important;
  display:grid!important;
  place-items:center!important;
  background:#fff!important;
  overflow:hidden!important;
  font-size:11px!important;
}

.v24-receipt .photo-print img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
}

.v24-receipt .photo-caption{
  position:absolute!important;
  right:6mm!important;
  top:59mm!important;
  font-size:10px!important;
}

.v24-receipt .receipt-note{
  font-style:italic!important;
  margin:4px 0 8px!important;
  max-width:155mm!important;
}

.v24-receipt .receipt-section-title{
  font-weight:900!important;
  text-transform:uppercase!important;
  font-size:15px!important;
  margin:5px 0!important;
}

.v24-receipt .form-line{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:4px!important;
  align-items:flex-end!important;
  margin:3px 0!important;
  min-height:19px!important;
}

.v24-receipt .fill{
  border-bottom:1px dotted #000!important;
  min-width:40mm!important;
  flex:1!important;
  padding:0 4px!important;
  font-weight:700!important;
}

.v24-receipt .fill.short{min-width:22mm!important;flex:0 0 auto!important}
.v24-receipt .fill.mid{min-width:45mm!important;flex:0 0 auto!important}
.v24-receipt .fill.long{min-width:145mm!important;flex:1 1 145mm!important}

.v24-receipt .print-check-grid{
  display:grid!important;
  grid-template-columns:repeat(4,1fr)!important;
  gap:8px 12px!important;
  margin:7px 0!important;
}

.v24-receipt .check-box{
  display:inline-block!important;
  width:5mm!important;
  height:5mm!important;
  border:1px solid #000!important;
  vertical-align:middle!important;
  margin-left:4px!important;
}

.v24-receipt .receipt-bottom-row{
  display:grid!important;
  grid-template-columns:32mm 1fr!important;
  gap:28mm!important;
  align-items:start!important;
  margin-top:7mm!important;
  page-break-inside:avoid!important;
}

.v24-receipt .mrz-qr-box.compact{
  width:29mm!important;
  text-align:center!important;
  font-size:10px!important;
}

.v24-receipt .qr-render{
  width:24mm!important;
  height:24mm!important;
  display:grid!important;
  place-items:center!important;
  border:1px solid #000!important;
  background:#fff!important;
  padding:1px!important;
  margin:0 auto!important;
  box-sizing:border-box!important;
}

.v24-receipt .qr-render canvas,
.v24-receipt .qr-render img{
  width:22mm!important;
  height:22mm!important;
  display:block!important;
}

.v24-receipt .qr-title{
  font-weight:900!important;
  text-transform:uppercase!important;
  margin-bottom:2px!important;
}

.v24-receipt .qr-note{
  font-size:9px!important;
  line-height:1.1!important;
  margin-top:2px!important;
}

.v24-receipt .owner-confirm-only{
  text-align:center!important;
  justify-self:end!important;
  max-width:100mm!important;
}

.v24-receipt .owner-confirm-only b{
  text-transform:uppercase!important;
  font-size:15px!important;
}

.v24-receipt .owner-confirm-only p{
  margin:4px 0!important;
}

.v24-receipt .sign-space{
  height:22mm!important;
}

.pdf-render-holder{
  z-index:-1!important;
}

@media print{
  body *{visibility:hidden!important}
  #printArea, #printArea *{visibility:visible!important}
  #printArea{
    position:absolute!important;
    left:0!important;
    top:0!important;
    width:210mm!important;
    background:#fff!important;
  }
  .v24-receipt{
    width:210mm!important;
    min-height:297mm!important;
    box-shadow:none!important;
    margin:0!important;
    print-color-adjust:exact;
    -webkit-print-color-adjust:exact;
  }
}

/* =========================================================
   V28 - SEARCHABLE ADDRESS SELECT
   ========================================================= */
.smart-search-wrap{
  position:relative;
  width:100%;
}

.smart-search-input{
  width:100%;
  margin-bottom:8px;
  background:#fff!important;
  border:2px solid #dbeafe!important;
}

.smart-search-input:focus{
  border-color:#14b8a6!important;
  box-shadow:0 0 0 4px rgba(20,184,166,.12)!important;
}

.smart-search-hidden-select{
  display:none!important;
}

.smart-search-list{
  position:absolute;
  left:0;
  right:0;
  top:58px;
  max-height:280px;
  overflow:auto;
  z-index:99999;
  background:#fff;
  border:1px solid #bfdbfe;
  box-shadow:0 18px 48px rgba(15,23,42,.18);
  border-radius:16px;
  padding:8px;
}

.smart-search-item{
  width:100%;
  border:0;
  background:#fff;
  display:flex;
  gap:10px;
  align-items:center;
  padding:11px 12px;
  border-radius:12px;
  cursor:pointer;
  text-align:left;
  font-size:14px;
}

.smart-search-item:hover{
  background:#eff6ff;
}

.smart-search-item b{
  min-width:58px;
  color:#0f766e;
  font-weight:900;
}

.smart-search-item span{
  color:#0f172a;
  font-weight:700;
}

.smart-search-empty{
  padding:12px;
  color:#991b1b;
  background:#fee2e2;
  border-radius:12px;
  font-weight:800;
}

/* =========================================================
   V29 - QR ẢNH TRỰC TIẾP
   ========================================================= */
.qr-img-ready{
  width:24mm!important;
  height:24mm!important;
  border:1px solid #000!important;
  padding:1px!important;
  background:white!important;
  object-fit:contain!important;
}
.mrz-qr-box.compact{
  width:30mm!important;
  text-align:center!important;
}

/* =========================================================
   V30 - PLACEHOLDER RÕ RÀNG, KHÔNG HIỆN SẴN DỮ LIỆU
   ========================================================= */
input::placeholder,
textarea::placeholder{
  color:#94a3b8!important;
  opacity:1!important;
  font-weight:500!important;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus{
  -webkit-text-fill-color:#0f172a;
  transition: background-color 9999s ease-in-out 0s;
}

/* V31 - địa chỉ trên phiếu rõ mã - tên */
.v26-receipt .form-line .fill.mid{
  word-break:break-word!important;
}

/* =========================================================
   V33 - KHÓA HỒ SƠ
   ========================================================= */
.badge.locked{
  background:#fee2e2!important;
  color:#991b1b!important;
  border:1px solid #fecaca!important;
}

.badge.unlock{
  background:#ecfdf5!important;
  color:#047857!important;
  border:1px solid #bbf7d0!important;
}

.v33-lock-inline{
  display:inline-flex;
  margin-right:4px;
  vertical-align:middle;
}

.btn.warn{
  background:#f97316!important;
  color:#fff!important;
}

.btn.success{
  background:#059669!important;
  color:#fff!important;
}

button:disabled{
  opacity:.55!important;
  cursor:not-allowed!important;
}

/* =========================================================
   V34 - TRA CỨU / IN PHIẾU NGOÀI MÀN HÌNH ĐĂNG NHẬP
   ========================================================= */
.public-print-box{
  margin-top:16px;
  padding:14px;
  border:1px solid #bfdbfe;
  background:linear-gradient(135deg,#eff6ff,#f8fafc);
  border-radius:18px;
}

.public-print-title{
  font-weight:1000;
  color:#0f172a;
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:4px;
}

.public-print-box p{
  margin:4px 0 10px;
  color:#64748b;
  font-size:13px;
}

.public-print-row{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:8px;
  align-items:center;
}

.public-lookup-result{
  margin-top:10px;
}

.public-loading,
.public-error,
.public-found{
  padding:10px 12px;
  border-radius:14px;
  font-weight:800;
}

.public-loading{
  background:#e0f2fe;
  color:#075985;
}

.public-error{
  background:#fee2e2;
  color:#991b1b;
  border:1px solid #fecaca;
}

.public-found{
  background:#ecfdf5;
  color:#065f46;
  border:1px solid #bbf7d0;
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
}

.public-found b{
  display:block;
  color:#064e3b;
  font-size:15px;
}

.public-found span{
  display:inline-block;
  margin-right:10px;
  font-size:12px;
  color:#334155;
}

@media(max-width:720px){
  .public-print-row{
    grid-template-columns:1fr;
  }
  .public-found{
    flex-direction:column;
    align-items:stretch;
  }
}

/* V35 - public print stronger */
#publicPrintFrameV35{pointer-events:none!important}
.public-print-box{
  margin-top:16px;
  padding:14px;
  border:1px solid #bfdbfe;
  background:linear-gradient(135deg,#eff6ff,#f8fafc);
  border-radius:18px;
}
.public-print-title{
  font-weight:1000;
  color:#0f172a;
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:4px;
}
.public-print-box p{
  margin:4px 0 10px;
  color:#64748b;
  font-size:13px;
}
.public-print-row{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:8px;
  align-items:center;
}
.public-lookup-result{margin-top:10px}
.public-loading,.public-error,.public-found{
  padding:10px 12px;
  border-radius:14px;
  font-weight:800;
}
.public-loading{background:#e0f2fe;color:#075985}
.public-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.public-found{
  background:#ecfdf5;
  color:#065f46;
  border:1px solid #bbf7d0;
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
}
.public-found b{display:block;color:#064e3b;font-size:15px}
.public-found span{display:inline-block;margin-right:10px;font-size:12px;color:#334155}
@media(max-width:720px){
  .public-print-row{grid-template-columns:1fr}
  .public-found{flex-direction:column;align-items:stretch}
}

/* V36 - Excel import cư dân */
.excel-error{
  color:#991b1b!important;
  background:#fee2e2!important;
  font-weight:800!important;
}
.excel-ok{
  color:#047857!important;
  background:#dcfce7!important;
  font-weight:800!important;
}

/* =========================================================
   V40 - XUẤT PDF HÀNG LOẠT HỒ SƠ ĐÃ CHỌN
   ========================================================= */
.bulk-pdf-floating-v40{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:9999;
  display:none;
  align-items:center;
  gap:10px;
  padding:10px;
  border-radius:18px;
  background:rgba(15,23,42,.92);
  box-shadow:0 18px 45px rgba(15,23,42,.25);
}

.bulk-pdf-floating-v40 .btn{
  white-space:nowrap;
}

.v40-pdf-holder{
  pointer-events:none!important;
}

/* =========================================================
   V41 - IN/PDF HÀNG LOẠT LUÔN HIỆN
   ========================================================= */
.v41-bulk-toolbar{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  z-index:99999;
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px;
  border-radius:18px;
  background:rgba(15,23,42,.94);
  box-shadow:0 20px 55px rgba(15,23,42,.32);
  color:#fff;
  max-width:calc(100vw - 24px);
  overflow:auto;
}

.v41-bulk-title{
  font-weight:900;
  white-space:nowrap;
  padding:0 8px;
}

.v41-check-wrap{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-right:6px;
  vertical-align:middle;
}

.v41-check-wrap input,
.v41-record-check{
  width:18px!important;
  height:18px!important;
  accent-color:#0f766e;
  cursor:pointer;
}

.v41-select-all-th{
  width:42px!important;
  text-align:center!important;
}

.v41-pdf-holder,
#v41BulkPrintFrame{
  pointer-events:none!important;
}

@media(max-width:760px){
  .v41-bulk-toolbar{
    left:8px;
    right:8px;
    transform:none;
    bottom:8px;
    flex-wrap:wrap;
    justify-content:center;
  }
  .v41-bulk-title{
    width:100%;
    text-align:center;
  }
}

/* =========================================================
   V42 - Không cho thanh hàng loạt hiện ở màn hình đăng nhập
   ========================================================= */
body:has(#loginScreen:not(.hide)) #v41BulkToolbar,
body:has(.login-screen:not(.hide)) #v41BulkToolbar{
  display:none!important;
}

/* =========================================================
   V43 - CHỮ KÝ SỐ TRÊN PHIẾU
   ========================================================= */
.v43-digital-signature{margin-top:8px;display:grid;grid-template-columns:44mm 1fr;gap:8mm;align-items:center;width:100%;color:#000;page-break-inside:avoid;break-inside:avoid}
.v43-signature-left{text-align:center;min-height:25mm}
.v43-signature-img{width:42mm;max-height:23mm;object-fit:contain;display:block;margin:0 auto}
.v43-signature-name{font-family:"Times New Roman",serif;font-size:12px;color:#000;margin-top:1px}
.v43-signature-right{text-align:left;font-family:"Times New Roman",serif;font-size:13px;line-height:1.15;color:#000}
.v43-approved-by{font-weight:700;text-align:center;font-size:14px;margin-bottom:3px}
.v43-signed-text{white-space:normal;font-size:13px}

/* =========================================================
   V44 - MÀN HÌNH CẤU HÌNH CHỮ KÝ SỐ ADMIN
   ========================================================= */
.signature-admin-btn{
  background:#7c3aed!important;
  color:#fff!important;
}

.v44-signature-floating-host{
  position:fixed;
  right:24px;
  top:24px;
  z-index:9999;
}

.v44-modal{
  position:fixed;
  inset:0;
  z-index:100000;
  background:rgba(15,23,42,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.v44-modal.hide{
  display:none!important;
}

.v44-modal-card{
  width:min(760px,96vw);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border-radius:24px;
  box-shadow:0 30px 80px rgba(15,23,42,.35);
  padding:22px;
}

.v44-modal-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  border-bottom:1px solid #e2e8f0;
  padding-bottom:12px;
  margin-bottom:16px;
}

.v44-modal-head h2{
  margin:0;
  color:#0f172a;
  font-size:24px;
}

.v44-modal-head p{
  margin:4px 0 0;
  color:#64748b;
}

.v44-close{
  border:0;
  background:#fee2e2;
  color:#991b1b;
  width:42px;
  height:42px;
  border-radius:14px;
  cursor:pointer;
  font-weight:900;
}

.v44-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.v44-form-grid label{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-weight:900;
  color:#334155;
}

.v44-form-grid input,
.v44-form-grid select{
  width:100%;
  border:1px solid #cbd5e1;
  border-radius:14px;
  padding:12px 14px;
  font-size:15px;
  outline:none;
}

.v44-form-grid input:focus,
.v44-form-grid select:focus{
  border-color:#7c3aed;
  box-shadow:0 0 0 4px rgba(124,58,237,.12);
}

.v44-form-grid small{
  color:#64748b;
  font-weight:600;
}

.v44-full{
  grid-column:1 / -1;
}

.v44-preview-title{
  margin-top:18px;
  font-weight:1000;
  color:#0f172a;
}

#v44SignaturePreviewBox{
  margin-top:8px;
  border:1px dashed #94a3b8;
  border-radius:18px;
  padding:14px;
  background:#f8fafc;
}

.v44-signature-preview{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:20px;
  align-items:center;
  max-width:560px;
  margin:auto;
  background:#fff;
  padding:12px;
  border-radius:14px;
}

.v44-preview-left{
  text-align:center;
}

.v44-preview-left img{
  max-width:190px;
  max-height:92px;
  object-fit:contain;
}

.v44-preview-left div{
  font-family:"Times New Roman",serif;
  font-size:18px;
  color:#000;
}

.v44-preview-right{
  font-family:"Times New Roman",serif;
  color:#000;
  font-size:18px;
  line-height:1.15;
}

.v44-preview-right b{
  display:block;
  text-align:center;
  margin-bottom:4px;
}

.v44-preview-right p{
  margin:0;
}

.v44-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:18px;
}

@media(max-width:720px){
  .v44-form-grid{
    grid-template-columns:1fr;
  }
  .v44-signature-preview{
    grid-template-columns:1fr;
  }
}

/* =========================================================
   V45 - THÊM ẢNH HÀNG LOẠT THEO SỐ PHIẾU
   ========================================================= */
.v45-bulk-photo-btn{
  background:#0f766e!important;
  color:#fff!important;
}

.v45-floating-host{
  position:fixed;
  right:24px;
  top:80px;
  z-index:9999;
}

.v45-modal{
  position:fixed;
  inset:0;
  z-index:100000;
  background:rgba(15,23,42,.58);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.v45-modal.hide{
  display:none!important;
}

.v45-modal-card{
  width:min(980px,96vw);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border-radius:24px;
  box-shadow:0 30px 80px rgba(15,23,42,.35);
  padding:22px;
}

.v45-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid #e2e8f0;
  margin-bottom:16px;
}

.v45-modal-head h2{
  margin:0;
  font-size:24px;
  color:#0f172a;
}

.v45-modal-head p{
  margin:5px 0 0;
  color:#64748b;
}

.v45-close{
  width:42px;
  height:42px;
  border:0;
  border-radius:14px;
  background:#fee2e2;
  color:#991b1b;
  cursor:pointer;
}

.v45-upload-box{
  margin-bottom:14px;
}

.v45-file-drop{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-height:150px;
  border:2px dashed #0f766e;
  background:#f0fdfa;
  border-radius:20px;
  cursor:pointer;
  text-align:center;
  padding:20px;
}

.v45-file-drop input{
  display:none;
}

.v45-file-drop i{
  font-size:38px;
  color:#0f766e;
  margin-bottom:8px;
}

.v45-file-drop b{
  font-size:18px;
  color:#0f172a;
}

.v45-file-drop span{
  color:#64748b;
  margin-top:4px;
}

.v45-info-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-bottom:14px;
}

.v45-info-grid div{
  border:1px solid #e2e8f0;
  background:#f8fafc;
  border-radius:16px;
  padding:12px;
  text-align:center;
}

.v45-info-grid b{
  display:block;
  font-size:24px;
  color:#0f766e;
}

.v45-info-grid span{
  color:#64748b;
  font-weight:800;
}

.v45-preview-title{
  font-weight:1000;
  color:#0f172a;
  margin:12px 0 8px;
}

.v45-photo-table-wrap{
  overflow:auto;
  border:1px solid #e2e8f0;
  border-radius:16px;
}

.v45-photo-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
}

.v45-photo-table th,
.v45-photo-table td{
  padding:10px 12px;
  border-bottom:1px solid #e2e8f0;
  text-align:left;
  vertical-align:top;
}

.v45-photo-table th{
  background:#f8fafc;
  color:#334155;
  font-weight:1000;
}

.v45-status{
  display:inline-flex;
  padding:5px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
}

.v45-status.ok{
  background:#dcfce7;
  color:#166534;
}

.v45-status.bad,
.v45-bad{
  background:#fee2e2;
  color:#991b1b;
  padding:5px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
}

.v45-progress{
  height:10px;
  background:#e2e8f0;
  border-radius:999px;
  overflow:hidden;
  margin-top:14px;
}

.v45-progress.hide{
  display:none!important;
}

#v45BulkPhotoProgressBar{
  height:100%;
  width:0%;
  background:#0f766e;
  transition:.2s;
}

.v45-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:16px;
}

@media(max-width:720px){
  .v45-info-grid{
    grid-template-columns:1fr;
  }
  .v45-modal-actions{
    flex-direction:column;
  }
}

/* =========================================================
   V46 - Chữ ký số chỉ hiện một lần, gọn hơn
   ========================================================= */
.v43-digital-signature + .v43-digital-signature{
  display:none!important;
}

.v43-digital-signature{
  margin-top:5px!important;
  max-width:115mm;
  margin-left:auto;
  margin-right:auto;
}

/* =========================================================
   V47 - CHỮ KÝ SỐ THEO TÀI KHOẢN + LOOKUP ROLE
   ========================================================= */
.v47-user-sign-btn{
  background:#7c3aed!important;
  color:#fff!important;
  margin-left:6px;
}

.v47-modal{
  position:fixed;
  inset:0;
  z-index:100000;
  background:rgba(15,23,42,.58);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.v47-modal.hide{
  display:none!important;
}

.v47-modal-card{
  width:min(820px,96vw);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border-radius:24px;
  box-shadow:0 30px 80px rgba(15,23,42,.35);
  padding:22px;
}

.v47-modal-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  border-bottom:1px solid #e2e8f0;
  padding-bottom:14px;
  margin-bottom:16px;
}

.v47-modal-head h2{
  margin:0;
  color:#0f172a;
  font-size:24px;
}

.v47-modal-head p{
  margin:5px 0 0;
  color:#64748b;
}

.v47-close{
  width:42px;
  height:42px;
  border:0;
  border-radius:14px;
  background:#fee2e2;
  color:#991b1b;
  cursor:pointer;
}

.v47-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.v47-form-grid label{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-weight:900;
  color:#334155;
}

.v47-form-grid input,
.v47-form-grid select{
  width:100%;
  border:1px solid #cbd5e1;
  border-radius:14px;
  padding:12px 14px;
  font-size:15px;
  outline:none;
}

.v47-form-grid input:focus,
.v47-form-grid select:focus{
  border-color:#7c3aed;
  box-shadow:0 0 0 4px rgba(124,58,237,.12);
}

.v47-form-grid small{
  color:#64748b;
}

.v47-full{
  grid-column:1 / -1;
}

.v47-preview-title{
  margin-top:16px;
  font-weight:1000;
  color:#0f172a;
}

#v47SignaturePreview{
  margin-top:8px;
  border:1px dashed #94a3b8;
  border-radius:18px;
  padding:14px;
  background:#f8fafc;
}

.v47-sign-preview{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:20px;
  align-items:center;
  max-width:560px;
  margin:auto;
  background:#fff;
  padding:12px;
  border-radius:14px;
}

.v47-sign-preview.disabled{
  opacity:.45;
}

.v47-sign-left{
  text-align:center;
}

.v47-sign-left img{
  max-width:190px;
  max-height:92px;
  object-fit:contain;
}

.v47-sign-left b{
  display:block;
  font-family:"Times New Roman",serif;
  font-size:18px;
  color:#000;
}

.v47-no-sign{
  border:1px dashed #cbd5e1;
  padding:24px;
  border-radius:12px;
  color:#64748b;
}

.v47-sign-right{
  font-family:"Times New Roman",serif;
  color:#000;
  font-size:18px;
  line-height:1.15;
}

.v47-sign-right h3{
  text-align:center;
  margin:0 0 4px;
}

.v47-sign-right p{
  margin:0;
}

.v47-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:18px;
}

.v47-approved-signature{
  margin-top:6px;
  display:grid;
  grid-template-columns:44mm 1fr;
  gap:8mm;
  align-items:center;
  width:100%;
  color:#000;
  page-break-inside:avoid;
  break-inside:avoid;
}

.v47-approved-left{
  text-align:center;
  min-height:25mm;
}

.v47-approved-left img{
  width:42mm;
  max-height:23mm;
  object-fit:contain;
  display:block;
  margin:0 auto;
}

.v47-approved-left div{
  font-family:"Times New Roman",serif;
  font-size:12px;
  color:#000;
}

.v47-approved-right{
  text-align:left;
  font-family:"Times New Roman",serif;
  font-size:13px;
  line-height:1.15;
  color:#000;
}

.v47-approved-right b{
  display:block;
  text-align:center;
  font-size:14px;
  margin-bottom:3px;
}

.v47-approved-right p{
  margin:0;
}

.lookup-only-mode .admin-only,
.lookup-only-mode .manager-only,
.lookup-only-mode .input-only{
  display:none!important;
}

@media(max-width:720px){
  .v47-form-grid,
  .v47-sign-preview{
    grid-template-columns:1fr;
  }
}

/* V48 - Chữ ký duyệt chỉ 1 lần */
.v43-digital-signature,
.v47-approved-signature{
  display:none!important;
}
.v48-approved-signature{
  margin-top:5px!important;
  display:grid;
  grid-template-columns:34mm 1fr;
  gap:6mm;
  align-items:center;
  width:100%;
  max-width:92mm;
  margin-left:auto;
  margin-right:auto;
  color:#000;
  page-break-inside:avoid;
  break-inside:avoid;
}
.v48-approved-left{text-align:center;min-height:20mm}
.v48-approved-left img{width:32mm;max-height:18mm;object-fit:contain;display:block;margin:0 auto}
.v48-approved-left div{font-family:"Times New Roman",serif;font-size:10.5px;color:#000}
.v48-approved-right{text-align:left;font-family:"Times New Roman",serif;font-size:11px;line-height:1.08;color:#000}
.v48-approved-right b{display:block;text-align:center;font-size:12px;margin-bottom:2px}
.v48-approved-right p{margin:0}

/* =========================================================
   V49 - Chữ ký dạng mẫu và ép 1 trang
   ========================================================= */
.v43-digital-signature,
.v47-approved-signature,
.v48-approved-signature{
  display:none!important;
}

.receipt-a4,
.v26-receipt,
.v41-receipt{
  overflow:hidden!important;
}

.receipt-bottom-row{
  margin-top:4mm!important;
  align-items:start!important;
}

.owner-confirm-only{
  font-size:11px!important;
  line-height:1.08!important;
}

.owner-confirm-only p{
  margin:2px 0!important;
}

.owner-confirm-only b{
  font-size:12px!important;
}

.v49-approved-signature{
  margin-top:2mm!important;
  display:grid!important;
  grid-template-columns:43mm 45mm!important;
  gap:6mm!important;
  align-items:center!important;
  justify-content:center!important;
  max-width:96mm!important;
  width:96mm!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:#000!important;
  page-break-inside:avoid!important;
  break-inside:avoid!important;
}

.v49-sign-left{
  text-align:center!important;
}

.v49-sign-left img{
  width:42mm!important;
  max-height:18mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:0 auto!important;
}

.v49-sign-name{
  font-family:"Times New Roman",serif!important;
  font-size:10.5px!important;
  color:#000!important;
  margin-top:0!important;
}

.v49-sign-right{
  text-align:left!important;
  font-family:"Times New Roman",serif!important;
  color:#000!important;
}

.v49-sign-title{
  font-weight:700!important;
  text-align:center!important;
  font-size:12px!important;
  margin-bottom:2px!important;
}

.v49-sign-text{
  font-size:11px!important;
  line-height:1.08!important;
  white-space:normal!important;
}

@media print{
  .receipt-a4,
  .v26-receipt,
  .v41-receipt{
    max-height:297mm!important;
    overflow:hidden!important;
  }
}

/* =========================================================
   V50 - Fix không hiện mã HTML chữ ký
   ========================================================= */
.v43-digital-signature,
.v47-approved-signature,
.v48-approved-signature,
.v49-approved-signature{
  display:none!important;
}

.v50-approved-signature{
  margin-top:2mm!important;
  display:grid!important;
  grid-template-columns:42mm 48mm!important;
  gap:6mm!important;
  align-items:center!important;
  justify-content:center!important;
  width:96mm!important;
  max-width:96mm!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:#000!important;
  page-break-inside:avoid!important;
  break-inside:avoid!important;
  overflow:hidden!important;
}

.v50-sign-left{
  text-align:center!important;
  overflow:hidden!important;
}

.v50-sign-left img{
  width:42mm!important;
  max-height:18mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:0 auto!important;
}

.v50-sign-name{
  font-family:"Times New Roman",serif!important;
  font-size:10.5px!important;
  color:#000!important;
  margin-top:0!important;
}

.v50-sign-right{
  text-align:left!important;
  font-family:"Times New Roman",serif!important;
  color:#000!important;
  overflow:hidden!important;
}

.v50-sign-title{
  font-weight:700!important;
  text-align:center!important;
  font-size:12px!important;
  margin-bottom:2px!important;
}

.v50-sign-text{
  font-size:11px!important;
  line-height:1.08!important;
  white-space:normal!important;
}

.owner-confirm-only{
  font-size:11px!important;
  line-height:1.08!important;
}

.owner-confirm-only p{
  margin:2px 0!important;
}

.receipt-bottom-row{
  margin-top:4mm!important;
}

/* =========================================================
   V51 - Hiện ảnh chữ ký hoặc cảnh báo chưa cấu hình
   ========================================================= */
.v50-approved-signature{
  display:none!important;
}

.v51-approved-signature{
  margin-top:2mm!important;
  display:grid!important;
  grid-template-columns:42mm 48mm!important;
  gap:6mm!important;
  align-items:center!important;
  justify-content:center!important;
  width:96mm!important;
  max-width:96mm!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:#000!important;
  page-break-inside:avoid!important;
  break-inside:avoid!important;
  overflow:hidden!important;
}

.v51-sign-left{
  text-align:center!important;
  overflow:hidden!important;
}

.v51-sign-left img{
  width:42mm!important;
  max-height:18mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:0 auto!important;
}

.v51-sign-name{
  font-family:"Times New Roman",serif!important;
  font-size:10.5px!important;
  color:#000!important;
  margin-top:0!important;
}

.v51-sign-right{
  text-align:left!important;
  font-family:"Times New Roman",serif!important;
  color:#000!important;
  overflow:hidden!important;
}

.v51-sign-title{
  font-weight:700!important;
  text-align:center!important;
  font-size:12px!important;
  margin-bottom:2px!important;
}

.v51-sign-text{
  font-size:11px!important;
  line-height:1.08!important;
  white-space:normal!important;
}

.v51-missing-sign-img{
  width:38mm;
  min-height:12mm;
  border:1px dashed #999;
  color:#555;
  font-size:8px;
  line-height:1.05;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1mm;
}

/* =========================================================
   V52 - Ép hiện chữ ký duyệt
   ========================================================= */
.v43-digital-signature,
.v47-approved-signature,
.v48-approved-signature,
.v49-approved-signature,
.v50-approved-signature,
.v51-approved-signature{
  display:none!important;
}

.v52-approved-signature{
  margin-top:2mm!important;
  display:grid!important;
  grid-template-columns:42mm 48mm!important;
  gap:6mm!important;
  align-items:center!important;
  justify-content:center!important;
  width:96mm!important;
  max-width:96mm!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:#000!important;
  page-break-inside:avoid!important;
  break-inside:avoid!important;
  overflow:hidden!important;
}

.v52-sign-left{
  text-align:center!important;
  overflow:hidden!important;
}

.v52-sign-left img{
  width:42mm!important;
  max-height:18mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:0 auto!important;
}

.v52-sign-name{
  font-family:"Times New Roman",serif!important;
  font-size:10.5px!important;
  color:#000!important;
  margin-top:0!important;
}

.v52-sign-right{
  text-align:left!important;
  font-family:"Times New Roman",serif!important;
  color:#000!important;
  overflow:hidden!important;
}

.v52-sign-title{
  font-weight:700!important;
  text-align:center!important;
  font-size:12px!important;
  margin-bottom:2px!important;
}

.v52-sign-text{
  font-size:11px!important;
  line-height:1.08!important;
  white-space:normal!important;
}

.v52-missing-img{
  width:38mm;
  min-height:12mm;
  border:1px dashed #999;
  color:#555;
  font-size:8px;
  line-height:1.05;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1mm;
}

.owner-confirm-only{
  font-size:11px!important;
  line-height:1.08!important;
}

.owner-confirm-only p{
  margin:2px 0!important;
}

.receipt-bottom-row{
  margin-top:4mm!important;
}

/* =========================================================
   V54 - Trả mẫu phiếu cũ, chỉ thêm chữ ký gọn
   ========================================================= */
.v43-digital-signature,
.v47-approved-signature,
.v48-approved-signature,
.v49-approved-signature,
.v50-approved-signature,
.v51-approved-signature,
.v52-approved-signature,
.v53-approved-signature{
  display:none!important;
}

.v54-approved-signature{
  margin-top:2mm!important;
  display:grid!important;
  grid-template-columns:42mm 48mm!important;
  gap:6mm!important;
  align-items:center!important;
  justify-content:center!important;
  width:96mm!important;
  max-width:96mm!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:#000!important;
  page-break-inside:avoid!important;
  break-inside:avoid!important;
  overflow:hidden!important;
}

.v54-sign-left{
  text-align:center!important;
  overflow:hidden!important;
}

.v54-sign-left img{
  width:42mm!important;
  max-height:18mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:0 auto!important;
}

.v54-sign-name{
  font-family:"Times New Roman",serif!important;
  font-size:10.5px!important;
  color:#000!important;
  margin-top:0!important;
}

.v54-sign-right{
  text-align:left!important;
  font-family:"Times New Roman",serif!important;
  color:#000!important;
  overflow:hidden!important;
}

.v54-sign-title{
  font-weight:700!important;
  text-align:center!important;
  font-size:12px!important;
  margin-bottom:2px!important;
}

.v54-sign-text{
  font-size:11px!important;
  line-height:1.08!important;
  white-space:normal!important;
}

.v54-missing-img{
  width:38mm;
  min-height:12mm;
  border:1px dashed #999;
  color:#555;
  font-size:8px;
  line-height:1.05;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1mm;
}



/* =========================================================
   V55 - chữ ký số + tiến trình PDF
   ========================================================= */
.v43-digital-signature,
.v47-approved-signature,
.v48-approved-signature,
.v49-approved-signature,
.v50-approved-signature,
.v51-approved-signature,
.v52-approved-signature,
.v53-approved-signature,
.v54-approved-signature{
  display:none!important;
}

.v55-approved-signature{
  margin-top:2mm!important;
  display:grid!important;
  grid-template-columns:42mm 48mm!important;
  gap:6mm!important;
  align-items:center!important;
  justify-content:center!important;
  width:96mm!important;
  max-width:96mm!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:#000!important;
  page-break-inside:avoid!important;
  break-inside:avoid!important;
  overflow:hidden!important;
}

.v55-sign-left{text-align:center!important;overflow:hidden!important;}
.v55-sign-left img{width:42mm!important;max-height:18mm!important;object-fit:contain!important;display:block!important;margin:0 auto!important;}
.v55-sign-name{font-family:"Times New Roman",serif!important;font-size:10.5px!important;color:#000!important;margin-top:0!important;}
.v55-sign-right{text-align:left!important;font-family:"Times New Roman",serif!important;color:#000!important;overflow:hidden!important;}
.v55-sign-title{font-weight:700!important;text-align:center!important;font-size:12px!important;margin-bottom:2px!important;}
.v55-sign-text{font-size:11px!important;line-height:1.08!important;white-space:normal!important;}
.v55-missing-img{width:38mm;min-height:12mm;border:1px dashed #999;color:#555;font-size:8px;line-height:1.05;display:flex;align-items:center;justify-content:center;margin:0 auto 1mm;}

.v55-pdf-progress{
  position:fixed;
  inset:0;
  z-index:200000;
  background:rgba(15,23,42,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
}

.v55-pdf-progress.hide{display:none!important;}

.v55-progress-card{
  width:min(460px,92vw);
  background:#fff;
  border-radius:22px;
  padding:22px;
  box-shadow:0 30px 80px rgba(15,23,42,.35);
  text-align:center;
}

.v55-progress-title{font-weight:1000;font-size:22px;color:#0f172a;}
.v55-progress-count{margin-top:10px;font-size:38px;font-weight:1000;color:#0f766e;}
.v55-progress-bar{height:14px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin-top:14px;}
#v55ProgressBar{height:100%;width:0%;background:#0f766e;transition:.2s;}
.v55-progress-text{margin-top:12px;color:#475569;font-weight:800;}



/* =========================================================
   V56 - Fix QR MRZ trắng
   ========================================================= */
.v56-qr-img,
.qr-img-ready{
  width:22mm!important;
  height:22mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:1mm auto!important;
  border:1px solid #000!important;
  padding:1px!important;
  background:#fff!important;
  box-sizing:border-box!important;
}

.mrz-qr-box,
.v53-qr-box,
.v55-qr-box{
  text-align:center!important;
}



/* =========================================================
   V57 - QR cư dân hợp lệ đầy đủ trường
   ========================================================= */
.v57-qr-img,
.v56-qr-img,
.qr-img-ready{
  width:24mm!important;
  height:24mm!important;
  object-fit:contain!important;
  display:block!important;
  margin:1mm auto!important;
  border:1px solid #000!important;
  padding:1px!important;
  background:#fff!important;
  box-sizing:border-box!important;
}

.mrz-qr-box,
.v53-qr-box,
.v55-qr-box{
  text-align:center!important;
}


.v58-full-reload-btn{background:#0f766e!important;color:#fff!important;}



/* =========================================================
   V59 - Thanh chọn hàng loạt theo bộ lọc
   ========================================================= */
.v59-bulk-bar{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  z-index:99999;
  background:#0f172a;
  color:#fff;
  border-radius:20px;
  padding:10px 12px;
  display:flex;
  gap:8px;
  align-items:center;
  box-shadow:0 18px 50px rgba(15,23,42,.35);
  max-width:96vw;
  overflow:auto;
}

.v59-bulk-bar b{
  white-space:nowrap;
  padding:0 8px;
}

.v59-bulk-bar button{
  border:0;
  border-radius:14px;
  padding:10px 14px;
  font-weight:900;
  cursor:pointer;
  background:#dbeafe;
  color:#1d4ed8;
  white-space:nowrap;
}

.v59-bulk-bar button:nth-child(3){
  background:#dcfce7;
  color:#166534;
}

.v59-bulk-bar button:nth-child(4){
  background:#fee2e2;
  color:#991b1b;
}

.v59-bulk-bar button:nth-child(5){
  background:#e2e8f0;
  color:#0f172a;
}



/* =========================================================
   V60 - chống treo trang
   ========================================================= */
.v60-load-more-btn{
  background:#7c3aed!important;
  color:#fff!important;
}

.v60-fast-notice{
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  border-radius:16px;
  padding:10px 14px;
  margin:10px 0;
  font-weight:800;
}

.v60-shown-note{
  margin-top:4px;
  font-size:12px;
  color:#64748b;
  font-weight:700;
}



/* V61 - tra cứu cư dân ngoài trang đăng nhập */
.v61-public-lookup-box{margin-top:16px;background:#f8fafc;border:1px solid #dbeafe;border-radius:18px;padding:14px}
.v61-lookup-title{font-size:18px;font-weight:1000;color:#0f172a}
.v61-lookup-desc{margin-top:4px;color:#64748b;font-size:14px;line-height:1.4}
.v61-lookup-row{margin-top:12px;display:grid;grid-template-columns:1fr auto;gap:8px}
.v61-lookup-row input{border:1px solid #cbd5e1;border-radius:14px;padding:12px 14px;font-size:15px;outline:none}
.v61-lookup-row input:focus{border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.v61-lookup-row button,.v61-actions button{border:0;border-radius:14px;padding:12px 16px;font-weight:900;background:#2563eb;color:#fff;cursor:pointer}
.v61-public-result{margin-top:12px}
.v61-alert,.v61-loading,.v61-found{padding:12px;border-radius:14px;background:#eff6ff;color:#1d4ed8;font-weight:800}
.v61-alert.danger{background:#fee2e2;color:#991b1b}
.v61-result-list{display:grid;gap:8px}
.v61-result-list button{border:1px solid #cbd5e1;border-radius:14px;background:#fff;padding:12px;text-align:left;cursor:pointer}
.v61-result-list button b{display:block;color:#0f172a}
.v61-result-list button span{display:block;margin-top:3px;color:#64748b;font-size:13px}
.v61-record-card{background:#fff;border:1px solid #dbeafe;border-radius:18px;padding:14px;box-shadow:0 10px 30px rgba(15,23,42,.08)}
.v61-record-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;border-bottom:1px solid #e2e8f0;padding-bottom:10px;margin-bottom:10px}
.v61-record-head h3{margin:0;color:#0f172a;font-size:20px}
.v61-record-head p{margin:4px 0 0;color:#64748b}
.v61-record-head img,.v61-avatar{width:66px;height:88px;border-radius:10px;object-fit:cover;background:#e2e8f0;display:flex;align-items:center;justify-content:center;color:#0f172a}
.v61-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.v61-info-grid div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:8px}
.v61-info-grid b{display:block;font-size:12px;color:#475569}
.v61-info-grid span{display:block;margin-top:3px;color:#0f172a;font-weight:800}
.v61-info-grid .v61-wide{grid-column:1 / -1}
.v61-actions{display:flex;gap:8px;margin-top:12px}
.v61-actions button:nth-child(2){background:#dc2626}
@media(max-width:720px){.v61-lookup-row,.v61-info-grid{grid-template-columns:1fr}}



/* =========================================================
   V63 - chỉ hiện trang tra cứu, giao diện SmartStay cũ
   ========================================================= */
#v62GovLookupPage{
  display:none!important;
}

.v63-login-hidden{
  display:none!important;
}

.v63-login-open{
  display:block!important;
  max-width:560px!important;
  margin:18px auto!important;
  position:relative!important;
  z-index:20!important;
}

.v63-lookup-only-page{
  min-height:100vh;
  padding:42px 18px;
  background:
    radial-gradient(circle at top left, rgba(45,212,191,.22), transparent 34%),
    radial-gradient(circle at top right, rgba(59,130,246,.18), transparent 32%),
    linear-gradient(135deg,#eefdfb,#f8fbff 55%,#eef5ff);
  color:#0f172a;
}

.v63-hero{
  max-width:1120px;
  margin:0 auto 22px;
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:center;
}

.v63-brand{
  display:flex;
  gap:16px;
  align-items:center;
}

.v63-logo{
  width:72px;
  height:72px;
  border-radius:22px;
  background:linear-gradient(135deg,#0f766e,#2563eb);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:34px;
  box-shadow:0 16px 40px rgba(15,118,110,.25);
}

.v63-kicker{
  display:inline-block;
  background:rgba(15,118,110,.12);
  color:#0f766e;
  padding:6px 12px;
  border-radius:999px;
  font-weight:900;
  font-size:13px;
}

.v63-brand h1{
  margin:8px 0 4px;
  font-size:38px;
  line-height:1.05;
  color:#0f172a;
}

.v63-brand p{
  margin:0;
  color:#64748b;
  font-size:16px;
}

.v63-admin-btn{
  border:0;
  border-radius:16px;
  padding:12px 16px;
  background:#0f172a;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}

.v63-search-card{
  max-width:1120px;
  margin:0 auto;
  background:#fff;
  border:1px solid #dbeafe;
  border-radius:28px;
  padding:28px;
  box-shadow:0 24px 80px rgba(15,23,42,.10);
}

.v63-search-card h2{
  margin:0;
  font-size:30px;
  color:#0f172a;
}

.v63-desc{
  margin:8px 0 18px;
  color:#64748b;
  font-size:16px;
}

.v63-search-row{
  display:grid;
  grid-template-columns:1fr 150px;
  gap:12px;
}

.v63-search-row input{
  border:1px solid #cbd5e1;
  border-radius:18px;
  padding:15px 18px;
  font-size:16px;
  outline:none;
}

.v63-search-row input:focus{
  border-color:#2563eb;
  box-shadow:0 0 0 5px rgba(37,99,235,.12);
}

.v63-search-row button{
  border:0;
  border-radius:18px;
  padding:15px;
  background:#2563eb;
  color:#fff;
  font-weight:1000;
  cursor:pointer;
}

.v63-examples{
  margin-top:12px;
  color:#64748b;
  font-size:14px;
}

.v63-examples span{
  display:inline-block;
  background:#eff6ff;
  color:#1d4ed8;
  border-radius:999px;
  padding:5px 9px;
  margin:4px;
  font-weight:800;
}

.v63-lookup-result{
  margin-top:18px;
}

.v63-alert,
.v63-loading,
.v63-found{
  padding:14px;
  border-radius:16px;
  background:#eff6ff;
  color:#1d4ed8;
  font-weight:900;
}

.v63-alert.danger{
  background:#fee2e2;
  color:#991b1b;
}

.v63-result-list{
  display:grid;
  gap:10px;
  margin-top:12px;
}

.v63-result-list button{
  border:1px solid #cbd5e1;
  border-radius:16px;
  background:#fff;
  padding:14px;
  text-align:left;
  cursor:pointer;
}

.v63-result-list button b{
  display:block;
  color:#0f172a;
}

.v63-result-list button span{
  display:block;
  margin-top:4px;
  color:#64748b;
}

.v63-record-card{
  border:1px solid #dbeafe;
  border-radius:24px;
  padding:18px;
  background:#fff;
  box-shadow:0 14px 40px rgba(15,23,42,.08);
}

.v63-record-top{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding-bottom:14px;
  border-bottom:1px solid #e2e8f0;
}

.v63-record-top h3{
  margin:0;
  font-size:26px;
}

.v63-record-top p{
  margin:5px 0 0;
  color:#64748b;
}

.v63-record-top img,
.v63-avatar{
  width:76px;
  height:98px;
  object-fit:cover;
  border-radius:14px;
  background:#e2e8f0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
}

.v63-status-line{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:14px 0;
}

.v63-status-line span{
  background:#dcfce7;
  color:#166534;
  border-radius:999px;
  padding:7px 11px;
  font-weight:800;
}

.v63-info-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}

.v63-info-grid div{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:16px;
  padding:11px;
}

.v63-info-grid .wide{
  grid-column:1 / -1;
}

.v63-info-grid label{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:900;
}

.v63-info-grid b{
  display:block;
  margin-top:4px;
  color:#0f172a;
}

.v63-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:16px;
}

.v63-actions button{
  border:0;
  border-radius:16px;
  padding:12px 16px;
  color:#fff;
  background:#2563eb;
  font-weight:900;
  cursor:pointer;
}

.v63-actions button:nth-child(2){
  background:#dc2626;
}

.v63-actions button:nth-child(3){
  background:#64748b;
}

@media(max-width:720px){
  .v63-hero,
  .v63-brand{
    flex-direction:column;
    align-items:flex-start;
  }
  .v63-search-row,
  .v63-info-grid{
    grid-template-columns:1fr;
  }
  .v63-brand h1{
    font-size:30px;
  }
}



/* =========================================================
   V64 - chỉ tra cứu, Ctrl+N đăng nhập
   ========================================================= */
.v64-force-hide,
#v59BulkBar,
.v59-bulk-bar,
#v58FullReloadBtn,
.v58-full-reload-btn,
#v60LoadMoreBtn,
.v60-load-more-btn,
#v60FastNotice,
.v60-fast-notice,
.v63-admin-btn,
.v63-examples{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.v64-login-hidden{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.v64-login-open{
  display:block!important;
  visibility:visible!important;
  pointer-events:auto!important;
  max-width:560px!important;
  margin:22px auto!important;
  position:relative!important;
  z-index:9999!important;
  background:#fff!important;
  border-radius:24px!important;
  box-shadow:0 24px 80px rgba(15,23,42,.22)!important;
}

/* Màn hình ngoài chỉ tập trung vào tra cứu */
#v63LookupOnlyPage{
  min-height:100vh!important;
}

#v63LookupOnlyPage .v63-hero{
  justify-content:center!important;
}

#v63LookupOnlyPage .v63-brand{
  justify-content:center!important;
  text-align:center!important;
}

#v63LookupOnlyPage .v63-brand p{
  max-width:680px;
}

/* Ẩn các dòng hướng dẫn hệ thống không cần thiết */
.notice-panel,
.help-panel,
.guide-panel,
.instruction,
.instructions{
  display:none!important;
}



/* =========================================================
   V65 - chỉ còn trang tra cứu, bỏ panel xanh + đăng nhập
   ========================================================= */

.v65-force-hide,
.notice-panel,
.intro-panel,
.welcome-panel,
.hero-panel,
.brand-panel,
.left-panel,
.login-left,
.login-info,
.login-banner,
.feature-panel,
.system-intro,
.login-card,
.login-form,
.login-panel,
.auth-card,
.auth-form,
#loginForm,
#loginBox,
#v59BulkBar,
.v59-bulk-bar,
#v58FullReloadBtn,
.v58-full-reload-btn,
#v60LoadMoreBtn,
.v60-load-more-btn,
#v60FastNotice,
.v60-fast-notice,
.v63-admin-btn,
.v63-examples,
.top-actions,
.page-actions,
.bulk-actions,
.batch-actions,
.floating-actions{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}

/* Bỏ bố cục 2 cột cũ, chỉ còn tra cứu */
.login-screen,
#loginScreen{
  display:block!important;
  min-height:100vh!important;
  padding:0!important;
  background:
    radial-gradient(circle at top left, rgba(45,212,191,.18), transparent 34%),
    radial-gradient(circle at top right, rgba(59,130,246,.16), transparent 32%),
    linear-gradient(135deg,#eefdfb,#f8fbff 55%,#eef5ff)!important;
}

/* Trang tra cứu chiếm toàn màn hình */
#v63LookupOnlyPage,
.v65-active-lookup-only{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  min-height:100vh!important;
  width:100%!important;
  padding:60px 18px!important;
  box-sizing:border-box!important;
}

#v63LookupOnlyPage .v63-hero{
  justify-content:center!important;
  text-align:center!important;
}

#v63LookupOnlyPage .v63-brand{
  justify-content:center!important;
  text-align:center!important;
  flex-direction:column!important;
}

#v63LookupOnlyPage .v63-logo{
  margin:0 auto!important;
}

#v63LookupOnlyPage .v63-search-card{
  max-width:920px!important;
  margin:24px auto 0!important;
}

/* Trường hợp form tra cứu V61 đang tồn tại */
#v61PublicLookupBox{
  max-width:920px!important;
  margin:60px auto!important;
}



/* =========================================================
   V66 - tra cứu hiện đầy đủ phiếu + phím 2005 đăng nhập
   ========================================================= */
.v66-receipt-wrap{
  margin-top:18px;
}

.v66-receipt-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-bottom:12px;
}

.v66-receipt-actions button{
  border:0;
  border-radius:14px;
  padding:11px 14px;
  font-weight:900;
  cursor:pointer;
  color:#fff;
  background:#2563eb;
}

.v66-receipt-actions button:nth-child(2){
  background:#dc2626;
}

.v66-receipt-actions button:nth-child(3){
  background:#64748b;
}

.v66-receipt-a4{
  width:210mm;
  min-height:297mm;
  margin:0 auto;
  background:#fff;
  color:#000;
  font-family:"Times New Roman", serif;
  font-size:12px;
  line-height:1.18;
  padding:9mm 10mm;
  box-sizing:border-box;
  box-shadow:0 18px 60px rgba(15,23,42,.18);
  position:relative;
}

.v66-header{
  display:grid;
  grid-template-columns:28mm 1fr 38mm;
  gap:3mm;
  align-items:start;
}

.v66-header h2{
  font-size:17px;
  margin:0;
  text-align:center;
  font-weight:700;
}

.v66-header h3{
  font-size:12px;
  margin:2px 0 0;
  text-align:center;
}

.v66-form-no{
  border:1px solid #000;
  padding:3px 4px;
  font-size:10px;
  text-align:center;
}

.v66-note{
  font-style:italic;
  margin:7mm 32mm 3mm 0;
}

.v66-photo{
  position:absolute;
  top:31mm;
  right:10mm;
  width:27mm;
  height:35mm;
  border:1px solid #999;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:10px;
}

.v66-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.v66-section{
  font-weight:700;
  font-size:13px;
  margin-top:2mm;
}

.v66-line{
  border-bottom:1px dotted #000;
  min-height:4.5mm;
  margin-right:30mm;
}

.v66-line span{
  font-weight:700;
}

.v66-sub{
  border-bottom:1px dotted #000;
  margin-left:10mm;
  width:142mm;
  min-height:4mm;
  font-size:10.5px;
}

.v66-mrz{
  font-size:9px;
  word-break:break-word;
}

.v66-docs{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2mm 5mm;
  margin-top:2mm;
}

.v66-bottom{
  display:grid;
  grid-template-columns:34mm 1fr;
  gap:12mm;
  margin-top:5mm;
  align-items:start;
}

.v66-qr{
  text-align:center;
  font-size:9px;
}

.v66-qr img{
  width:24mm;
  height:24mm;
  display:block;
  border:1px solid #000;
  padding:1px;
  margin:1mm auto;
  object-fit:contain;
}

.v66-qr span{
  display:block;
}

.v66-confirm{
  text-align:center;
  font-size:11px;
  line-height:1.12;
}

.v66-confirm>b{
  font-size:13px;
}

.v66-confirm p{
  margin:2px 0;
}

.v66-confirm h3{
  font-size:13px;
  margin:2px 0;
}

.v66-confirm i{
  display:block;
}

.v66-signature{
  margin-top:2mm;
  display:grid;
  grid-template-columns:42mm 52mm;
  gap:7mm;
  justify-content:center;
  align-items:center;
}

.v66-sign-left{
  text-align:center;
}

.v66-sign-left img,
.v66-sign-placeholder{
  width:42mm;
  height:18mm;
  object-fit:contain;
  display:block;
  margin:0 auto;
}

.v66-sign-right{
  text-align:left;
}

.v66-sign-right b{
  display:block;
  text-align:center;
  font-size:12px;
}

.v66-sign-right span{
  display:block;
  font-size:11px;
  line-height:1.1;
}

/* Mở login bằng 2005 */
.v66-login-open{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
  max-width:560px!important;
  margin:22px auto!important;
  position:relative!important;
  z-index:99999!important;
  background:#fff!important;
  border-radius:24px!important;
  box-shadow:0 24px 80px rgba(15,23,42,.25)!important;
}

@media(max-width:900px){
  .v66-receipt-a4{
    width:100%;
    min-height:auto;
    overflow:auto;
    padding:12px;
  }
  .v66-header{
    grid-template-columns:1fr;
  }
  .v66-form-no{
    max-width:220px;
    margin:0 auto;
  }
  .v66-photo{
    position:static;
    margin:8px auto;
  }
  .v66-line,
  .v66-sub{
    margin-right:0;
    width:auto;
  }
  .v66-docs{
    grid-template-columns:1fr 1fr;
  }
  .v66-bottom{
    grid-template-columns:1fr;
  }
}



/* =========================================================
   V67 - giao diện tra cứu như mẫu + login 2005 trong 10s
   ========================================================= */
.v67-hide,
#v63LookupOnlyPage,
#v61PublicLookupBox,
#v62GovLookupPage,
.notice-panel,
.intro-panel,
.welcome-panel,
.hero-panel,
.brand-panel,
.left-panel,
.login-left,
.login-info,
.login-banner,
.feature-panel,
.system-intro,
#v59BulkBar,
.v59-bulk-bar,
#v58FullReloadBtn,
.v58-full-reload-btn,
#v60LoadMoreBtn,
.v60-load-more-btn,
#v60FastNotice,
.v60-fast-notice,
.v63-admin-btn,
.v63-examples,
.top-actions,
.page-actions,
.bulk-actions,
.batch-actions,
.floating-actions{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.login-card,
.login-form,
.login-panel,
.auth-card,
.auth-form,
#loginForm,
#loginBox{
  display:none!important;
}

.v67-login-open{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
  max-width:560px!important;
  margin:22px auto!important;
  position:relative!important;
  z-index:99999!important;
  background:#fff!important;
  border-radius:24px!important;
  box-shadow:0 24px 80px rgba(15,23,42,.25)!important;
}

#loginScreen,
.login-screen{
  display:block!important;
  min-height:100vh!important;
  padding:0!important;
  background:#e9eef3!important;
}

.v67-lookup-page{
  min-height:100vh;
  background:#e9eef3;
  color:#111827;
  font-family:Arial, Helvetica, sans-serif;
}

.v67-banner{
  height:230px;
  background:
    linear-gradient(rgba(229,236,243,.72),rgba(229,236,243,.72)),
    radial-gradient(circle at 70% 0%, rgba(148,163,184,.5), transparent 36%),
    linear-gradient(135deg,#cbd5e1,#e2e8f0);
  border-top:3px solid #0b63b6;
  display:flex;
  align-items:center;
}

.v67-banner-inner{
  width:min(1620px,86vw);
  margin:0 auto;
}

.v67-banner h1{
  color:#075ebd;
  font-size:48px;
  font-weight:900;
  margin:0;
  display:flex;
  align-items:center;
  gap:8px;
}

.v67-banner h1 span{
  display:inline-block;
  width:5px;
  height:34px;
  background:#f97316;
}

.v67-main{
  width:min(1620px,86vw);
  margin:-62px auto 50px;
}

.v67-card{
  background:#fff;
  border-radius:5px;
  padding:54px 26px 45px;
  box-shadow:0 10px 24px rgba(15,23,42,.08);
}

.v67-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px 20px;
}

.v67-field label{
  display:block;
  font-size:15px;
  color:#111827;
  text-transform:uppercase;
  margin-bottom:10px;
}

.v67-field input{
  width:100%;
  height:48px;
  border:1px solid #d1d5db;
  padding:0 16px;
  font-size:21px;
  color:#374151;
  outline:none;
  box-sizing:border-box;
  background:#fff;
}

.v67-field input:focus{
  border-color:#0b63b6;
  box-shadow:0 0 0 2px rgba(11,99,182,.12);
}

.v67-captcha-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.v67-captcha-row input{
  width:155px;
  text-align:center;
  font-size:16px;
}

.v67-refresh{
  border:0;
  background:transparent;
  color:#f97316;
  font-size:34px;
  font-weight:900;
  cursor:pointer;
  line-height:1;
}

.v67-captcha-text{
  display:inline-block;
  min-width:135px;
  color:#4f46e5;
  font-family:"Times New Roman", serif;
  font-size:36px;
  font-weight:700;
  letter-spacing:8px;
  transform:skew(-10deg);
  text-decoration:line-through;
}

.v67-search-center{
  display:flex;
  justify-content:center;
  margin-top:24px;
}

.v67-search-btn{
  width:310px;
  height:62px;
  border:0;
  border-radius:5px;
  background:#ed1023;
  color:#fff;
  font-size:17px;
  font-weight:900;
  cursor:pointer;
}

.v67-note{
  margin-top:0;
  color:red;
  font-size:20px;
  font-weight:900;
}

.v67-result{
  margin-top:28px;
}

.v67-alert{
  background:#fff;
  border-left:5px solid #0b63b6;
  padding:16px 18px;
  font-weight:900;
  color:#0b63b6;
  box-shadow:0 8px 20px rgba(15,23,42,.08);
}

.v67-alert.danger{
  border-left-color:#dc2626;
  color:#dc2626;
}

.v67-list{
  display:grid;
  gap:10px;
  margin-top:12px;
}

.v67-list button{
  background:#fff;
  border:1px solid #d1d5db;
  border-radius:5px;
  padding:14px;
  text-align:left;
  cursor:pointer;
}

.v67-list button b{
  display:block;
  font-size:18px;
}

.v67-list button span{
  display:block;
  margin-top:4px;
  color:#64748b;
}

@media(max-width:1000px){
  .v67-grid{
    grid-template-columns:1fr;
  }
  .v67-banner h1{
    font-size:36px;
  }
  .v67-main,
  .v67-banner-inner{
    width:94vw;
  }
  .v67-captcha-row{
    flex-wrap:wrap;
  }
}



/* =========================================================
   V68 - trang tra cứu luôn hiện + kết quả bảng/chi tiết
   ========================================================= */
.v68-hide,
#v67LookupPage,
#v63LookupOnlyPage,
#v61PublicLookupBox,
#v62GovLookupPage,
.notice-panel,
.intro-panel,
.welcome-panel,
.hero-panel,
.brand-panel,
.left-panel,
.login-left,
.login-info,
.login-banner,
.feature-panel,
.system-intro,
#v59BulkBar,
.v59-bulk-bar,
#v58FullReloadBtn,
.v58-full-reload-btn,
#v60LoadMoreBtn,
.v60-load-more-btn,
#v60FastNotice,
.v60-fast-notice,
.v63-admin-btn,
.v63-examples,
.top-actions,
.page-actions,
.bulk-actions,
.batch-actions,
.floating-actions{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.login-card,
.login-form,
.login-panel,
.auth-card,
.auth-form,
#loginForm,
#loginBox{
  display:none!important;
}

.v68-login-open{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
  max-width:560px!important;
  margin:22px auto!important;
  position:relative!important;
  z-index:99999!important;
  background:#fff!important;
  border-radius:24px!important;
  box-shadow:0 24px 80px rgba(15,23,42,.25)!important;
}

#loginScreen,
.login-screen{
  display:block!important;
  min-height:100vh!important;
  padding:0!important;
  background:#e9eef3!important;
}

.v68-page{
  min-height:100vh;
  background:#e9eef3;
  color:#000;
  font-family:Arial, Helvetica, sans-serif;
}

.v68-hero{
  height:230px;
  background:
    linear-gradient(rgba(229,236,243,.72),rgba(229,236,243,.72)),
    radial-gradient(circle at 70% 0%, rgba(148,163,184,.5), transparent 36%),
    linear-gradient(135deg,#cbd5e1,#e2e8f0);
  border-top:3px solid #0b63b6;
  display:flex;
  align-items:center;
}

.v68-inner{
  width:min(1620px,86vw);
  margin:0 auto;
}

.v68-hero h1{
  color:#075ebd;
  font-size:48px;
  font-weight:900;
  margin:0;
  display:flex;
  align-items:center;
  gap:8px;
}

.v68-hero h1 span{
  display:inline-block;
  width:5px;
  height:34px;
  background:#f97316;
}

.v68-main{
  width:min(1620px,86vw);
  margin:-62px auto 50px;
}

.v68-search-card{
  background:#fff;
  border-radius:5px;
  padding:54px 26px 45px;
  box-shadow:0 10px 24px rgba(15,23,42,.08);
}

.v68-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px 20px;
}

.v68-field label{
  display:block;
  font-size:15px;
  color:#111827;
  text-transform:uppercase;
  margin-bottom:10px;
}

.v68-field input{
  width:100%;
  height:48px;
  border:1px solid #d1d5db;
  padding:0 16px;
  font-size:21px;
  color:#374151;
  outline:none;
  box-sizing:border-box;
  background:#fff;
}

.v68-field input:focus{
  border-color:#0b63b6;
  box-shadow:0 0 0 2px rgba(11,99,182,.12);
}

.v68-captcha-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.v68-captcha-row input{
  width:155px;
  text-align:center;
  font-size:16px;
}

.v68-captcha-row button{
  border:0;
  background:transparent;
  color:#f97316;
  font-size:34px;
  font-weight:900;
  cursor:pointer;
  line-height:1;
}

#v68CaptchaText{
  display:inline-block;
  min-width:135px;
  color:#4f46e5;
  font-family:"Times New Roman", serif;
  font-size:36px;
  font-weight:700;
  letter-spacing:8px;
  transform:skew(-10deg);
  text-decoration:line-through;
}

.v68-center{
  display:flex;
  justify-content:center;
  margin-top:24px;
}

.v68-search-btn{
  width:310px;
  height:62px;
  border:0;
  border-radius:5px;
  background:#ed1023;
  color:#fff;
  font-size:17px;
  font-weight:900;
  cursor:pointer;
}

.v68-note{
  margin-top:0;
  color:red;
  font-size:20px;
  font-weight:900;
}

.v68-result{
  margin-top:28px;
}

.v68-alert{
  background:#fff;
  border-left:5px solid #0b63b6;
  padding:16px 18px;
  font-weight:900;
  color:#0b63b6;
  box-shadow:0 8px 20px rgba(15,23,42,.08);
}

.v68-alert.danger{
  border-left-color:#dc2626;
  color:#dc2626;
}

.v68-result-box{
  background:#fff;
  padding:12px 12px 70px;
  border-radius:4px;
}

.v68-result-box h2{
  color:#64748b;
  margin:8px 0 14px;
  font-size:24px;
  font-weight:900;
}

.v68-result-table{
  width:100%;
  border-collapse:collapse;
  margin-bottom:18px;
}

.v68-result-table thead th{
  background:#0b63b6;
  color:#fff;
  padding:18px 12px;
  text-align:center;
  font-size:18px;
}

.v68-result-table tbody td{
  padding:14px 12px;
  text-align:center;
  border-bottom:1px solid #e5e7eb;
  font-size:16px;
  vertical-align:middle;
}

.v68-result-table button{
  border:0;
  background:transparent;
  color:#0b63b6;
  font-weight:800;
  cursor:pointer;
  font-size:15px;
  margin:2px 5px;
}

.v68-detail-card{
  border:1px solid #e5e7eb;
  border-radius:5px;
  padding:26px 36px;
  display:grid;
  grid-template-columns:330px 1fr;
  gap:36px;
  min-height:330px;
}

.v68-photo-col{
  text-align:left;
  padding-left:10px;
}

.v68-photo-col img,
.v68-avatar{
  width:150px;
  height:150px;
  border-radius:50%;
  object-fit:cover;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#dbeafe;
  font-size:56px;
  margin:0 0 44px 30px;
}

.v68-photo-col p{
  font-size:16px;
  margin:9px 0;
}

.v68-info-col h3{
  font-size:24px;
  margin:0 0 12px;
  border-bottom:1px solid #e5e7eb;
  padding-bottom:12px;
}

.v68-info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 50px;
}

.v68-info-grid p,
.v68-address p{
  font-size:16px;
  margin:8px 0;
}

.v68-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.v68-actions button{
  border:0;
  border-radius:5px;
  padding:11px 14px;
  background:#0b63b6;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}

.v68-actions button:nth-child(2){
  background:#dc2626;
}

.v68-actions button:nth-child(3){
  background:#64748b;
}

@media(max-width:1000px){
  .v68-grid,
  .v68-detail-card,
  .v68-info-grid{
    grid-template-columns:1fr;
  }
  .v68-hero h1{
    font-size:36px;
  }
  .v68-main,
  .v68-inner{
    width:94vw;
  }
  .v68-captcha-row{
    flex-wrap:wrap;
  }
  .v68-result-table{
    min-width:900px;
  }
  .v68-result-box{
    overflow:auto;
  }
}



/* =========================================================
   V69 - chỉ giữ trang tra cứu, không login
   ========================================================= */
.v69-old-hidden{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

#v69LookupRoot{
  display:block!important;
  visibility:visible!important;
  min-height:100vh!important;
}

html, body{
  margin:0!important;
  min-height:100vh!important;
  background:#e9eef3!important;
}

.v69-page{
  min-height:100vh;
  background:#e9eef3;
  color:#000;
  font-family:Arial, Helvetica, sans-serif;
}

.v69-hero{
  height:230px;
  background:
    linear-gradient(rgba(229,236,243,.72),rgba(229,236,243,.72)),
    radial-gradient(circle at 70% 0%, rgba(148,163,184,.5), transparent 36%),
    linear-gradient(135deg,#cbd5e1,#e2e8f0);
  border-top:3px solid #0b63b6;
  display:flex;
  align-items:center;
}

.v69-inner{
  width:min(1620px,86vw);
  margin:0 auto;
}

.v69-hero h1{
  color:#075ebd;
  font-size:48px;
  font-weight:900;
  margin:0;
  display:flex;
  align-items:center;
  gap:8px;
}

.v69-hero h1 span{
  display:inline-block;
  width:5px;
  height:34px;
  background:#f97316;
}

.v69-main{
  width:min(1620px,86vw);
  margin:-62px auto 50px;
}

.v69-search-card{
  background:#fff;
  border-radius:5px;
  padding:54px 26px 45px;
  box-shadow:0 10px 24px rgba(15,23,42,.08);
}

.v69-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px 20px;
}

.v69-field label{
  display:block;
  font-size:15px;
  color:#111827;
  text-transform:uppercase;
  margin-bottom:10px;
}

.v69-field input{
  width:100%;
  height:48px;
  border:1px solid #d1d5db;
  padding:0 16px;
  font-size:21px;
  color:#374151;
  outline:none;
  box-sizing:border-box;
  background:#fff;
}

.v69-field input:focus{
  border-color:#0b63b6;
  box-shadow:0 0 0 2px rgba(11,99,182,.12);
}

.v69-captcha-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.v69-captcha-row input{
  width:155px;
  text-align:center;
  font-size:16px;
}

.v69-captcha-row button{
  border:0;
  background:transparent;
  color:#f97316;
  font-size:34px;
  font-weight:900;
  cursor:pointer;
  line-height:1;
}

#v69CaptchaText{
  display:inline-block;
  min-width:135px;
  color:#4f46e5;
  font-family:"Times New Roman", serif;
  font-size:36px;
  font-weight:700;
  letter-spacing:8px;
  transform:skew(-10deg);
  text-decoration:line-through;
}

.v69-center{
  display:flex;
  justify-content:center;
  margin-top:24px;
}

.v69-search-btn{
  width:310px;
  height:62px;
  border:0;
  border-radius:5px;
  background:#ed1023;
  color:#fff;
  font-size:17px;
  font-weight:900;
  cursor:pointer;
}

.v69-note{
  margin-top:0;
  color:red;
  font-size:20px;
  font-weight:900;
}

.v69-result{
  margin-top:28px;
}

.v69-alert{
  background:#fff;
  border-left:5px solid #0b63b6;
  padding:16px 18px;
  font-weight:900;
  color:#0b63b6;
  box-shadow:0 8px 20px rgba(15,23,42,.08);
}

.v69-alert.danger{
  border-left-color:#dc2626;
  color:#dc2626;
}

.v69-result-box{
  background:#fff;
  padding:12px 12px 70px;
  border-radius:4px;
}

.v69-result-box h2{
  color:#64748b;
  margin:8px 0 14px;
  font-size:24px;
  font-weight:900;
}

.v69-result-table{
  width:100%;
  border-collapse:collapse;
  margin-bottom:18px;
}

.v69-result-table thead th{
  background:#0b63b6;
  color:#fff;
  padding:18px 12px;
  text-align:center;
  font-size:18px;
}

.v69-result-table tbody td{
  padding:14px 12px;
  text-align:center;
  border-bottom:1px solid #e5e7eb;
  font-size:16px;
  vertical-align:middle;
}

.v69-result-table button{
  border:0;
  background:transparent;
  color:#0b63b6;
  font-weight:800;
  cursor:pointer;
  font-size:15px;
  margin:2px 5px;
}

.v69-detail-card{
  border:1px solid #e5e7eb;
  border-radius:5px;
  padding:26px 36px;
  display:grid;
  grid-template-columns:330px 1fr;
  gap:36px;
  min-height:330px;
}

.v69-photo-col{
  text-align:left;
  padding-left:10px;
}

.v69-photo-col img,
.v69-avatar{
  width:150px;
  height:150px;
  border-radius:50%;
  object-fit:cover;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#dbeafe;
  font-size:56px;
  margin:0 0 44px 30px;
}

.v69-photo-col p{
  font-size:16px;
  margin:9px 0;
}

.v69-info-col h3{
  font-size:24px;
  margin:0 0 12px;
  border-bottom:1px solid #e5e7eb;
  padding-bottom:12px;
}

.v69-info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 50px;
}

.v69-info-grid p,
.v69-address p{
  font-size:16px;
  margin:8px 0;
}

.v69-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.v69-actions button{
  border:0;
  border-radius:5px;
  padding:11px 14px;
  background:#0b63b6;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}

.v69-actions button:nth-child(2){
  background:#dc2626;
}

.v69-actions button:nth-child(3){
  background:#64748b;
}

@media(max-width:1000px){
  .v69-grid,
  .v69-detail-card,
  .v69-info-grid{
    grid-template-columns:1fr;
  }
  .v69-hero h1{
    font-size:36px;
  }
  .v69-main,
  .v69-inner{
    width:94vw;
  }
  .v69-captcha-row{
    flex-wrap:wrap;
  }
  .v69-result-table{
    min-width:900px;
  }
  .v69-result-box{
    overflow:auto;
  }
}



/* V70 - bỏ captcha/mã bảo vệ */
.v70-hide-captcha{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}



/* =========================================================
   V71 - khóa in/tải PDF + MRZ
   ========================================================= */
.v71-locked-btn::before{
  content:"🔒 ";
}

.v71-mrz-box{
  margin-top:18px;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  border-radius:8px;
  padding:12px;
}

.v71-mrz-box label{
  display:block;
  color:#1e3a8a;
  font-weight:900;
  margin-bottom:8px;
}

.v71-mrz-box textarea{
  width:100%;
  min-height:72px;
  resize:vertical;
  border:1px solid #93c5fd;
  border-radius:6px;
  padding:10px;
  font-family:Consolas, monospace;
  font-size:14px;
  box-sizing:border-box;
  background:#fff;
}

.v71-mrz-box button{
  margin-top:8px;
  border:0;
  border-radius:6px;
  padding:9px 12px;
  background:#0b63b6;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}



/* =========================================================
   V72 - Báo sai sót công khai
   ========================================================= */
.v72-report-btn{
  border:0!important;
  border-radius:5px!important;
  padding:11px 14px!important;
  background:#f97316!important;
  color:#fff!important;
  font-weight:900!important;
  cursor:pointer!important;
}

.v72-table-report{
  display:inline-block!important;
  margin-left:6px!important;
  padding:7px 10px!important;
  font-size:14px!important;
}

.v72-modal{
  position:fixed;
  inset:0;
  z-index:300000;
  background:rgba(15,23,42,.62);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.v72-dialog{
  width:min(1180px,96vw);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border-radius:18px;
  box-shadow:0 28px 90px rgba(0,0,0,.35);
}

.v72-head{
  position:sticky;
  top:0;
  background:#fff;
  z-index:2;
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding:18px 20px;
  border-bottom:1px solid #e5e7eb;
}

.v72-head h2{
  margin:0;
  color:#0f172a;
  font-size:24px;
}

.v72-head p{
  margin:5px 0 0;
  color:#64748b;
}

.v72-head button{
  border:0;
  background:#fee2e2;
  color:#991b1b;
  width:42px;
  height:42px;
  border-radius:12px;
  font-size:28px;
  font-weight:900;
  cursor:pointer;
}

.v72-table-wrap{
  padding:16px 20px;
  overflow:auto;
}

.v72-table{
  width:100%;
  border-collapse:collapse;
  min-width:900px;
}

.v72-table th{
  background:#0b63b6;
  color:#fff;
  padding:12px;
  text-align:left;
}

.v72-table td{
  border:1px solid #e5e7eb;
  padding:10px;
  vertical-align:top;
}

.v72-table td:nth-child(1){
  width:240px;
}

.v72-table td:nth-child(2){
  width:360px;
  color:#334155;
  font-weight:700;
}

.v72-table textarea{
  width:100%;
  min-height:54px;
  resize:vertical;
  border:1px solid #cbd5e1;
  border-radius:8px;
  padding:8px;
  box-sizing:border-box;
  font-family:Arial, sans-serif;
}

.v72-note-box{
  padding:0 20px 16px;
}

.v72-note-box label{
  display:block;
  font-weight:900;
  margin-bottom:8px;
  color:#0f172a;
}

.v72-note-box textarea{
  width:100%;
  min-height:72px;
  resize:vertical;
  border:1px solid #cbd5e1;
  border-radius:10px;
  padding:10px;
  box-sizing:border-box;
}

.v72-actions{
  position:sticky;
  bottom:0;
  background:#fff;
  border-top:1px solid #e5e7eb;
  display:flex;
  justify-content:flex-end;
  gap:10px;
  padding:16px 20px;
}

.v72-actions button{
  border:0;
  border-radius:10px;
  padding:12px 16px;
  font-weight:900;
  cursor:pointer;
}

.v72-actions button:first-child{
  background:#16a34a;
  color:#fff;
}

.v72-actions button:last-child{
  background:#e2e8f0;
  color:#0f172a;
}



/* =========================================================
   V73 - bỏ hàng nút phụ phía dưới
   ========================================================= */
.v73-hide-lower-actions,
.v69-detail-card .v69-actions,
.v68-detail-card .v68-actions,
.v69-info-col > .v69-actions,
.v68-info-col > .v68-actions{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

/* Giữ nút trên bảng kết quả */
.v69-result-table .v72-report-btn,
.v68-result-table .v72-report-btn,
.v69-result-table button,
.v68-result-table button{
  display:inline-block!important;
  visibility:visible!important;
  pointer-events:auto!important;
}



/* =========================================================
   V74 - fix báo sai sót bị out
   ========================================================= */
.v74-report-safe{
  cursor:pointer!important;
}

#v72MistakeModal{
  z-index:999999!important;
}

#v72MistakeModal,
#v72MistakeModal *{
  pointer-events:auto!important;
}

#v72MistakeModal.v69-old-hidden,
#v72MistakeModal.v68-hide,
#v72MistakeModal.v67-hide,
#v72MistakeModal.v65-force-hide,
#v72MistakeModal.v73-hide-lower-actions{
  display:flex!important;
  visibility:visible!important;
  opacity:1!important;
}



/* =========================================================
   V75 - ĐÃ KIỂM TRA + ẩn báo sai sót sau khi gửi
   ========================================================= */
.v75-hide-report{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.v75-checked-wrap{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin:10px 0 14px;
  padding:10px 12px;
  background:#fff7f7;
  border:2px dashed #dc2626;
  border-radius:8px;
}

.v75-stamp{
  color:#dc2626;
  border:3px solid #dc2626;
  border-radius:8px;
  padding:7px 14px;
  font-size:22px;
  font-weight:1000;
  letter-spacing:1px;
  text-transform:uppercase;
  transform:rotate(-2deg);
  background:#fff;
}

.v75-approved-line{
  color:#991b1b;
  font-size:16px;
  font-weight:900;
}

.v75-result-status{
  margin:10px 0 14px;
}



/* =========================================================
   V76 - cập nhật sau 5 giây + tiến trình
   ========================================================= */
.v76-hide-report{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.v76-progress-box{
  background:#fff7ed;
  border:2px solid #fb923c;
  color:#9a3412;
  border-radius:10px;
  padding:14px 16px;
  margin:10px 0 14px;
  font-weight:900;
}

.v76-progress-box span{
  display:block;
  margin-top:4px;
}

.v76-progress-line{
  margin-top:10px;
  height:8px;
  background:#fed7aa;
  border-radius:999px;
  overflow:hidden;
}

.v76-progress-line i{
  display:block;
  height:100%;
  width:0%;
  background:#f97316;
  border-radius:999px;
  animation:v76load 5s linear forwards;
}

@keyframes v76load{
  from{width:0%}
  to{width:100%}
}

.v76-checked-wrap{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin:10px 0 14px;
  padding:10px 12px;
  background:#fff7f7;
  border:2px dashed #dc2626;
  border-radius:8px;
}

.v76-stamp{
  color:#dc2626;
  border:3px solid #dc2626;
  border-radius:8px;
  padding:7px 14px;
  font-size:22px;
  font-weight:1000;
  letter-spacing:1px;
  text-transform:uppercase;
  transform:rotate(-2deg);
  background:#fff;
}

.v76-approved-line{
  color:#991b1b;
  font-size:16px;
  font-weight:900;
}



/* =========================================================
   SMARTSTAY V77 VIP PRO FINAL
   ========================================================= */
.v77-result-box{
  background:#fff;
  padding:12px 12px 70px;
  border-radius:4px;
}

.v77-table{
  width:100%;
  border-collapse:collapse;
  margin-bottom:18px;
}

.v77-table th{
  background:#0b63b6;
  color:#fff;
  padding:18px 12px;
  text-align:center;
  font-size:18px;
}

.v77-table td{
  padding:14px 12px;
  text-align:center;
  border-bottom:1px solid #e5e7eb;
  font-size:16px;
  vertical-align:middle;
}

.v77-table button{
  border:0;
  background:transparent;
  color:#0b63b6;
  font-weight:900;
  cursor:pointer;
  margin:2px 5px;
}

.v77-btn-report{
  background:#f97316!important;
  color:#fff!important;
  border-radius:5px!important;
  padding:7px 10px!important;
}

.v77-detail{
  border:1px solid #e5e7eb;
  border-radius:5px;
  padding:26px 36px;
  display:grid;
  grid-template-columns:330px 1fr;
  gap:36px;
  min-height:330px;
}

.v77-photo img,
.v77-avatar{
  width:150px;
  height:150px;
  border-radius:50%;
  object-fit:cover;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#dbeafe;
  font-size:56px;
  margin:0 0 44px 30px;
}

.v77-photo p{
  font-size:16px;
  margin:9px 0;
}

.v77-info h3{
  font-size:24px;
  margin:0 0 12px;
  border-bottom:1px solid #e5e7eb;
  padding-bottom:12px;
}

.v77-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 50px;
}

.v77-grid p,
.v77-address p{
  font-size:16px;
  margin:8px 0;
}

.v77-mrz{
  margin-top:18px;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  border-radius:8px;
  padding:12px;
}

.v77-mrz label{
  display:block;
  color:#1e3a8a;
  font-weight:900;
  margin-bottom:8px;
}

.v77-mrz textarea{
  width:100%;
  min-height:72px;
  resize:vertical;
  border:1px solid #93c5fd;
  border-radius:6px;
  padding:10px;
  font-family:Consolas, monospace;
  font-size:14px;
  box-sizing:border-box;
  background:#fff;
}

.v77-mrz button{
  margin-top:8px;
  border:0;
  border-radius:6px;
  padding:9px 12px;
  background:#0b63b6;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}

.v77-stamp-wrap{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin:10px 0 14px;
  padding:10px 12px;
  background:#fff7f7;
  border:2px dashed #dc2626;
  border-radius:8px;
}

.v77-stamp{
  color:#dc2626;
  border:3px solid #dc2626;
  border-radius:8px;
  padding:7px 14px;
  font-size:22px;
  font-weight:1000;
  letter-spacing:1px;
  text-transform:uppercase;
  transform:rotate(-2deg);
  background:#fff;
}

.v77-approved{
  color:#991b1b;
  font-size:16px;
  font-weight:900;
}

.v77-modal{
  position:fixed;
  inset:0;
  z-index:999999;
  background:rgba(15,23,42,.65);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.v77-dialog{
  width:min(1180px,96vw);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border-radius:18px;
  box-shadow:0 28px 90px rgba(0,0,0,.35);
}

.v77-head{
  position:sticky;
  top:0;
  background:#fff;
  z-index:2;
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding:18px 20px;
  border-bottom:1px solid #e5e7eb;
}

.v77-head h2{
  margin:0;
  color:#0f172a;
  font-size:24px;
}

.v77-head p{
  margin:5px 0 0;
  color:#64748b;
}

.v77-head button{
  border:0;
  background:#fee2e2;
  color:#991b1b;
  width:42px;
  height:42px;
  border-radius:12px;
  font-size:28px;
  font-weight:900;
  cursor:pointer;
}

.v77-table-wrap{
  padding:16px 20px;
  overflow:auto;
}

.v77-report-table{
  width:100%;
  border-collapse:collapse;
  min-width:900px;
}

.v77-report-table th{
  background:#0b63b6;
  color:#fff;
  padding:12px;
  text-align:left;
}

.v77-report-table td{
  border:1px solid #e5e7eb;
  padding:10px;
  vertical-align:top;
}

.v77-report-table textarea{
  width:100%;
  min-height:54px;
  resize:vertical;
  border:1px solid #cbd5e1;
  border-radius:8px;
  padding:8px;
  box-sizing:border-box;
  font-family:Arial, sans-serif;
}

.v77-note-box{
  padding:0 20px 16px;
}

.v77-note-box label{
  display:block;
  font-weight:900;
  margin-bottom:8px;
}

.v77-note-box textarea{
  width:100%;
  min-height:72px;
  resize:vertical;
  border:1px solid #cbd5e1;
  border-radius:10px;
  padding:10px;
  box-sizing:border-box;
}

.v77-actions{
  position:sticky;
  bottom:0;
  background:#fff;
  border-top:1px solid #e5e7eb;
  display:flex;
  justify-content:flex-end;
  gap:10px;
  padding:16px 20px;
}

.v77-actions button{
  border:0;
  border-radius:10px;
  padding:12px 16px;
  font-weight:900;
  cursor:pointer;
}

.v77-actions button:first-child{
  background:#16a34a;
  color:#fff;
}

.v77-actions button:last-child{
  background:#e2e8f0;
  color:#0f172a;
}

.v77-progress{
  background:#fff7ed;
  border:2px solid #fb923c;
  color:#9a3412;
  border-radius:10px;
  padding:14px 16px;
  margin:10px 0 14px;
  font-weight:900;
}

.v77-progress span{
  display:block;
  margin-top:4px;
}

.v77-progress div{
  margin-top:10px;
  height:8px;
  background:#fed7aa;
  border-radius:999px;
  overflow:hidden;
}

.v77-progress i{
  display:block;
  height:100%;
  width:0%;
  background:#f97316;
  border-radius:999px;
  animation:v77load 5s linear forwards;
}

@keyframes v77load{
  from{width:0%}
  to{width:100%}
}

@media(max-width:1000px){
  .v77-detail,
  .v77-grid{
    grid-template-columns:1fr;
  }
  .v77-table{
    min-width:900px;
  }
  .v77-result-box{
    overflow:auto;
  }
}
