/* ============================================================
   GFMB Admissions System — Design System
   Navy + cream + gold, clean tables, premium form UI
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --navy:#0B1F3A;
  --navy-mid:#122847;
  --navy-lite:#1A3660;
  --gold:#C9A84C;
  --gold-lite:#E8D08A;
  --cream:#F7F5F0;
  --cream-dark:#EDE9E0;
  --slate:#4A5568;
  --slate-lite:#718096;
  --white:#fff;
  --green-bg:#EAF3DE;--green-txt:#27500A;--green-bdr:#3B6D11;
  --amber-bg:#FAEEDA;--amber-txt:#633806;--amber-bdr:#854F0B;
  --red-bg:#FCEBEB;--red-txt:#791F1F;--red-bdr:#A32D2D;
  --gray-bg:#F1EFE8;--gray-txt:#444441;
  --blue-bg:#E6F1FB;--blue-txt:#0C447C;
  --border:rgba(0,0,0,0.09);
  --radius:6px;--radius-lg:10px;--radius-xl:14px;
  --shadow:0 2px 12px rgba(0,0,0,.07);
  --shadow-lg:0 8px 32px rgba(0,0,0,.12);
}

body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:14px;line-height:1.5;color:var(--navy);
}

/* ── ADMIN SHELL ─────────────────────────────────────────────── */
body.admin-page{background:var(--cream);min-height:100vh}

.topbar{
  background:var(--navy);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1.5rem;height:54px;
  border-bottom:1px solid rgba(201,168,76,.2);
  position:sticky;top:0;z-index:100;
}
.topbar-logo{font-size:16px;font-weight:700;color:#fff;letter-spacing:.01em}
.topbar-logo span{color:rgba(255,255,255,.35);font-size:12px;font-weight:400;margin-left:8px}
.topbar-right{display:flex;align-items:center;gap:16px}
.topbar-user{font-size:12px;color:rgba(255,255,255,.45)}
.topbar-user strong{color:rgba(255,255,255,.85)}
.logout-btn{
  font-size:12px;color:rgba(255,255,255,.5);text-decoration:none;
  padding:5px 10px;border:1px solid rgba(255,255,255,.15);border-radius:4px;
  transition:background .15s;
}
.logout-btn:hover{background:rgba(255,255,255,.08);color:#fff}

.shell{display:flex;min-height:calc(100vh - 54px)}

.sidebar{
  width:216px;flex-shrink:0;
  background:var(--white);
  border-right:0.5px solid var(--border);
  padding:1rem 0;
  display:flex;flex-direction:column;
  position:sticky;top:54px;
  height:calc(100vh - 54px);
  overflow-y:auto;
}
.sb-section{
  font-size:10px;font-weight:600;color:var(--slate-lite);
  letter-spacing:.08em;text-transform:uppercase;
  padding:10px 16px 4px;
}
.sb-item{
  display:flex;align-items:center;gap:9px;
  padding:9px 16px;
  font-size:13px;color:var(--slate);
  text-decoration:none;
  border-left:2px solid transparent;
  transition:background .12s,color .12s;
}
.sb-item:hover{background:var(--cream);color:var(--navy)}
.sb-item.active{background:rgba(11,31,58,.05);color:var(--navy);font-weight:500;border-left-color:var(--gold)}
.sb-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7;transition:opacity .12s}
.sb-item:hover svg,.sb-item.active svg{opacity:1}
.sb-footer{margin-top:auto;padding:12px 14px;border-top:0.5px solid var(--border)}
.sb-avatar{
  width:30px;height:30px;border-radius:50%;
  background:var(--navy);color:#fff;
  font-size:12px;font-weight:600;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.sb-footer{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:auto;padding:12px 14px;border-top:0.5px solid var(--border)}
.sb-footer > div:nth-child(2){flex:1;min-width:0}
.sb-user-name{font-size:11px;font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-email{font-size:10px;color:var(--slate-lite);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-logout{color:var(--slate-lite);display:flex;align-items:center;flex-shrink:0;transition:color .12s}
.sb-logout:hover{color:var(--red-txt)}
.sb-logout svg{width:15px;height:15px}
.sb-powered{width:100%;padding-top:10px;border-top:0.5px solid var(--border);margin-top:4px}
.sb-powered img{height:22px;opacity:.65;transition:opacity .15s;display:block}
.sb-powered img:hover{opacity:1}

.main{flex:1;min-width:0}
.page-head{
  padding:1.25rem 1.5rem 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
  margin-bottom:1.25rem;
}
.page-title{font-size:18px;font-weight:600;color:var(--navy)}
.page-body{padding:0 1.5rem 2rem}

/* Stat cards */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:1.25rem}
.stat-card{background:var(--white);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:16px;position:relative}
.stat-icon-wrap{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--cream);border-radius:8px;margin-bottom:10px;color:var(--slate)}
.stat-icon-wrap svg{width:16px;height:16px}
.stat-label{font-size:11px;color:var(--slate-lite);margin-bottom:4px;font-weight:500}
.stat-value{font-size:26px;font-weight:700;color:var(--navy);line-height:1}
.stat-value.green{color:var(--green-txt)}
.stat-value.amber{color:var(--amber-txt)}
.stat-value.red{color:var(--red-txt)}
.stat-sub{font-size:11px;color:var(--slate-lite);margin-top:4px}
.page-head-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* Cards */
.card{background:var(--white);border:0.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1rem;overflow:hidden}
.card-head{padding:12px 16px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.card-title{font-size:13px;font-weight:600;color:var(--navy)}
.card-body{padding:16px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:0 14px;height:34px;
  font-size:13px;font-weight:500;font-family:inherit;
  border-radius:var(--radius);border:none;cursor:pointer;
  text-decoration:none;white-space:nowrap;
  transition:opacity .15s,background .15s;
}
.btn:hover{opacity:.88}
.btn-navy{background:var(--navy);color:#fff}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-outline{background:transparent;color:var(--navy);border:0.5px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff;opacity:1}
.btn-ghost{background:transparent;color:var(--slate);border:0.5px solid var(--border)}
.btn-ghost:hover{background:var(--cream);opacity:1}
.btn-danger{background:transparent;color:var(--red-txt);border:0.5px solid var(--red-bdr)}
.btn-danger:hover{background:var(--red-bg);opacity:1}
.btn-success{background:transparent;color:var(--green-txt);border:0.5px solid var(--green-bdr)}
.btn-success:hover{background:var(--green-bg);opacity:1}
.btn-sm{height:28px;padding:0 10px;font-size:12px}
.btn-lg{height:44px;padding:0 20px;font-size:14px}

/* Tables */
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:12px}
.tbl th{background:var(--cream);padding:9px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--slate);border-bottom:0.5px solid var(--border);white-space:nowrap}
.tbl td{padding:10px 14px;border-bottom:0.5px solid var(--border);color:var(--navy);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(0,0,0,.012)}
.tbl .mono{font-family:monospace;font-size:11px}
.tbl-meta{padding:8px 14px;border-bottom:0.5px solid var(--border);font-size:11px;color:var(--slate-lite);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.td-muted{color:var(--slate-lite)}

/* Pills */
.pill{display:inline-block;font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;white-space:nowrap}
.pill-green{background:var(--green-bg);color:var(--green-txt)}
.pill-amber{background:var(--amber-bg);color:var(--amber-txt)}
.pill-red{background:var(--red-bg);color:var(--red-txt)}
.pill-gray{background:var(--gray-bg);color:var(--gray-txt)}
.pill-blue{background:var(--blue-bg);color:var(--blue-txt)}

/* Alerts */
.alert{padding:10px 14px;border-radius:0 var(--radius) var(--radius) 0;font-size:13px;line-height:1.4;margin-bottom:1rem}
.alert-error{background:var(--red-bg);border-left:3px solid var(--red-bdr);color:var(--red-txt)}
.alert-success{background:var(--green-bg);border-left:3px solid var(--green-bdr);color:var(--green-txt)}
.alert-info{background:var(--blue-bg);border-left:3px solid var(--blue-txt);color:var(--blue-txt)}
.alert-warning{background:var(--amber-bg);border-left:3px solid var(--amber-bdr);color:var(--amber-txt)}

/* Form controls (admin) */
.f-label{display:block;font-size:11px;font-weight:500;color:var(--slate-lite);margin-bottom:4px}
.f-input,.f-select,.f-textarea{
  width:100%;height:36px;padding:0 11px;
  border:0.5px solid rgba(0,0,0,0.15);border-radius:var(--radius);
  font-size:13px;color:var(--navy);background:#fff;outline:none;
  font-family:inherit;transition:border-color .15s;
}
.f-textarea{height:auto;padding:9px 11px;resize:vertical}
.f-input:focus,.f-select:focus,.f-textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(11,31,58,0.06)}
.f-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:12px}
.f-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;align-items:center}

/* Detail rows */
.drow{display:flex;justify-content:space-between;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:13px;gap:12px}
.drow:last-child{border-bottom:none}
.dk{color:var(--slate-lite);flex-shrink:0;min-width:140px}
.dv{color:var(--navy);font-weight:500;text-align:right;word-break:break-word}
.dsection{font-size:10px;font-weight:600;color:var(--slate-lite);text-transform:uppercase;letter-spacing:.08em;margin:18px 0 8px;padding-bottom:4px;border-bottom:0.5px solid var(--border)}

/* Row actions */
.row-actions{display:flex;gap:5px;flex-wrap:wrap}

/* Empty state */
.empty{text-align:center;padding:3rem 1rem;font-size:13px;color:var(--slate-lite)}
.empty-icon{font-size:40px;margin-bottom:12px;display:block}

/* Search/filter bar */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:1rem}
.filter-bar .f-input{height:34px;width:auto;flex:1;min-width:160px;max-width:280px}
.filter-bar select{height:34px;padding:0 10px;border:0.5px solid rgba(0,0,0,0.15);border-radius:var(--radius);font-size:13px;color:var(--navy);background:#fff;font-family:inherit;cursor:pointer;outline:none}

/* Outcome action buttons */
.outcome-actions{display:flex;gap:8px;flex-wrap:wrap}
.outcome-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--radius);
  font-size:13px;font-weight:500;font-family:inherit;
  border:0.5px solid;cursor:pointer;text-decoration:none;
  transition:all .15s;
}
.outcome-accept{background:var(--green-bg);color:var(--green-txt);border-color:var(--green-bdr)}
.outcome-accept:hover{background:#d4edbe}
.outcome-reject{background:var(--red-bg);color:var(--red-txt);border-color:var(--red-bdr)}
.outcome-reject:hover{background:#f7d4d4}
.outcome-hold{background:var(--amber-bg);color:var(--amber-txt);border-color:var(--amber-bdr)}
.outcome-hold:hover{background:#f5e2c0}
.outcome-reinterview{background:var(--blue-bg);color:var(--blue-txt);border-color:var(--blue-txt)}
.outcome-reinterview:hover{background:#cde3f5}
.outcome-reapply{background:var(--gray-bg);color:var(--gray-txt);border-color:rgba(0,0,0,.12)}
.outcome-reapply:hover{background:#e6e4dc}

/* Modal overlay */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-head{padding:16px 20px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:600;color:var(--navy)}
.modal-close{font-size:20px;color:var(--slate-lite);cursor:pointer;line-height:1;border:none;background:none;padding:0}
.modal-close:hover{color:var(--navy)}
.modal-body{padding:20px}
.modal-foot{padding:14px 20px;border-top:0.5px solid var(--border);display:flex;gap:8px;justify-content:flex-end}

/* ── AUTH PAGES ─────────────────────────────────────────────── */
body.auth-page{background:var(--navy);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}
.login-box{background:#fff;border-radius:var(--radius-xl);padding:2.5rem 2rem;width:100%;max-width:380px;border:0.5px solid var(--border);box-shadow:var(--shadow-lg)}
.brand{text-align:center;margin-bottom:2rem}
.brand-logo{font-size:22px;font-weight:700;color:var(--navy);letter-spacing:.01em;margin-bottom:4px}
.brand-logo span{color:var(--gold)}
.brand-sub{font-size:12px;color:var(--slate-lite);line-height:1.4}
.login-box h1{font-size:16px;font-weight:500;color:var(--navy);margin-bottom:1.5rem;text-align:center}
.auth-error{background:var(--red-bg);border-left:3px solid var(--red-bdr);border-radius:0 var(--radius) var(--radius) 0;padding:9px 12px;font-size:12px;color:var(--red-txt);margin-bottom:1rem;line-height:1.4}
.field{margin-bottom:1rem}
.field label{display:block;font-size:12px;font-weight:500;color:var(--slate);margin-bottom:5px}
.field input[type=text],.field input[type=email],.field input[type=password]{width:100%;height:42px;padding:0 12px;border:0.5px solid rgba(0,0,0,0.15);border-radius:var(--radius);font-size:14px;color:var(--navy);background:#fff;outline:none;transition:border-color .15s;font-family:inherit}
.field input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(11,31,58,0.08)}
.btn-submit{width:100%;height:44px;background:var(--navy);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:opacity .15s,transform .1s;margin-top:.25rem}
.btn-submit:hover{opacity:.9}
.btn-submit:active{transform:scale(.98)}

/* ── APPLICANT PORTAL (Premium) ──────────────────────────────── */
body.portal-page{
  background:#f4f2ed;
  min-height:100vh;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* Hero header */
.portal-hero{
  background:linear-gradient(135deg, #0B1F3A 0%, #1A3660 60%, #0d2a4a 100%);
  padding:48px 24px 36px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.portal-hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9A84C' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.portal-hero-inner{position:relative;max-width:760px;margin:0 auto}
.portal-badge{
  display:inline-block;
  background:rgba(201,168,76,.15);
  border:1px solid rgba(201,168,76,.3);
  color:var(--gold);
  font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 14px;border-radius:20px;margin-bottom:20px;
}
.portal-hero h1{
  font-size:clamp(24px,4vw,38px);font-weight:700;
  color:#fff;margin-bottom:10px;line-height:1.2;
}
.portal-hero h1 em{color:var(--gold);font-style:normal}
.portal-hero p{font-size:15px;color:rgba(255,255,255,.65);max-width:560px;margin:0 auto 24px;line-height:1.6}
.portal-steps{
  display:flex;gap:8px;justify-content:center;flex-wrap:wrap;
}
.portal-step{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.08);
  padding:8px 14px;border-radius:20px;
  font-size:12px;color:rgba(255,255,255,.75);
}
.portal-step-num{
  width:20px;height:20px;border-radius:50%;
  background:var(--gold);color:var(--navy);
  font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}

/* Form container */
.portal-form-wrap{
  max-width:820px;margin:0 auto;
  padding:32px 20px 60px;
}

/* Section card */
.form-section{
  background:#fff;
  border:0.5px solid rgba(0,0,0,.09);
  border-radius:var(--radius-xl);
  margin-bottom:20px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.05);
}
.form-section-head{
  padding:16px 24px;
  background:linear-gradient(90deg,#0B1F3A,#1A3660);
  display:flex;align-items:center;gap:12px;
}
.form-section-icon{font-size:18px}
.form-section-title{font-size:14px;font-weight:600;color:#fff}
.form-section-sub{font-size:11px;color:rgba(255,255,255,.5);margin-top:1px}
.form-section-body{padding:24px}

/* Form fields (portal) */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.form-grid.cols-1{grid-template-columns:1fr}
.form-grid.cols-3{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.form-group{display:flex;flex-direction:column}
.form-group.span-2{grid-column:span 2}
.form-label{
  font-size:12px;font-weight:500;color:var(--slate);
  margin-bottom:6px;display:flex;align-items:center;gap:4px;
}
.form-label .req{color:#e53e3e;font-size:11px}
.form-control{
  height:44px;padding:0 14px;
  border:1px solid rgba(0,0,0,.12);border-radius:8px;
  font-size:14px;color:var(--navy);background:#fff;outline:none;
  font-family:inherit;transition:border-color .15s,box-shadow .15s;
  width:100%;
}
.form-control:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(11,31,58,.08)}
.form-control.has-error{border-color:#e53e3e;box-shadow:0 0 0 3px rgba(229,62,62,.08)}
select.form-control{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%234A5568' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;appearance:none}
textarea.form-control{height:auto;min-height:90px;padding:12px 14px;resize:vertical;line-height:1.5}
.form-hint{font-size:11px;color:var(--slate-lite);margin-top:4px;line-height:1.4}
.field-error{font-size:11px;color:#e53e3e;margin-top:4px}

/* Photo upload */
.photo-upload-area{
  border:2px dashed rgba(11,31,58,.15);border-radius:10px;
  padding:20px;text-align:center;background:var(--cream);
  cursor:pointer;transition:all .15s;
}
.photo-upload-area:hover{border-color:var(--navy);background:rgba(11,31,58,.03)}
.photo-preview{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--gold);margin:0 auto 10px;display:block}
.photo-placeholder{width:80px;height:80px;border-radius:50%;background:var(--cream-dark);margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:28px}
.photo-upload-area p{font-size:13px;color:var(--slate);margin-bottom:4px}
.photo-upload-area span{font-size:11px;color:var(--slate-lite)}

/* Slot picker */
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.slot-card{
  border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:12px;
  cursor:pointer;transition:all .15s;text-align:center;
  background:#fff;position:relative;
}
.slot-card:hover{border-color:var(--navy);background:rgba(11,31,58,.03)}
.slot-card.selected{border-color:var(--gold);background:rgba(201,168,76,.06);box-shadow:0 0 0 2px var(--gold)}
.slot-card.soft-reserved{border-color:var(--amber-bdr);background:var(--amber-bg)}
.slot-card-date{font-size:11px;font-weight:600;color:var(--slate-lite);text-transform:uppercase;letter-spacing:.06em}
.slot-card-time{font-size:15px;font-weight:600;color:var(--navy);margin:4px 0}
.slot-selected-badge{position:absolute;top:6px;right:6px;background:var(--gold);color:var(--navy);font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px}

/* Payment section */
.payment-box{
  background:linear-gradient(135deg,#0B1F3A,#1A3660);
  border-radius:10px;padding:24px;margin-top:8px;
  text-align:center;
}
.payment-amount{font-size:40px;font-weight:700;color:#fff;line-height:1}
.payment-amount span{font-size:20px;font-weight:400;color:rgba(255,255,255,.6);vertical-align:top;line-height:2.2}
.payment-label{font-size:12px;color:rgba(255,255,255,.5);margin-top:4px;margin-bottom:20px}
.pay-btn{
  display:inline-block;background:var(--gold);color:var(--navy);
  font-size:15px;font-weight:700;
  padding:13px 36px;border-radius:8px;border:none;cursor:pointer;
  font-family:inherit;transition:all .15s;text-decoration:none;
}
.pay-btn:hover{background:var(--gold-lite);transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,168,76,.3)}

/* Submit bar */
.submit-bar{
  background:#fff;
  border-top:1px solid rgba(0,0,0,.09);
  padding:20px 24px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
  border-radius:0 0 var(--radius-xl) var(--radius-xl);
}
.submit-bar-left{font-size:12px;color:var(--slate-lite);line-height:1.5}
.submit-main-btn{
  background:var(--navy);color:#fff;
  font-size:14px;font-weight:600;
  padding:12px 32px;border-radius:8px;border:none;cursor:pointer;
  font-family:inherit;transition:all .15s;
}
.submit-main-btn:hover{background:var(--navy-lite);transform:translateY(-1px);box-shadow:0 4px 12px rgba(11,31,58,.25)}
.submit-main-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Applicant nav */
.portal-nav{
  background:var(--navy);
  border-bottom:1px solid rgba(201,168,76,.2);
  padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:56px;
  position:sticky;top:0;z-index:50;
}
.portal-nav-logo{font-size:16px;font-weight:700;color:#fff}
.portal-nav-logo em{color:var(--gold);font-style:normal}

/* Progress stepper */
.stepper{display:flex;align-items:center;gap:0;margin-bottom:24px;overflow-x:auto;padding-bottom:4px}
.step{display:flex;align-items:center;gap:8px;flex-shrink:0}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;border:2px solid;transition:all .2s}
.step-dot.done{background:var(--green-txt);border-color:var(--green-txt);color:#fff}
.step-dot.active{background:var(--navy);border-color:var(--navy);color:#fff}
.step-dot.pending{background:#fff;border-color:rgba(0,0,0,.15);color:var(--slate-lite)}
.step-label{font-size:12px;font-weight:500;white-space:nowrap}
.step-label.active{color:var(--navy)}
.step-label.done{color:var(--green-txt)}
.step-label.pending{color:var(--slate-lite)}
.step-line{flex:1;height:1px;background:rgba(0,0,0,.1);margin:0 8px;min-width:20px}

@media(max-width:640px){
  .page-body{padding:0 .75rem 2rem}
  .page-head{padding:1rem .75rem 0}
  .sidebar{display:none}
  .form-grid{grid-template-columns:1fr}
  .form-group.span-2{grid-column:span 1}
  .portal-hero{padding:32px 16px 24px}
  .portal-steps{gap:6px}
  .portal-step{font-size:11px;padding:6px 10px}
}
