
:root {
  --aes-navy: #1a2b5e;
  --aes-blue: #1e4fa3;
  --aes-green: #2d8653;
  --aes-light: #f0f4fb;
  --aes-border: #d0daea;
  --aes-text: #1a1f2e;
  --aes-muted: #5a6680;
  --aes-white: #ffffff;
  --aes-row: #f7f9fd;
  --aes-danger: #c0392b;
  --aes-success: #27ae60;
  --radius: 8px;
  --shadow: 0 2px 12px rgba(26,43,94,0.10);
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;margin:0;padding:0;background:#1a2b5e;overflow:hidden;}
#page-form,#page-dashboard,#page-admin{background:#f0f4fb!important;}
#page-dashboard{display:none;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;}
#page-dashboard.active{display:flex;}
#page-landing.active,#page-login.active{overflow-y:auto;height:100vh;height:100dvh;}
#page-form.active,#page-admin.active{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;width:100%;max-width:100%;}
#page-form .form-scroll-shell{overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;width:100%;box-sizing:border-box;}
.form-wrap{max-width:860px;margin:0 auto;padding:24px 20px 60px;}
#page-admin #admin-users-page{overflow-y:auto;flex:1;min-height:0;width:100%;box-sizing:border-box;overflow-x:hidden;}
#page-admin #admin-logs-page{width:100%;box-sizing:border-box;overflow-y:auto;flex:1;min-height:0;padding:24px 20px max(16px,env(safe-area-inset-bottom,16px));}
@media(max-width:600px){
  .admin-add-grid{grid-template-columns:1fr!important;}
  .admin-add-grid button{width:100%;}
}
body{font-family:'Sarabun','IBM Plex Sans',sans-serif;background:#eef2f9;color:var(--aes-text);min-height:100vh;font-size:15px;}
/* ---- PAGES ---- */
.page{display:none;}
.page.active{display:block;}
/* ---- TOPBAR ---- */
.topbar{background:var(--aes-navy);padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,0.18);}
.topbar-brand{display:flex;align-items:center;gap:14px;}
.topbar-logo{height:36px;}
.topbar-title{color:white;font-size:17px;font-weight:600;letter-spacing:0.3px;}
.topbar-right{display:flex;align-items:center;gap:12px;}
.topbar-btn{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.22);color:white;padding:6px 16px;border-radius:var(--radius);font-size:13px;cursor:pointer;font-family:inherit;transition:all .2s;}
.topbar-btn:hover{background:rgba(255,255,255,0.22);}
.topbar-badge{background:var(--aes-green);color:white;font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600;}
/* ---- LANDING ---- */
.landing-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2b5e 0%,#2a5a9e 60%,#1e6645 100%);background-size:200% 200%;animation:gradientShift 32s ease infinite;padding:40px 20px 50px;padding-bottom:calc(50px + 32px);}
@keyframes gradientShift{
  0%{background-position:0% 50%;}
  25%{background-position:100% 50%;}
  50%{background-position:100% 0%;}
  75%{background-position:0% 100%;}
  100%{background-position:0% 50%;}
}
.landing-card{background:white;border-radius:16px;padding:48px 48px 40px;max-width:520px;width:100%;box-shadow:0 8px 40px rgba(0,0,0,0.22);text-align:center;}
.landing-logo{height:60px;margin-bottom:8px;}
.landing-subtitle{color:var(--aes-muted);font-size:14px;margin-bottom:32px;}
.landing-title{font-size:22px;font-weight:700;color:var(--aes-navy);margin-bottom:6px;}
.landing-divider{display:flex;align-items:center;gap:12px;margin:28px 0;}
.landing-divider span{flex:1;height:1px;background:var(--aes-border);}
.landing-divider p{color:var(--aes-muted);font-size:13px;}
.btn-primary{background:var(--aes-blue);color:white;border:none;padding:13px 32px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;width:100%;font-family:inherit;transition:all .2s;margin-bottom:10px;}
.btn-primary:hover{background:var(--aes-navy);}
.btn-secondary{background:white;color:var(--aes-navy);border:2px solid var(--aes-navy);padding:12px 32px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;width:100%;font-family:inherit;transition:all .2s;}
.btn-secondary:hover{background:var(--aes-light);}
/* ---- HR LOGIN ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2b5e,#1e4fa3);padding:20px 20px 50px;}
.login-card{background:white;border-radius:16px;padding:48px;max-width:400px;width:100%;box-shadow:0 8px 40px rgba(0,0,0,0.22);}
.login-logo{height:48px;margin-bottom:16px;}
.login-title{font-size:20px;font-weight:700;color:var(--aes-navy);margin-bottom:4px;}
.login-sub{font-size:13px;color:var(--aes-muted);margin-bottom:28px;}
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--aes-navy);margin-bottom:6px;}
.form-group input{width:100%;border:1.5px solid var(--aes-border);border-radius:var(--radius);padding:10px 14px;font-size:14px;font-family:inherit;outline:none;transition:border .2s;}
.form-group input:focus{border-color:var(--aes-blue);}
.login-err{color:var(--aes-danger);font-size:13px;margin-bottom:12px;display:none;}
@keyframes flashRed{0%{border-color:var(--aes-danger);background:#fff0f0;}70%{border-color:var(--aes-danger);background:#fff0f0;}100%{border-color:var(--aes-border);background:white;}}
.captcha-flash{animation:flashRed 1.2s ease forwards;}
.btn-back{background:none;border:none;color:var(--aes-muted);font-size:13px;cursor:pointer;margin-top:14px;font-family:inherit;text-decoration:underline;}
/* ---- DASHBOARD ---- */
.dash-layout{display:flex;flex:1;overflow:hidden;min-height:0;}
.dash-sidebar{width:220px;background:var(--aes-navy);padding:24px 0;flex-shrink:0;position:sticky;top:0;height:100%;overflow-y:hidden;transition:width .2s;}
.sidebar-item{display:flex;align-items:center;gap:10px;padding:12px 24px;color:rgba(255,255,255,0.72);font-size:14px;cursor:pointer;transition:all .2s;border-left:3px solid transparent;}
.sidebar-item:hover,.sidebar-item.active{background:rgba(255,255,255,0.10);color:white;border-left-color:var(--aes-green);}
.sidebar-icon{font-size:16px;}
.dash-main{flex:1;padding:28px 32px max(48px,calc(32px + env(safe-area-inset-bottom,0px)));overflow-y:auto;overflow-x:hidden;}
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.dash-header h2{font-size:20px;font-weight:700;color:var(--aes-navy);}
.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px;}
.stat-card{background:white;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border-left:4px solid var(--aes-blue);}
.stat-card.green{border-left-color:var(--aes-green);}
.stat-card.amber{border-left-color:#e67e22;}
.stat-number{font-size:28px;font-weight:700;color:var(--aes-navy);}
.stat-label{font-size:12px;color:var(--aes-muted);margin-top:4px;}
/* ---- TABLE ---- */
.table-wrap{background:white;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--aes-border);}
.table-toolbar h3{font-size:15px;font-weight:700;color:var(--aes-navy);}
.sort-btn{background:white;border:1.5px solid var(--aes-border);border-radius:6px;padding:5px 10px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;color:var(--aes-navy);display:inline-flex;align-items:center;gap:4px;transition:all .15s;}
.sort-btn:hover{background:#f0f4fb;}
.sort-btn.active-sort{background:var(--aes-navy);color:white;border-color:var(--aes-navy);}
.search-box{border:1.5px solid var(--aes-border);border-radius:var(--radius);padding:7px 14px;font-size:13px;font-family:inherit;outline:none;width:220px;}
.search-box:focus{border-color:var(--aes-blue);}
table{width:100%;border-collapse:collapse;}
thead tr{background:var(--aes-navy);}
thead th{color:white;font-size:12px;font-weight:600;padding:10px 14px;text-align:left;letter-spacing:0.4px;}
tbody tr{border-bottom:1px solid var(--aes-border);transition:background .15s;cursor:pointer;}
tbody tr:hover{background:var(--aes-row);}
tbody td{padding:10px 14px;font-size:13px;color:var(--aes-text);}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;}
.badge-new{background:#e8f4fd;color:#1e4fa3;}
.badge-reviewed{background:#e8f7ee;color:#2d8653;}
.badge-rejected{background:#fde8e8;color:#c0392b;}
.badge-passed{background:#d5f5e3;color:#1a7a4a;}
.badge-reserved{background:#fef9e7;color:#d68910;}
/* ---- APPLICANT DETAIL ---- */
.detail-wrap{background:white;border-radius:var(--radius);box-shadow:var(--shadow);padding:32px;}
.detail-header{display:flex;align-items:center;gap:20px;margin-bottom:28px;padding-bottom:20px;border-bottom:2px solid var(--aes-border);}
.applicant-avatar{width:64px;height:64px;border-radius:50%;background:var(--aes-navy);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:white;flex-shrink:0;}
.detail-name{font-size:20px;font-weight:700;color:var(--aes-navy);}
.detail-pos{font-size:13px;color:var(--aes-muted);margin-top:2px;}
.detail-actions{margin-left:auto;display:flex;gap:10px;}
.btn-pdf{background:var(--aes-navy);color:white;border:none;padding:9px 18px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;}
.btn-pdf:hover{background:#111d3d;}
.btn-back-dash{background:white;color:var(--aes-navy);border:1.5px solid var(--aes-border);padding:9px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;}
.btn-back-dash:hover{background:var(--aes-light);}
.section-title{font-size:13px;font-weight:700;color:var(--aes-blue);text-transform:uppercase;letter-spacing:0.8px;margin:22px 0 12px;padding-bottom:6px;border-bottom:1.5px solid var(--aes-border);}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px 24px;}
.info-item label{font-size:11px;color:var(--aes-muted);font-weight:600;letter-spacing:0.4px;text-transform:uppercase;}
.info-item p{font-size:14px;color:var(--aes-text);margin-top:2px;font-weight:500;}
.mini-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px;}
.mini-table th{background:var(--aes-light);color:var(--aes-navy);font-size:11px;font-weight:700;padding:7px 10px;text-align:left;letter-spacing:0.3px;}
.mini-table td{padding:7px 10px;border-bottom:1px solid var(--aes-border);}
/* ---- HR INTERNAL SECTION ---- */
.hr-section{background:#fffbea;border:1.5px solid #f0d060;border-radius:var(--radius);padding:20px;margin-top:24px;}
.hr-section-title{font-size:13px;font-weight:700;color:#7d6200;text-transform:uppercase;letter-spacing:0.7px;margin-bottom:14px;}
.hr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 20px;}
@media(max-width:700px){.hr-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.hr-grid{grid-template-columns:1fr;}}
.hr-field label{font-size:12px;color:#7d6200;font-weight:600;display:block;margin-bottom:4px;}
.hr-field input,.hr-field select,.hr-field textarea{width:100%;border:1.5px solid #e0c840;border-radius:6px;padding:8px 10px;font-size:13px;font-family:inherit;background:white;outline:none;}
.hr-field textarea{height:70px;resize:vertical;}
.radio-group{display:flex;gap:16px;flex-wrap:wrap;}
.radio-group label{font-size:13px;color:var(--aes-text);display:flex;align-items:center;gap:6px;font-weight:400;cursor:pointer;}
.btn-save-hr{background:var(--aes-green);color:white;border:none;padding:10px 24px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;margin-top:16px;transition:all .2s;}
.btn-save-hr:hover{background:#1f6b40;}
.btn-delete{background:white;color:var(--aes-danger);border:1.5px solid var(--aes-danger);padding:9px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;}
.btn-delete:hover{background:var(--aes-danger);color:white;}
.btn-delete-sm{background:none;border:none;color:var(--aes-danger);font-size:13px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;font-family:inherit;}
.btn-delete-sm:hover{background:#fde8e8;}
/* Pagination */
.pg-btn{background:white;border:1.5px solid var(--aes-border);color:var(--aes-navy);padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;min-width:36px;}
.pg-btn:hover{border-color:var(--aes-blue);color:var(--aes-blue);}
.pg-btn.active{background:var(--aes-navy);color:white;border-color:var(--aes-navy);}
.pg-btn:disabled{opacity:0.35;cursor:default;}
.pg-sep{color:var(--aes-muted);padding:0 4px;font-weight:600;line-height:36px;}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(26,43,94,0.55);z-index:2000;align-items:center;justify-content:center;}
.modal-overlay.show{display:flex;}
.modal-card{background:white;border-radius:14px;padding:36px 32px;max-width:380px;width:90%;text-align:center;box-shadow:0 8px 40px rgba(0,0,0,0.22);}
.modal-icon{font-size:40px;margin-bottom:12px;}
.modal-title{font-size:18px;font-weight:700;color:var(--aes-text);margin-bottom:8px;}
.modal-msg{font-size:14px;color:var(--aes-muted);line-height:1.6;margin-bottom:24px;}
.modal-actions{display:flex;gap:10px;justify-content:center;}
.btn-confirm-del{background:var(--aes-danger);color:white;border:none;padding:10px 24px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;}
.btn-confirm-del:hover{background:#9b2b1b;}
.btn-cancel-del{background:white;color:var(--aes-navy);border:1.5px solid var(--aes-border);padding:10px 20px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;}
.btn-cancel-del:hover{background:var(--aes-light);}
/* ---- APPLICATION FORM ---- */
#page-admin #admin-db-page{flex:1;min-height:0;width:100%;box-sizing:border-box;overflow:hidden;}
.db-table-btn{display:block;width:100%;text-align:left;padding:9px 16px;background:none;border:none;font-family:inherit;font-size:13px;color:var(--aes-navy);cursor:pointer;border-left:3px solid transparent;transition:all .15s;}
.db-table-btn:hover{background:#f3e8fd;border-left-color:#7c3aed;}
.db-table-btn.active{background:#ede9fe;border-left-color:#7c3aed;font-weight:700;color:#7c3aed;}
/* ===== DB MANAGER TABLE - COMPLETE REWRITE ===== */
.db-data-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed;}
.db-data-table th{background:var(--aes-navy);color:white;padding:10px 14px;text-align:left;font-weight:600;font-size:12px;letter-spacing:0.3px;position:sticky;top:0;z-index:2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.db-data-table td{padding:10px 14px;border-bottom:1px solid var(--aes-border);vertical-align:middle;background:white;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.db-data-table tbody tr:nth-child(even) td{background:#f9fbfd;}
.db-data-table tbody tr:hover td{background:#f3e8fd;}
.db-th-num{width:44px;text-align:center!important;}
.db-td-num{width:44px;text-align:center!important;color:#aaa;font-size:12px;}
.db-th-act{width:130px;text-align:center!important;}
.db-td-act{width:130px;text-align:center!important;white-space:nowrap;}
/* ===== END DB MANAGER TABLE ===== */
.db-action-btn{border:none;border-radius:5px;padding:4px 10px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;}
.db-edit-btn{background:#dbeafe;color:#1e40af;}
.db-del-btn{background:#fde8e8;color:var(--aes-danger);}
.db-pg-btn{border:1.5px solid var(--aes-border);background:white;border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;font-family:inherit;}
.db-pg-btn.active{background:var(--aes-navy);color:white;border-color:var(--aes-navy);}
.db-field-row{display:flex;flex-direction:column;gap:4px;}
.db-field-row label{font-size:12px;font-weight:600;color:var(--aes-navy);}
.db-field-row input,.db-field-row textarea,.db-field-row select{border:1.5px solid var(--aes-border);border-radius:6px;padding:8px 10px;font-size:13px;font-family:inherit;outline:none;width:100%;box-sizing:border-box;}
.db-field-row textarea{min-height:80px;resize:vertical;}

.form-top{background:var(--aes-navy);border-radius:12px 12px 0 0;padding:24px 140px;display:flex;align-items:center;justify-content:center;min-height:140px;position:relative;overflow:hidden;}
.form-top-logo{height:48px;}
.form-top-title{text-align:center;}
.form-top-title h1{color:white;font-size:20px;font-weight:700;}
.form-top-title p{color:rgba(255,255,255,0.72);font-size:14px;}
.form-top-photo{
  width:90px;height:110px;
  border:2px dashed rgba(255,255,255,0.4);border-radius:6px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;color:rgba(255,255,255,0.6);font-size:11px;text-align:center;gap:4px;
  position:relative;overflow:hidden;
  flex-shrink:0;min-width:90px;min-height:110px;max-width:90px;max-height:110px;
}
.form-top-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.form-card{background:white;padding:28px 32px;border-left:1px solid var(--aes-border);border-right:1px solid var(--aes-border);}
.form-card:last-of-type{border-bottom:1px solid var(--aes-border);border-radius:0 0 12px 12px;}
.form-section-title{font-size:14px;font-weight:700;color:var(--aes-navy);background:var(--aes-light);padding:8px 14px;border-radius:6px;margin-bottom:16px;border-left:4px solid var(--aes-blue);}
.frow{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:14px;}
.frow.full{grid-template-columns:1fr;}
.frow.two{grid-template-columns:1fr 1fr;}
.frow.three{grid-template-columns:1fr 1fr 1fr;}
.frow.four{grid-template-columns:1fr 1fr 1fr 1fr;}
.fg{display:flex;flex-direction:column;gap:4px;}
.fg label{font-size:12px;font-weight:600;color:var(--aes-navy);}
.fg label span{color:var(--aes-danger);}
.idtype-options{display:flex;gap:12px;padding:8px 12px;background:var(--aes-light);border-radius:6px;margin-bottom:6px;flex-wrap:wrap;}
.idtype-opt{display:inline-flex!important;align-items:center!important;gap:6px!important;font-size:13px!important;font-weight:500!important;color:var(--aes-navy)!important;cursor:pointer;white-space:nowrap;padding:4px 8px;}
.idtype-opt input[type="radio"]{width:16px;height:16px;flex-shrink:0;margin:0;}
#idcard-fg{grid-column:span 2;}
.fg input,.fg select,.fg textarea{border:1.5px solid var(--aes-border);border-radius:6px;padding:8px 12px;font-size:14px;font-family:inherit;outline:none;transition:border .2s;width:100%;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--aes-blue);}
.fg textarea{height:64px;resize:vertical;}
.checkbox-row{display:flex;gap:20px;flex-wrap:wrap;align-items:center;padding:6px 0;}
.checkbox-row label{display:flex;align-items:center;gap:7px;font-size:14px;cursor:pointer;}
.section-divider{height:1px;background:var(--aes-border);margin:20px 0;}
.date-wrap{position:relative;display:flex;align-items:center;}
.date-wrap input.date-text{flex:1;padding-right:36px;}
.date-wrap .date-cal-btn{position:absolute;right:0;top:0;bottom:0;width:36px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--aes-muted);font-size:15px;}
.date-wrap .date-cal-btn:hover{color:var(--aes-navy);}
.date-wrap input.date-hidden{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;}
.section-deco-divider{display:flex;align-items:center;gap:14px;margin:0;padding:10px 20px;background:white;border-left:1px solid var(--aes-border);border-right:1px solid var(--aes-border);overflow:hidden;box-sizing:border-box;width:100%;}
.section-deco-divider span{flex:1;height:1px;background:linear-gradient(to right,transparent,var(--aes-border),transparent);}
.section-deco-divider p{font-size:10px;font-weight:700;color:var(--aes-muted);letter-spacing:2px;text-transform:uppercase;white-space:nowrap;padding:0 8px;}
/* mini form tables */
.form-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:10px;}
.form-table th{background:var(--aes-navy);color:white;padding:8px 10px;font-size:12px;font-weight:600;text-align:left;}
.form-table.center-headers th{text-align:center;}
.form-table td{border:1px solid var(--aes-border);padding:4px;}
.form-table td input,.form-table td select{border:none;width:100%;font-size:13px;font-family:inherit;padding:5px 8px;background:transparent;outline:none;}
.form-table tr:nth-child(even){background:#f9fbfd;}
/* Scroll wrapper — applied in HTML around each table */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:10px;}
.table-scroll .form-table{min-width:480px;width:100%;}

.lang-table th,.lang-table td{text-align:center;border:1px solid var(--aes-border);}
.lang-table th{background:var(--aes-navy);color:white;padding:7px 4px;white-space:nowrap;}
.lang-table td{padding:6px 4px;}
.lang-table td:first-child{text-align:left;font-weight:600;padding-left:10px;white-space:nowrap;}
.submit-bar{text-align:center;padding:24px 0;}
.btn-submit{background:var(--aes-blue);color:white;border:none;padding:14px 48px;border-radius:var(--radius);font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;box-shadow:0 4px 16px rgba(30,79,163,0.3);}
.btn-submit:hover{background:var(--aes-navy);transform:translateY(-1px);}
.fg input.field-error,.fg select.field-error,.fg textarea.field-error{border-color:var(--aes-danger)!important;background:#fff5f5!important;}
.field-error-msg{font-size:11px;color:var(--aes-danger);margin-top:3px;font-weight:600;display:none;}
.fg.has-error .field-error-msg{display:block;}
.form-error-banner{background:#fff0f0;border:1.5px solid var(--aes-danger);border-radius:var(--radius);padding:14px 20px;margin-bottom:18px;font-size:13px;color:var(--aes-danger);font-weight:600;display:none;align-items:flex-start;gap:10px;text-align:left;line-height:1.5;}
.form-error-banner.show{display:flex;}
.success-overlay{display:none;position:fixed;inset:0;background:rgba(26,43,94,0.7);z-index:1000;align-items:center;justify-content:center;}
.success-overlay.show{display:flex;}
.success-card{background:white;border-radius:16px;padding:48px 40px;text-align:center;max-width:400px;}
.success-icon{font-size:48px;margin-bottom:16px;}
.success-title{font-size:22px;font-weight:700;color:var(--aes-green);margin-bottom:8px;}
.success-msg{color:var(--aes-muted);font-size:14px;line-height:1.6;}
/* lang toggle */
.lang-toggle{display:flex;border:1px solid rgba(255,255,255,0.3);border-radius:6px;overflow:hidden;}
.lang-toggle button{background:none;border:none;color:rgba(255,255,255,0.6);padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;}
.lang-toggle button.active{background:rgba(255,255,255,0.18);color:white;}
/* tab system for detail view */
.tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid var(--aes-border);padding-bottom:0;}
.tab{padding:10px 18px;font-size:13px;font-weight:600;color:var(--aes-muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;}
.tab.active{color:var(--aes-blue);border-bottom-color:var(--aes-blue);}
.tab-content{display:none;}
.tab-content.active{display:block;}
/* responsive */
/* ===== RESPONSIVE / MOBILE ===== */
@media(max-width:640px){
  /* Grid columns collapse to 1 column on mobile */
  .frow.four,.frow.three,.frow.two{grid-template-columns:1fr;}
  .frow{grid-template-columns:1fr;}
  /* Reset span 2 on mobile since grid is now 1 column */
  #idcard-fg{grid-column:span 1;}

  /* Form */
  .form-wrap{padding:12px 12px 60px;}
  .form-top{flex-direction:column!important;align-items:center!important;justify-content:flex-start!important;padding:16px 16px 136px!important;min-height:auto!important;overflow:hidden!important;}
  .form-top-photo{position:absolute!important;bottom:14px!important;left:50%!important;transform:translateX(-50%)!important;right:auto!important;top:auto!important;}
  .form-card{padding:14px 12px;}

  /* Landing & Login cards */
  .landing-card{padding:32px 20px 28px;border-radius:12px;}
  .login-card{padding:32px 20px;border-radius:12px;}

  /* Topbar */
  .topbar{padding:0 12px;height:52px;}
  .topbar-badge{display:none;}
  .topbar-btn{padding:6px 10px;font-size:12px;}

  /* Dashboard — icon-only sidebar on tablet/small screens */
  .dash-sidebar{width:58px;padding:16px 0;}
  .dash-main{padding:14px 10px max(48px,calc(32px + env(safe-area-inset-bottom,0px)));}
  .stat-cards{grid-template-columns:1fr 1fr;}
  .table-wrap{overflow-x:auto;}
  table{min-width:480px;}
  .sidebar-item{padding:12px 0;justify-content:center;gap:0;border-left:3px solid transparent;}
  .sidebar-label{display:none;}
  .sidebar-icon{font-size:20px;}
  /* Clock — compact on mobile */
  #dash-clock{min-width:0!important;margin-right:4px!important;}
  #dash-clock div:first-child{font-size:10px!important;}
  #dash-clock div:last-child{font-size:12px!important;letter-spacing:0.5px!important;}

  /* Detail tabs scroll horizontally */
  .tabs{overflow-x:auto;white-space:nowrap;padding-bottom:4px;flex-wrap:nowrap!important;}
  .tab{flex-shrink:0;font-size:12px;padding:8px 10px;}

  /* Info grid 1 col */
  .info-grid{grid-template-columns:1fr 1fr;}

  /* Form table headers wrap */
  /* Form tables scroll horizontally */
  .table-scroll{overflow-x:auto;}
  .table-scroll .form-table{min-width:460px;}
  .form-table th,.form-table td{font-size:11px;padding:6px 4px;}

  /* Military/marital checkbox rows */
  .checkbox-row{flex-wrap:wrap;gap:8px;}

  /* Skills language radio rows */
  .lang-table{font-size:11px;}
  .lang-table td,.lang-table th{padding:4px 3px;}

  /* Success overlay */
  .success-card{padding:32px 20px;}

  /* Section decorative divider text */
  .section-deco-divider p{font-size:9px;}

  /* ID card radio row wrap */
  #l-idcard + div{flex-wrap:wrap;gap:8px;}

  /* Submit bar */
  .submit-bar{padding:12px 12px;flex-direction:column;gap:8px;align-items:stretch;}
  .btn-submit{width:100%;text-align:center;}

  /* Modal */
  .modal-card{padding:28px 20px;}
}

@media(max-width:480px){
  .frow.four,.frow.three,.frow.two,.frow{grid-template-columns:1fr!important;}
  .info-grid{grid-template-columns:1fr!important;}
  .fg[style*="grid-column:span"]{grid-column:span 1!important;}
  .topbar-right{gap:4px;}
  .topbar-btn{padding:5px 7px;font-size:11px;}
  .topbar-btn svg{display:none;}
  .form-section-title{font-size:14px;}
  .form-top h1{font-size:22px;}
  .stat-cards{grid-template-columns:1fr!important;}
}
