/*
 * MCampus Career Portal — Master Design System v2.0
 * File  : Content/Static/career-portal.css
 * Stack : Bootstrap 3.4.1 | jQuery 3 | Font Awesome 4.7 | Poppins / DM Serif Display
 *
 * RULES
 *   - NEVER use Bootstrap 4/5 utility classes (d-flex, mt-*, etc.)
 *   - Use var(--cp-*) tokens for every colour, radius, shadow
 *   - All border-radius must use !important
 * ================================================================ */


/* ══════════════════════════════════════════════════════════════
   §1  DESIGN TOKENS
   ══════════════════════════════════════════════════════════════ */
:root {
    /* ── Navy (primary brand) ── */
    --cp-navy:           #0b1f3a;
    --cp-navy-mid:       #132d54;
    --cp-navy-hover:     #0d2645;
    --cp-navy-deep:      #071428;

    /* ── Gold ── */
    --cp-gold:           #c9a227;
    --cp-gold-light:     #f0c040;
    --cp-gold-bg:        #fef9eb;
    --cp-gold-border:    #f5e199;

    /* ── Teal ── */
    --cp-teal:           #0d9488;
    --cp-teal-light:     #14b8a6;
    --cp-teal-bg:        #f0fdfa;
    --cp-teal-border:    #99f6e4;

    /* ── Amber (non-teaching) ── */
    --cp-amber:          #d97706;
    --cp-amber-bg:       #fffbeb;
    --cp-amber-border:   #fde68a;

    /* ── Blue (role pill) ── */
    --cp-blue-bg:        #eff6ff;
    --cp-blue-text:      #1d4ed8;
    --cp-blue-border:    #bfdbfe;

    /* ── Kept for backward-compat ── */
    --cp-primary:        #1e4fa3;
    --cp-primary-dark:   #163a7a;
    --cp-primary-light:  #2b6cb0;
    --cp-accent:         #2563eb;
    --cp-bg:             #f5f7fb;
    --cp-surface:        #ffffff;
    --cp-text:           #1f2937;
    --cp-text-muted:     #6b7280;
    --cp-text-light:     #4b5563;
    --cp-border:         #e5e7eb;
    --cp-dark:           #0b1f3a;
    --cp-dark-footer:    #071428;
    --cp-success:        #16a34a;
    --cp-info-bg:        #eef4ff;
    --cp-info-border:    #c3d6f9;
    --cp-radius-sm:      4px;
    --cp-radius:         10px;
    --cp-radius-lg:      18px;
    --cp-radius-pill:    30px;
    --cp-shadow:         0 4px 20px rgba(0,0,0,.06);
    --cp-shadow-lg:      0 10px 30px rgba(0,0,0,.10);
    --cp-transition:     .2s ease;
    --cp-card-radius:    12px;
    --cp-card-shadow:    0 1px 3px rgba(11,31,58,.07), 0 8px 24px rgba(11,31,58,.05);
}


/* ══════════════════════════════════════════════════════════════
   §2  BASE RESET
   ══════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: "Poppins", sans-serif !important;
    background: var(--cp-bg);
    color: var(--cp-text);
}

a { text-decoration: none; color: inherit; }

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: "Poppins", sans-serif !important;
}
/* ══════════════════════════════════════════════════════════════
   §3  NAVBAR
   ══════════════════════════════════════════════════════════════ */
.navbar-career {
    background: var(--cp-navy);
    border: none;
    border-radius: 0 !important;
    margin-bottom: 0;
    min-height: 64px;
    box-shadow: 0 2px 12px rgba(7,20,40,.35);
    /* sticky */
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1030;
    width: 100%;
}

/* Push page content below the fixed navbar */
.wrapper { padding-top: 64px; }

.navbar-career .container-fluid { padding-left: 28px; padding-right: 28px; }

/* ── Brand ── */
.navbar-career .navbar-brand {
    padding: 12px 0;
    height: auto;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 10px;
    margin-right: 24px;
}

/* Gold letter mark (shown when no logo image) */
.cp-brand-mark {
    width: 38px;
    height: 38px;
    background: var(--cp-gold);
    border-radius: 8px !important;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cp-navy);
    font-weight: 800;
    font-size: 18px;
    flex-shrink: 0;
    line-height: 1;
    font-family: "DM Serif Display", "Poppins", serif;
}

/* Actual logo image (shown when logo exists) */
.cp-brand-logo {
    max-height: 40px;
    width: auto;
    display: block;
    flex-shrink: 0;
}

.cp-brand-text {
    display: -webkit-flex;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.cp-brand-name {
    color: #fff;
    font-weight: 700;
    font-size: 15px;
    line-height: 1.2;
    white-space: nowrap;
}

.cp-brand-sub {
    color: var(--cp-gold);
    font-size: 10.5px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: .04em;
    white-space: nowrap;
}

/* ── Nav links ── */
.navbar-career .navbar-nav > li > a {
    color: rgba(255,255,255,.82) !important;
    font-weight: 500;
    font-size: 14px;
    padding: 22px 16px;
    transition: color var(--cp-transition), background-color var(--cp-transition);
}

.navbar-career .navbar-nav > li > a:hover,
.navbar-career .navbar-nav > li > a:focus {
    color: #fff !important;
    background-color: rgba(255,255,255,.08);
}

.navbar-career .navbar-nav > li.active > a {
    color: #fff !important;
    background-color: rgba(255,255,255,.12);
}

.navbar-career .navbar-nav > li > a.nav-username {
    font-weight: 600;
    cursor: default;
}
.navbar-career .navbar-nav > li > a.nav-username:hover {
    background-color: transparent;
}

/* ── Login/Register CTA button ── */
.navbar-career .navbar-nav > li.cp-nav-cta-li > a {
    background: var(--cp-gold) !important;
    color: var(--cp-navy) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    padding: 8px 20px !important;
    border-radius: 20px !important;
    margin: 13px 6px !important;
    line-height: 1.4;
    display: inline-block !important;
    transition: background var(--cp-transition), transform var(--cp-transition) !important;
}
.navbar-career .navbar-nav > li.cp-nav-cta-li > a:hover {
    background: var(--cp-gold-light) !important;
    transform: translateY(-1px);
}

/* ── Hamburger ── */
.navbar-career .navbar-toggle {
    border-color: rgba(255,255,255,.3);
    margin-top: 15px;
    margin-bottom: 15px;
    border-radius: 6px !important;
}
.navbar-career .navbar-toggle .icon-bar { background-color: #fff; }
.navbar-career .navbar-toggle:hover,
.navbar-career .navbar-toggle:focus { background-color: rgba(255,255,255,.12); }

@media (max-width: 767px) {
    .navbar-career .navbar-collapse {
        background: var(--cp-navy-mid);
        border-top: 1px solid rgba(255,255,255,.1);
    }
    .navbar-career .navbar-nav > li > a  { padding: 12px 20px; }
    .navbar-career .navbar-nav > li.cp-nav-cta-li > a {
        margin: 8px 20px !important;
        display: block !important;
        text-align: center;
        border-radius: 8px !important;
    }
    .navbar-career .container-fluid { padding-left: 16px; padding-right: 16px; }
    .navbar-career .navbar-brand { gap: 8px; }
    .cp-brand-name { font-size: 14px; }
}


/* ══════════════════════════════════════════════════════════════
   §4  HERO SECTION
   ══════════════════════════════════════════════════════════════ */
.cp-hero {
    background: linear-gradient(135deg, #0b1f3a 0%, #132d54 55%, #0d2645 100%);
    padding: 48px 40px 42px;
    position: relative;
    overflow: hidden;
}

/* Decorative glow orbs */
.cp-hero::before {
    content: '';
    position: absolute;
    width: 480px;
    height: 480px;
    background: radial-gradient(circle, rgba(201,162,39,.18) 0%, transparent 68%);
    right: -80px;
    top: -120px;
    border-radius: 50% !important;
    pointer-events: none;
}

.cp-hero::after {
    content: '';
    position: absolute;
    width: 260px;
    height: 260px;
    background: radial-gradient(circle, rgba(13,148,136,.14) 0%, transparent 70%);
    left: 55%;
    bottom: -60px;
    border-radius: 50% !important;
    pointer-events: none;
}

.cp-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 680px;
}

/* "NOW HIRING" badge */
.cp-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: transparent;
    border: 1.5px solid var(--cp-gold);
    color: var(--cp-gold);
    font-size: 11.5px;
    font-weight: 700;
    padding: 5px 14px;
    border-radius: 20px !important;
    margin-bottom: 18px;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.cp-hero-badge .fa { font-size: 11px; }

/* Headline */
.cp-hero-title {
    font-family: 'DM Serif Display', 'Georgia', serif;
    font-size: 38px;
    font-weight: 400;
    color: #fff;
    line-height: 1.18;
    margin: 0 0 14px;
}

.cp-hero-title em {
    font-style: italic;
    color: var(--cp-gold);
}

/* Description */
.cp-hero-desc {
    color: rgba(255,255,255,.68);
    font-size: 14.5px;
    line-height: 1.72;
    max-width: 500px;
    margin-bottom: 24px;
}

/* Feature pills */
.cp-hero-pills {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cp-hero-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 1px solid rgba(255,255,255,.22);
    color: rgba(255,255,255,.82);
    background: rgba(255,255,255,.06);
    font-size: 13px;
    font-weight: 500;
    padding: 7px 16px;
    border-radius: 20px !important;
    transition: border-color var(--cp-transition), background var(--cp-transition);
}

.cp-hero-pill .fa { font-size: 12px; opacity: .8; }
.cp-hero-pill:hover { border-color: rgba(255,255,255,.45); background: rgba(255,255,255,.1); }

/* Legacy info strip — hidden in v2 */
.cp-info-strip { display: none; }

@media (max-width: 767px) {
    .cp-hero { padding: 32px 20px 30px; }
    .cp-hero-title { font-size: 26px; }
    .cp-hero-desc { font-size: 13.5px; }
    .cp-hero::before { display: none; }
}


/* ══════════════════════════════════════════════════════════════
   §5  WRAPPER & LAYOUT SHELL
   ══════════════════════════════════════════════════════════════ */
.wrapper { min-height: 100vh; display: -webkit-flex; display: flex; flex-direction: column; }
.site-content { flex: 1; }


/* ══════════════════════════════════════════════════════════════
   §6  FOOTER
   ══════════════════════════════════════════════════════════════ */
.footer-career {
    background-color: var(--cp-navy);
    color: #fff;
    padding-top: 48px;
    border-top: 3px solid var(--cp-gold);
    margin-top: auto;
}

.footer-career .footer-logo { margin-bottom: 14px; }
.footer-career .footer-logo img { max-height: 50px; width: auto; opacity: .9; }

/* Gold square letter mark (footer) */
.cp-footer-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: var(--cp-gold);
    border-radius: 10px !important;
    color: var(--cp-navy);
    font-weight: 800;
    font-size: 20px;
    font-family: "DM Serif Display", serif;
    margin-bottom: 12px;
}

.footer-career .footer-tagline {
    font-size: 13.5px;
    color: rgba(255,255,255,.58);
    line-height: 1.7;
    margin-top: 8px;
}

.footer-career h4 {
    color: var(--cp-gold-light);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .09em;
    margin-bottom: 18px;
    padding-bottom: 9px;
    border-bottom: 1px solid rgba(255,255,255,.1);
}

.footer-career ul { list-style: none; padding: 0; margin: 0; }
.footer-career ul li { margin-bottom: 10px; }

.footer-career ul li a {
    color: rgba(255,255,255,.68);
    font-size: 13.5px;
    transition: color var(--cp-transition);
}
.footer-career ul li a:hover { color: #fff; }
.footer-career ul li a .fa {
    margin-right: 8px;
    width: 14px;
    text-align: center;
    color: rgba(255,255,255,.4);
}

.footer-career .footer-contact-text {
    font-size: 13.5px;
    color: rgba(255,255,255,.68);
    line-height: 1.9;
}
.footer-career .footer-contact-text strong {
    color: #fff;
    display: block;
    margin-bottom: 8px;
    font-size: 14px;
}

/* Gold icons in About Us */
.footer-career .footer-contact-text .fa {
    margin-right: 8px;
    color: var(--cp-gold);
    width: 14px;
    text-align: center;
    opacity: 1;
}

.footer-bottom {
    background-color: var(--cp-navy-deep);
    margin-top: 36px;
    padding: 14px 0;
    font-size: 12.5px;
    color: rgba(255,255,255,.45);
    text-align: center;
}
.footer-bottom a { color: rgba(255,255,255,.72); }
.footer-bottom a:hover { color: #fff; text-decoration: underline; }
.footer-bottom strong { color: rgba(255,255,255,.85); }

@media (max-width: 767px) {
    .footer-career [class*="col-"] { margin-bottom: 30px; }
    .footer-career { padding-top: 32px; }
}


/* ══════════════════════════════════════════════════════════════
   §7  LEGACY FILTER CHIPS
   ══════════════════════════════════════════════════════════════ */
.filters {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 20px;
    padding: 20px 25px;
}
.school-name { font-size: 18px; font-weight: 600; color: var(--cp-primary-dark); white-space: nowrap; }
.filter-list  { display: flex; gap: 12px; flex-wrap: wrap; }

.filter-chip {
    display: flex; align-items: center; gap: 6px;
    padding: 10px 18px;
    border-radius: var(--cp-radius-pill) !important;
    background: var(--cp-surface);
    border: 1px solid var(--cp-border) !important;
    cursor: pointer; font-size: 14px; font-weight: 500;
    transition: all var(--cp-transition);
}
.filter-chip .count    { font-weight: 600; color: var(--cp-accent); }
.filter-chip.active    { background: #cfe2ff !important; border-color: #9ec5fe !important; color: #052c65 !important; }


/* ══════════════════════════════════════════════════════════════
   §8-11  OLD HERO / CONTENT / WHY-TEACHERS (legacy, kept as-is)
   ══════════════════════════════════════════════════════════════ */
.hero {
    background: linear-gradient(180deg, #ffffff, #eef2fb);
    padding: 0 60px;
    display: grid; grid-template-columns: 50% 50%;
    align-items: center; gap: 40px;
}
.hero h1 { font-size: 44px; font-weight: 700; color: var(--cp-primary-dark); }
.hero h1 span { display: block; margin-top: 6px; }
.hero p { margin-top: 20px; font-size: 16px; line-height: 1.7; color: var(--cp-text-light); max-width: 520px; }
.hero button { margin-top: 28px; padding: 14px 26px; font-size: 15px; border-radius: var(--cp-radius) !important; border: none; background: var(--cp-accent); color: #fff; cursor: pointer; font-weight: 600; }
.hero img { width: 100%; max-width: 250mm; justify-self: end; }

.content { padding: 30px 60px 0; }
.content h2 { font-size: 26px; margin-bottom: 14px; color: var(--cp-primary-dark); }
.content p  { color: var(--cp-text-light); line-height: 1.7; }
.content .content { padding: 0; }

.job-desc    { margin: 18px 0; color: var(--cp-text-light); line-height: 1.6; }
.job-points li { margin-bottom: 8px; list-style: none; padding-left: 22px; position: relative; }
.job-points li::before { content: "✓"; position: absolute; left: 0; color: var(--cp-success); font-weight: 700; }
.job-actions { margin-top: 24px; display: flex; gap: 14px; }
.btn-outline  { padding: 12px 20px; border-radius: var(--cp-radius) !important; border: 1px solid var(--cp-accent); background: var(--cp-surface); color: var(--cp-accent); font-weight: 600; cursor: pointer; }

.why-teachers { padding: 40px 60px; background: #eef2fb; }
.why-card { background: linear-gradient(180deg, #ffffff, #f3f6fd); border-radius: var(--cp-radius-lg) !important; padding: 5px 40px; display: grid; grid-template-columns: 70% 30%; align-items: center; box-shadow: var(--cp-shadow-lg); gap: 30px; }
.why-content h3 { font-size: 22px; font-weight: 600; color: var(--cp-primary-dark); margin-bottom: 18px; }
.quote { position: relative; padding-left: 34px; }
.quote p { font-size: 16px; line-height: 1.7; color: #374151; }
.quote-icon { position: absolute; font-size: 48px; color: #93c5fd; font-weight: 700; }
.quote-icon.left  { left: 0;   top: -10px; }
.quote-icon.right { right: -10px; bottom: -30px; }
.quote-author { margin-top: 18px; font-size: 14px; color: var(--cp-text-muted); }
.why-image { text-align: right; }
.why-image img { max-width: 200mm; width: 100%; }


/* ══════════════════════════════════════════════════════════════
   §12  JQUERY UI OVERRIDES
   ══════════════════════════════════════════════════════════════ */
.ui-widget { font-size: 13px; }
.ui-widget-header  { border: none !important; background: none !important; color: #222; font-weight: 700; }
.ui-widget-content { border: none !important; background: none !important; color: #362b36; }
.ui-state-error    { background: none; color: red; border: 0; }
.ui-dialog         { z-index: 5001 !important; }
.ui-autocomplete.ui-widget-content  { z-index: 9999; background: #f2f5f7 !important; border: 1px solid #f2f5f7 !important; }
.ui-datepicker.ui-widget-content    { border: 1px solid #ddd !important; background: #f2f5f7 !important; color: #362b36 !important; }
.ui-timepicker-table.ui-widget-content { border: 1px solid #ddd !important; background: #f2f5f7 !important; color: #362b36 !important; }
.McampusHelpPopUp.ui-widget-content { background: #fff !important; border-color: #c2c2c2 !important; }


/* ══════════════════════════════════════════════════════════════
   §13  FILE-UPLOAD OVERRIDES
   ══════════════════════════════════════════════════════════════ */
.fileupload-buttonbar  { padding: 0 !important; margin-top: 0; width: 100% !important; }
.fileinput-button      { width: 100%; }
.files                 { margin: 0 !important; width: 100%; }
.fileupload-content    { padding: 0 !important; }
.uploadfile .form-group label { padding: 0 !important; background: none !important; color: black; }
.fileinput-button span { display: none !important; }
.fileinput-button input[type=file] {
    padding: 10px; height: 50px;
    background-color: #f5f5f5;
    border: 1px dashed #8f8e8e;
    border-radius: var(--cp-radius) !important;
    width: 100%;
}
.fileinput-button input[type="file"]::-webkit-file-upload-button,
.fileinput-button input[type="file"]::file-selector-button {
    background: #3c8dbc; border: 1px solid #3c8dbc;
    padding: 6px 12px; border-radius: 20px !important;
    cursor: pointer; color: white;
}


/* ══════════════════════════════════════════════════════════════
   §14  AUTOCOMPLETE
   ══════════════════════════════════════════════════════════════ */
.mcampusautocomplete               { width: 100%; }
.ui-autocomplete-multiselect-item { min-height: 32px; padding: 5px; }
.ui-combobox-input.ui-autocomplete-input { width: 100%; }
.ui-combobox-input                 { background: white; color: #555; }
.ui-autocomplete-multiselect       { background: white; color: black; min-width: 135px; }
.jsautocomplete-wrapper-Message input {
    background: white; border-color: #D2D6DE;
    border-radius: 0; width: 100%; color: white; margin: 3px 0;
}


/* ══════════════════════════════════════════════════════════════
   §15  BACKWARD-COMPAT UTILITIES
   ══════════════════════════════════════════════════════════════ */
.textColor       { color: white !important; font-size: 20px; }
.textColor:hover { color: black !important; }
.bodyBg {
    background-image: linear-gradient(120deg, #FF4081, #81D4FA);
    background-repeat: round; background-size: cover; height: 100%;
}


/* ══════════════════════════════════════════════════════════════
   §16  GLOBAL RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .hero { grid-template-columns: 1fr; text-align: center; }
    .hero img { justify-self: center; }
    .hero, .filters, .content { padding-left: 20px; padding-right: 20px; }
}
@media (max-width: 768px) {
    .why-teachers { padding: 40px 20px; }
    .why-card     { grid-template-columns: 1fr; text-align: center; }
    .why-image    { text-align: center; }
    .quote        { padding-left: 0; }
    .quote-icon.left { left: -10px; }
}


/* ══════════════════════════════════════════════════════════════
   §17  PAGE HEADER (legacy — hidden behind hero in v2)
   ══════════════════════════════════════════════════════════════ */
.cp-page-header { display: none; }
.cp-landing-wrapper { padding: 0; }


/* ══════════════════════════════════════════════════════════════
   §18  FILTER BAR
   ══════════════════════════════════════════════════════════════ */
.cp-filter-bar {
    background: var(--cp-surface);
    border-bottom: 1px solid var(--cp-border);
    box-shadow: 0 2px 10px rgba(11,31,58,.06);
    padding: 18px 28px 16px;
}

.cp-filter-row {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: nowrap;
}

.cp-filter-sep {
    border: none;
    border-top: 1px solid var(--cp-border);
    margin: 13px 0;
}

/* Label */
.cp-filter-label {
    min-width: 72px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--cp-text-muted);
    flex-shrink: 0;
    padding-top: 1px;
}

.cp-filter-chips {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    flex: 1;
}

.cp-section-group { display: -webkit-flex; display: flex; flex-wrap: wrap; gap: 8px; width: 100%; }

/* Search input (right side of section row) */
.cp-filter-search-wrap {
    margin-left: auto;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    border: 1.5px solid var(--cp-border);
    border-radius: var(--cp-radius-pill) !important;
    padding: 6px 16px;
    gap: 8px;
    min-width: 256px;
    max-width: 340px;
    background: var(--cp-bg);
    transition: border-color var(--cp-transition), background var(--cp-transition);
    flex-shrink: 0;
}
.cp-filter-search-wrap:focus-within {
    border-color: var(--cp-primary-light);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(43,108,176,.1);
}
.cp-filter-search-wrap .fa {
    color: var(--cp-text-muted);
    font-size: 13px;
    flex-shrink: 0;
}
.cp-search-input {
    border: none;
    background: transparent;
    outline: none;
    font-family: inherit;
    font-size: 13px;
    color: var(--cp-text);
    width: 100%;
    min-width: 0;
}
.cp-search-input::placeholder { color: var(--cp-text-muted); }

/* Pill button (base) */
.cp-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 16px;
    border-radius: var(--cp-radius-pill) !important;
    background: var(--cp-bg);
    border: 1.5px solid var(--cp-border);
    font-size: 13px;
    font-weight: 500;
    color: var(--cp-text);
    cursor: pointer;
    transition: all var(--cp-transition);
    outline: none;
    white-space: nowrap;
    line-height: 1.4;
    font-family: inherit;
}
.cp-filter-btn .fa { font-size: 12px; }
.cp-filter-btn:hover {
    border-color: var(--cp-primary-light);
    color: var(--cp-primary);
    background: var(--cp-info-bg);
}

/* ── School active → navy ── */
.cp-filter-btn.cp-filter-active,
.school-btn.cp-filter-active {
    background: var(--cp-navy);
    border-color: var(--cp-navy);
    color: #fff;
    font-weight: 600;
    box-shadow: 0 3px 10px rgba(11,31,58,.25);
}
.school-btn.cp-filter-active:hover {
    background: var(--cp-navy-hover);
    border-color: var(--cp-navy-hover);
}

/* ── Section active → teal ── */
.section-btn.cp-filter-active {
    background: var(--cp-teal) !important;
    border-color: var(--cp-teal) !important;
    color: #fff !important;
    font-weight: 600;
    box-shadow: 0 3px 10px rgba(13,148,136,.25) !important;
}
.section-btn.cp-filter-active:hover {
    background: var(--cp-teal-light) !important;
    border-color: var(--cp-teal-light) !important;
}

@media (max-width: 767px) {
    .cp-filter-bar { padding: 14px 16px 12px; }
    .cp-filter-row { flex-wrap: wrap; }
    .cp-filter-search-wrap { min-width: 100%; max-width: 100%; margin-left: 0; margin-top: 10px; }
    .cp-filter-btn { font-size: 12px; padding: 6px 12px; }
}


/* ══════════════════════════════════════════════════════════════
   §18b  RESULTS META ROW
   ══════════════════════════════════════════════════════════════ */
.cp-results-meta-row {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 22px 28px 14px;
    flex-wrap: wrap;
    gap: 12px;
    background: var(--cp-bg);
}

.cp-results-meta-left {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.cp-results-dot {
    width: 9px;
    height: 9px;
    background: var(--cp-gold);
    border-radius: 50% !important;
    flex-shrink: 0;
}

.cp-results-section-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--cp-text-muted);
}

.cp-results-heading {
    font-family: 'DM Serif Display', 'Georgia', serif;
    font-size: 22px;
    font-weight: 400;
    color: var(--cp-navy);
    margin: 0;
    line-height: 1;
}

.cp-results-count-badge {
    background: var(--cp-navy);
    color: #fff;
    font-size: 11.5px;
    font-weight: 600;
    padding: 3px 13px;
    border-radius: var(--cp-radius-pill) !important;
    white-space: nowrap;
}

.cp-sort-select {
    border: 1.5px solid var(--cp-border);
    border-radius: var(--cp-radius) !important;
    padding: 7px 12px;
    font-size: 13px;
    font-weight: 500;
    color: var(--cp-text);
    background: var(--cp-surface);
    outline: none;
    font-family: inherit;
    cursor: pointer;
    transition: border-color var(--cp-transition);
    -webkit-appearance: auto;
}
.cp-sort-select:focus { border-color: var(--cp-primary-light); }

@media (max-width: 767px) {
    .cp-results-meta-row { padding: 16px 16px 10px; }
    .cp-results-heading  { font-size: 18px; }
}


/* ══════════════════════════════════════════════════════════════
   §19  JOBS CONTENT AREA
   ══════════════════════════════════════════════════════════════ */
.cp-jobs-area {
    padding: 0 28px 32px;
    min-height: 380px;
    background: var(--cp-bg);
}

/* No-jobs empty state */
.cp-no-jobs { text-align: center; padding: 70px 20px; color: var(--cp-text-muted); }
.cp-no-jobs .fa { font-size: 52px; color: #dce2ef; display: block; margin-bottom: 16px; }
.cp-no-jobs p   { font-size: 15px; font-weight: 500; }

/* Legacy panel header (hidden in v2) */
.cp-section-panel-header { display: none; }

@media (max-width: 767px) { .cp-jobs-area { padding: 0 14px 24px; } }


/* ══════════════════════════════════════════════════════════════
   §20  JOB CARDS
   ══════════════════════════════════════════════════════════════ */
#cpJobCardsList { display: flex; flex-direction: column; gap: 16px; }

.cp-job-card {
    background: var(--cp-surface);
    border-radius: var(--cp-card-radius) !important;
    border: 1px solid #e3e8f0;
    border-left: 4px solid var(--cp-navy) !important;
    box-shadow: var(--cp-card-shadow);
    overflow: hidden;
    transition: box-shadow var(--cp-transition),
                border-left-color var(--cp-transition),
                transform var(--cp-transition);
}

.cp-job-card:hover {
    box-shadow: 0 4px 16px rgba(11,31,58,.1), 0 12px 36px rgba(11,31,58,.1);
    border-left-color: var(--cp-gold) !important;
    transform: translateY(-2px);
}

/* ── Card top section (title + right badge) ── */
.cp-job-card-top {
    padding: 20px 22px 16px;
    display: -webkit-flex;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.cp-job-card-body { flex: 1; min-width: 0; }

.cp-job-title {
    font-family: 'DM Serif Display', 'Georgia', serif;
    font-size: 19px;
    font-weight: 400;
    color: var(--cp-navy);
    margin: 0 0 5px;
    line-height: 1.3;
}

.cp-job-subtitle {
    font-size: 13px;
    color: var(--cp-text-muted);
    margin-bottom: 12px;
    line-height: 1.4;
}

/* Tag row */
.cp-job-tags {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cp-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 500;
    padding: 3px 10px;
    border-radius: var(--cp-radius-pill) !important;
    white-space: nowrap;
    line-height: 1.5;
}
.cp-tag .fa { font-size: 10px; }

/* Date tag — gray */
.cp-tag-date {
    background: #f1f5f9;
    color: #64748b;
    border: 1px solid #e2e8f0;
}

/* Role tag — blue */
.cp-tag-role {
    background: var(--cp-blue-bg);
    color: var(--cp-blue-text);
    border: 1px solid var(--cp-blue-border);
}

/* Section tag — teal */
.cp-tag-section {
    background: var(--cp-teal-bg);
    color: var(--cp-teal);
    border: 1px solid var(--cp-teal-border);
}

/* Teaching tag — amber */
.cp-tag-teaching {
    background: var(--cp-amber-bg);
    color: var(--cp-amber);
    border: 1px solid var(--cp-amber-border);
}

/* ── Right side: dept label + status badge ── */
.cp-job-card-right {
    display: -webkit-flex;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
    flex-shrink: 0;
    padding-top: 2px;
}

.cp-dept-label {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--cp-text-muted);
    white-space: nowrap;
}

.cp-status-badge {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 600;
    padding: 3px 11px;
    border-radius: var(--cp-radius-pill) !important;
    white-space: nowrap;
}

/* "Open" → gold */
.cp-status-open {
    background: var(--cp-gold-bg);
    color: var(--cp-gold);
    border: 1px solid var(--cp-gold-border);
}

/* "New" → teal */
.cp-status-new {
    background: var(--cp-teal-bg);
    color: var(--cp-teal);
    border: 1px solid var(--cp-teal-border);
}

/* ── Description ── */
.cp-job-description {
    padding: 14px 22px;
    font-size: 13.5px;
    color: var(--cp-text-light);
    line-height: 1.78;
    border-top: 1px solid #f0f3f8;
    border-bottom: 1px solid #f0f3f8;
    word-wrap: break-word;
}

/* ── Card footer: meta pills + action buttons ── */
.cp-job-card-footer {
    padding: 12px 22px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    background: #fafbff;
}

.cp-job-footer-meta {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
}

.cp-foot-pill {
    font-size: 12px;
    color: var(--cp-text-muted);
    font-weight: 500;
}

.cp-foot-pill + .cp-foot-pill::before {
    content: '\00b7';
    margin: 0 7px;
    color: #d1d5db;
}

.cp-job-footer-actions {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

/* ── Buttons ── */
.cp-btn-view {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 500;
    color: var(--cp-navy);
    background: var(--cp-surface);
    border: 1.5px solid var(--cp-navy);
    border-radius: 7px !important;
    cursor: pointer;
    transition: background var(--cp-transition), color var(--cp-transition);
    text-decoration: none;
    font-family: inherit;
    line-height: 1.4;
    white-space: nowrap;
}
.cp-btn-view:hover {
    background: var(--cp-navy);
    color: #fff;
    text-decoration: none;
}

.cp-btn-apply {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    background: var(--cp-navy);
    border: none;
    border-radius: 7px !important;
    cursor: pointer;
    transition: background var(--cp-transition), transform var(--cp-transition);
    box-shadow: 0 2px 8px rgba(11,31,58,.2);
    text-decoration: none;
    font-family: inherit;
    line-height: 1.4;
    white-space: nowrap;
}
.cp-btn-apply:hover {
    background: var(--cp-navy-hover);
    transform: translateY(-1px);
    color: #fff;
    text-decoration: none;
}

.cp-btn-apply.ui-state-disabled,
.cp-btn-view.ui-state-disabled {
    opacity: .45;
    pointer-events: none;
    cursor: not-allowed;
    transform: none;
}

/* Hidden by search */
.cp-filtered-out { display: none !important; }

/* Legacy badge (actively hiring) */
.cp-current-badge {
    display: inline-flex; align-items: center; gap: 5px;
    background: linear-gradient(135deg, #16a34a, #15803d);
    color: #fff; font-size: 11px; font-weight: 600;
    padding: 4px 12px; border-radius: var(--cp-radius-pill) !important;
    white-space: nowrap; flex-shrink: 0;
}

@media (max-width: 767px) {
    .cp-job-card-top     { flex-direction: column; }
    .cp-job-card-right   { flex-direction: row; align-items: center; }
    .cp-job-card-footer  { flex-direction: column; align-items: stretch; }
    .cp-job-footer-actions { justify-content: stretch; }
    .cp-btn-view, .cp-btn-apply { flex: 1; justify-content: center; }
    #cpJobCardsList { gap: 12px; }
}


/* ══════════════════════════════════════════════════════════════
   §21  PAGINATION
   ══════════════════════════════════════════════════════════════ */
.cp-pagination-wrap {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
    padding: 16px 28px 4px;
    flex-wrap: wrap;
    gap: 12px;
    background: var(--cp-bg);
}

.cp-page-info { font-size: 13px; color: var(--cp-text-muted); }
.cp-page-info strong { color: var(--cp-text); font-weight: 600; }

.cp-pagination { display: -webkit-flex; display: flex; align-items: center; gap: 5px; }

.cp-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border-radius: var(--cp-radius-sm) !important;
    border: 1.5px solid var(--cp-border);
    background: var(--cp-surface);
    color: var(--cp-text);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--cp-transition);
    outline: none;
    font-family: inherit;
}
.cp-page-btn:hover:not(:disabled):not(.cp-page-active) {
    border-color: var(--cp-navy);
    color: var(--cp-navy);
    background: var(--cp-info-bg);
}
.cp-page-btn.cp-page-active {
    background: var(--cp-navy);
    border-color: var(--cp-navy);
    color: #fff;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(11,31,58,.25);
}
.cp-page-btn:disabled { opacity: .32; cursor: default; }

@media (max-width: 767px) {
    .cp-pagination-wrap { justify-content: center; padding: 14px 16px; }
}


/* ══════════════════════════════════════════════════════════════
   §24  APPLICATION WIZARD  (multi-step job application)
   ══════════════════════════════════════════════════════════════ */

/* ── Neutralise AdminLTE .box inside wizard ── */
.cp-app-wizard.box,
.cp-app-wizard .box {
    border-top: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    margin-bottom: 0 !important;
    background: transparent !important;
}

/* ── Page wrapper ── */
.cp-app-wizard {
    background: var(--cp-bg);
    min-height: calc(100vh - 64px);
    padding-bottom: 40px;
}

/* ── Job context bar ── */
.cp-app-context-bar {
    background: var(--cp-navy);
    padding: 14px 32px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
.cp-app-context-inner {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    width: 100%;
}

.cp-app-context-icon {
    width: 36px;
    height: 36px;
    background: rgba(201,162,39,.2);
    border-radius: 8px !important;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cp-gold);
    font-size: 15px;
    flex-shrink: 0;
}

.cp-app-context-text { flex: 1; min-width: 0; }
.cp-app-context-label {
    font-size: 10.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: rgba(255,255,255,.55);
    margin-bottom: 2px;
}
.cp-app-context-title {
    font-family: 'DM Serif Display', serif;
    font-size: 17px;
    font-weight: 400;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cp-app-context-chips {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.cp-app-context-chip {
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.78);
    font-size: 11.5px;
    font-weight: 500;
    padding: 4px 11px;
    border-radius: 20px !important;
    white-space: nowrap;
}

/* ── Steps strip ── */
.cp-steps-strip {
    background: var(--cp-surface);
    border-bottom: 1px solid var(--cp-border);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.cp-steps-strip::-webkit-scrollbar { display: none; }

/* Neutralise nav-tabs-custom + nav-tabs inside strip */
.cp-steps-strip.nav-tabs-custom { box-shadow: none !important; background: transparent !important; }
.cp-steps-strip .nav-tabs-custom { box-shadow: none !important; }
.cp-steps-strip .nav-tabs,
.cp-steps-strip ul.nav-tabs {
    border-bottom: none !important;
    background: transparent !important;
    white-space: nowrap;
    display: -webkit-flex;
    display: flex;
    flex-wrap: nowrap;
    margin: 0 !important;
    padding: 0 24px;
}

.cp-steps-strip .nav-tabs > li,
.cp-steps-strip ul.nav-tabs > li {
    float: none !important;
    display: inline-flex !important;
    margin: 0 !important;
}

.cp-steps-strip .nav-tabs > li > a,
.cp-steps-strip ul.nav-tabs > li > a {
    display: -webkit-flex !important;
    display: flex !important;
    align-items: center;
    gap: 8px;
    padding: 14px 18px !important;
    font-size: 13px;
    font-weight: 500;
    color: var(--cp-text-muted) !important;
    background: transparent !important;
    border: none !important;
    border-bottom: 3px solid transparent !important;
    border-radius: 0 !important;
    margin: 0 !important;
    white-space: nowrap;
    transition: color var(--cp-transition), border-color var(--cp-transition) !important;
}

.cp-steps-strip .nav-tabs > li > a:hover,
.cp-steps-strip ul.nav-tabs > li > a:hover {
    color: var(--cp-navy) !important;
    background: transparent !important;
    border-bottom-color: rgba(11,31,58,.15) !important;
}

.cp-steps-strip .nav-tabs > li.active > a,
.cp-steps-strip ul.nav-tabs > li.active > a {
    color: var(--cp-navy) !important;
    background: transparent !important;
    border-bottom-color: var(--cp-gold) !important;
    font-weight: 700 !important;
}

/* Step number bubble */
.cp-step-num {
    width: 22px;
    height: 22px;
    border-radius: 50% !important;
    background: #e5e7eb;
    color: var(--cp-text-muted);
    font-size: 11px;
    font-weight: 700;
    display: -webkit-inline-flex;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background var(--cp-transition), color var(--cp-transition);
}

.cp-steps-strip .nav-tabs > li.active .cp-step-num {
    background: var(--cp-navy);
    color: #fff;
}

.cp-steps-strip .nav-tabs > li[style*="pointer-events:none"] > a,
.cp-steps-strip ul.nav-tabs > li[style*="pointer-events:none"] > a {
    opacity: .42 !important;
}

/* ── Wizard body content area ── */
.cp-wizard-body {
    padding: 24px 28px 0;
}

/* ── Wizard inline status message ── */
.cp-wizard-message {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-left: 4px solid #22c55e !important;
    border-radius: 8px !important;
    padding: 12px 18px;
    font-size: 13.5px;
    color: #166534;
    font-weight: 500;
    margin-bottom: 16px;
}

/* ── Step success/info message ── */
.cp-step-msg {
    background: var(--cp-teal-bg);
    border: 1px solid var(--cp-teal-border);
    border-left: 4px solid var(--cp-teal) !important;
    border-radius: 8px !important;
    padding: 12px 18px;
    font-size: 13.5px;
    color: #0f766e;
    font-weight: 500;
    margin-bottom: 20px;
    display: none;
}

/* ── Step nav footer (Previous / Next) ── */
.cp-step-nav {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 0 4px;
    gap: 10px;
    margin-top: 8px;
}

.cp-step-nav-right {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

/* ── Form card  ── */
.cp-form-card {
    background: var(--cp-surface);
    border-radius: var(--cp-card-radius) !important;
    border: 1px solid var(--cp-border);
    box-shadow: var(--cp-card-shadow);
    overflow: hidden;
    margin-bottom: 20px;
}

/* Neutralise AdminLTE box styles inside form card */
.cp-form-card.box,
.cp-form-card .box {
    border-top: none !important;
    box-shadow: none !important;
    margin-bottom: 0 !important;
}

.cp-form-card-hdr {
    padding: 15px 22px;
    border-bottom: 1px solid var(--cp-border);
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--cp-surface);
}

.cp-form-card-hdr-icon {
    width: 34px;
    height: 34px;
    background: var(--cp-info-bg);
    border-radius: 8px !important;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cp-navy);
    font-size: 14px;
    flex-shrink: 0;
}

.cp-form-card-title {
    font-size: 14.5px;
    font-weight: 700;
    color: var(--cp-navy);
    margin: 0;
    line-height: 1.2;
}

.cp-form-card-body {
    padding: 22px 22px 8px;
}

/* ── Section divider inside form card ── */
.cp-form-section-hdr {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 22px 0 14px;
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--cp-text-muted);
}
.cp-form-section-hdr .fa { color: var(--cp-gold); font-size: 12px; }
.cp-form-section-hdr::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--cp-border);
}
.cp-form-section-hdr:first-child { margin-top: 0; }

/* ── Form controls inside cp-form-card ── */
.cp-form-card .form-control,
.cp-form-card textarea.form-control {
    border-radius: 8px !important;
    border: 1.5px solid var(--cp-border) !important;
    font-size: 13.5px;
    padding: 8px 12px;
    height: auto;
    color: var(--cp-text);
    background: #fff;
    font-family: inherit;
    transition: border-color var(--cp-transition), box-shadow var(--cp-transition);
    box-shadow: none !important;
}
.cp-form-card .form-control:focus,
.cp-form-card textarea.form-control:focus {
    border-color: var(--cp-primary-light) !important;
    box-shadow: 0 0 0 3px rgba(43,108,176,.1) !important;
    outline: none;
}
.cp-form-card .form-control[readonly],
.cp-form-card .form-control[disabled] {
    background: var(--cp-bg) !important;
    color: var(--cp-text-muted) !important;
    cursor: default;
}

.cp-form-card .control-label,
.cp-form-card label {
    font-size: 12.5px !important;
    font-weight: 600 !important;
    color: var(--cp-navy) !important;
    margin-bottom: 5px !important;
}

/* Required star */
.cp-form-card .error-color,
.error-color { color: #ef4444; }

/* Validation message */
.cp-form-card .editor-error {
    font-size: 11.5px !important;
    color: #ef4444 !important;
    margin-top: 3px !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

/* ── Upload panel ── */
.cp-upload-panel {
    border: 1.5px dashed #d1d5db;
    border-radius: 10px !important;
    overflow: hidden;
    background: var(--cp-bg);
    margin-bottom: 16px;
}

.cp-upload-panel-hdr {
    background: #f0f4f8;
    border-bottom: 1px solid #dde3ea;
    padding: 10px 16px;
    font-size: 12.5px;
    font-weight: 700;
    color: var(--cp-navy);
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 7px;
}
.cp-upload-panel-hdr .fa { color: var(--cp-gold); }

.cp-upload-panel-body {
    padding: 14px 16px 12px;
}

.cp-upload-panel-title {
    font-size: 12.5px;
    font-weight: 700;
    color: var(--cp-navy);
    margin-bottom: 4px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 6px;
}
.cp-upload-panel-title .fa { color: var(--cp-gold); }

.cp-upload-panel-hint {
    font-size: 11.5px;
    color: var(--cp-text-muted);
    margin-bottom: 12px;
}

/* ── Address sub-section ── */
.cp-form-subsection {
    border: 1px solid var(--cp-border);
    border-radius: 10px !important;
    overflow: hidden;
    margin-bottom: 16px;
}

.cp-form-subsection-hdr {
    background: var(--cp-info-bg);
    border-bottom: 1px solid var(--cp-info-border);
    padding: 11px 18px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--cp-navy);
    text-transform: uppercase;
    letter-spacing: .06em;
}
.cp-form-subsection-hdr .fa { color: var(--cp-primary-light); font-size: 13px; }

.cp-form-subsection-body {
    padding: 18px 18px 4px;
    background: var(--cp-surface);
}

/* ── Confirmation modal body ── */
.cp-confirm-body {
    padding: 28px 28px 12px;
    text-align: center;
}

.cp-confirm-icon {
    width: 60px;
    height: 60px;
    background: var(--cp-teal-bg);
    border-radius: 50% !important;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    color: var(--cp-teal);
    font-size: 26px;
}

.cp-confirm-title {
    font-family: 'DM Serif Display', serif;
    font-size: 20px;
    font-weight: 400;
    color: var(--cp-navy);
    margin-bottom: 10px;
}

.cp-confirm-desc {
    font-size: 14px;
    color: var(--cp-text-muted);
    line-height: 1.7;
    max-width: 380px;
    margin: 0 auto;
}

.cp-confirm-footer {
    padding: 16px 28px 24px;
    text-align: center;
    border-top: 1px solid var(--cp-border);
    margin-top: 20px;
}

@media (max-width: 767px) {
    .cp-app-context-bar { padding: 12px 18px; }
    .cp-steps-strip .nav-tabs { padding: 0 10px; }
    .cp-steps-strip .nav-tabs > li > a { padding: 12px 12px !important; font-size: 12px; }
    .cp-wizard-body  { padding: 16px 14px 0; }
    .cp-form-card-body { padding: 16px 14px 6px; }
    .cp-step-nav { padding: 14px 0 4px; }
}


/* ══════════════════════════════════════════════════════════════
   §23  VIEW DETAILS PANEL  (AJAX content inside modal body)
   ══════════════════════════════════════════════════════════════ */

/* ── Title header ── */
.vd-header {
    background: linear-gradient(135deg, var(--cp-navy) 0%, var(--cp-navy-mid) 100%);
    padding: 22px 28px 20px;
    position: relative;
    overflow: hidden;
}

.vd-header::after {
    content: '';
    position: absolute;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(201,162,39,.15) 0%, transparent 70%);
    right: -30px; top: -60px;
    border-radius: 50% !important;
    pointer-events: none;
}

.vd-header-inner { position: relative; z-index: 1; }

.vd-title-row {
    display: -webkit-flex;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.vd-title {
    font-family: 'DM Serif Display', 'Georgia', serif;
    font-size: 22px;
    font-weight: 400;
    color: #fff;
    margin: 0;
    line-height: 1.25;
    flex: 1;
}

.vd-header-chips {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.vd-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.88);
    font-size: 12px;
    font-weight: 500;
    padding: 4px 12px;
    border-radius: 20px !important;
    white-space: nowrap;
}
.vd-chip .fa { font-size: 11px; opacity: .8; }

/* ── Meta grid ── */
.vd-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border-bottom: 1px solid var(--cp-border);
    background: var(--cp-surface);
}

.vd-meta-item {
    padding: 14px 20px;
    border-right: 1px solid var(--cp-border);
    border-bottom: 1px solid var(--cp-border);
}
.vd-meta-item:nth-child(3n) { border-right: none; }

.vd-meta-label {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--cp-text-muted);
    margin-bottom: 4px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 5px;
}
.vd-meta-label .fa { color: var(--cp-gold); font-size: 11px; }

.vd-meta-value {
    font-size: 13.5px;
    font-weight: 600;
    color: var(--cp-navy);
    line-height: 1.3;
    word-break: break-word;
}
.vd-meta-value.muted { font-weight: 400; color: var(--cp-text-light); }

/* ── Body: description + sections ── */
.vd-body { padding: 22px 28px; background: var(--cp-surface); }

.vd-section-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--cp-text-muted);
    margin-bottom: 12px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 8px;
}
.vd-section-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--cp-border);
}

.vd-description {
    font-size: 14px;
    color: var(--cp-text-light);
    line-height: 1.85;
    word-wrap: break-word;
}
.vd-description p  { margin-bottom: 10px; }
.vd-description ul,
.vd-description ol { padding-left: 22px; margin-bottom: 10px; }
.vd-description li { margin-bottom: 5px; }

/* ── Documents ── */
.vd-docs { margin-top: 20px; }

.vd-doc-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--cp-info-bg);
    border: 1px solid var(--cp-info-border);
    color: var(--cp-primary);
    font-size: 13px;
    font-weight: 500;
    padding: 8px 16px;
    border-radius: 8px !important;
    margin-right: 10px;
    margin-bottom: 8px;
    text-decoration: none;
    transition: background var(--cp-transition), border-color var(--cp-transition);
}
.vd-doc-link:hover {
    background: var(--cp-primary);
    border-color: var(--cp-primary);
    color: #fff;
    text-decoration: none;
}
.vd-doc-link .fa { font-size: 14px; }

/* ── Required info callout ── */
.vd-required {
    margin-top: 20px;
    background: var(--cp-gold-bg);
    border: 1px solid var(--cp-gold-border);
    border-left: 4px solid var(--cp-gold) !important;
    border-radius: 8px !important;
    padding: 16px 20px;
}

.vd-required-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--cp-navy);
    margin-bottom: 10px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 7px;
}
.vd-required-title .fa { color: var(--cp-gold); }

.vd-required ul {
    margin: 0;
    padding-left: 20px;
}
.vd-required ul li {
    font-size: 13px;
    color: var(--cp-text-light);
    margin-bottom: 5px;
    line-height: 1.5;
}

/* ── No-data state ── */
.vd-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--cp-text-muted);
}
.vd-empty .fa { font-size: 48px; color: #dce2ef; display: block; margin-bottom: 14px; }
.vd-empty p   { font-size: 15px; font-weight: 500; }

@media (max-width: 767px) {
    .vd-header      { padding: 18px 18px 16px; }
    .vd-title       { font-size: 17px; }
    .vd-meta-grid   { grid-template-columns: repeat(2, 1fr); }
    .vd-meta-item:nth-child(3n)  { border-right: 1px solid var(--cp-border); }
    .vd-meta-item:nth-child(2n)  { border-right: none; }
    .vd-body        { padding: 16px 18px; }
    .vd-title-row   { flex-direction: column; }
}

@media (max-width: 480px) {
    .vd-meta-grid { grid-template-columns: 1fr; }
    .vd-meta-item { border-right: none !important; }
}


/* ══════════════════════════════════════════════════════════════
   §22  VIEW DETAILS MODAL
   ══════════════════════════════════════════════════════════════ */
.cp-modal-content {
    border: none !important;
    border-radius: var(--cp-radius-lg) !important;
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(0,0,0,.22) !important;
}

.cp-modal-hdr {
    background: linear-gradient(135deg, var(--cp-navy) 0%, var(--cp-navy-mid) 100%);
    padding: 18px 24px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.cp-modal-hdr-title {
    color: #fff; font-size: 17px; font-weight: 700;
    display: -webkit-flex; display: flex;
    align-items: center; gap: 10px; margin: 0;
}
.cp-modal-hdr-title .fa { opacity: .85; }

.cp-modal-hdr-close {
    background: rgba(255,255,255,.18); border: none;
    border-radius: 50% !important;
    width: 34px; height: 34px;
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: center;
    color: #fff; cursor: pointer;
    transition: background var(--cp-transition);
    font-size: 14px; flex-shrink: 0;
}
.cp-modal-hdr-close:hover { background: rgba(255,255,255,.34); }

@media (max-width: 767px) {
    .cp-modal-hdr { padding: 14px 16px; }
    .cp-modal-hdr-title { font-size: 15px; }
}


/* ══════════════════════════════════════════════════════════════
   §25  ADD-MORE REPEATING CARDS  (Education, Service, Family…)
   ══════════════════════════════════════════════════════════════ */

/* ── Outer card for each repeating group ── */
.cp-add-more-card {
    background: #fff;
    border: 1px solid var(--cp-border);
    border-radius: 10px !important;
    margin-bottom: 18px;
    overflow: hidden;
}

/* ── Card header: number badge + label ── */
.cp-add-more-card-hdr {
    background: #f5f7fb;
    border-bottom: 1px solid var(--cp-border);
    padding: 10px 18px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    gap: 10px;
}

.cp-add-more-idx {
    width: 26px; height: 26px;
    background: var(--cp-navy);
    color: #fff;
    border-radius: 50% !important;
    font-size: 12px; font-weight: 700;
    display: -webkit-inline-flex;
    display: inline-flex;
    align-items: center; justify-content: center;
    flex-shrink: 0;
}

.cp-add-more-card-hdr-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--cp-navy);
    letter-spacing: .01em;
}

/* ── Card body (contains the field rows) ── */
.cp-add-more-card-body {
    padding: 16px 18px 6px;
}

/* ── Actions row: Add More (left) + Remove (right) ── */
.cp-add-more-actions {
    border-top: 1px solid var(--cp-border);
    padding: 10px 18px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.cp-btn-add-more {
    display: -webkit-inline-flex;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1.5px solid var(--cp-teal);
    color: var(--cp-teal);
    font-size: 13px;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 7px !important;
    cursor: pointer;
    transition: background var(--cp-transition), color var(--cp-transition);
    text-decoration: none;
}
.cp-btn-add-more:hover {
    background: var(--cp-teal);
    color: #fff;
    text-decoration: none;
}
.cp-btn-add-more .fa { font-size: 14px; }

.cp-btn-remove {
    display: -webkit-inline-flex;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1.5px solid #e53e3e;
    color: #e53e3e;
    font-size: 13px;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 7px !important;
    cursor: pointer;
    transition: background var(--cp-transition), color var(--cp-transition);
    text-decoration: none;
}
.cp-btn-remove:hover {
    background: #e53e3e;
    color: #fff;
    text-decoration: none;
}
.cp-btn-remove .fa { font-size: 14px; }

/* ── Form note (N/A hint etc.) ── */
.cp-form-note {
    display: -webkit-flex;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fffbeb;
    border: 1px solid #fcd34d;
    border-left: 3px solid var(--cp-gold) !important;
    border-radius: 7px !important;
    padding: 9px 14px;
    font-size: 12.5px;
    color: #92400e;
    font-weight: 500;
    margin-bottom: 18px;
}
.cp-form-note .fa { color: var(--cp-gold); margin-top: 1px; flex-shrink: 0; }

/* ── Reference details table ── */
.cp-ref-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0;
}
.cp-ref-table thead tr {
    background: var(--cp-navy);
}
.cp-ref-table thead th,
.cp-ref-table .header {
    padding: 10px 14px;
    text-align: left;
    font-size: 12.5px;
    font-weight: 700;
    color: #fff !important;
    text-transform: uppercase;
    letter-spacing: .04em;
    border: none;
}
.cp-ref-table tbody tr:nth-child(even) { background: #f8f9fc; }
.cp-ref-table tbody td,
.cp-ref-table .data {
    padding: 10px 14px;
    vertical-align: middle;
    font-size: 14px;
    color: var(--cp-text-dark) !important;
    border-bottom: 1px solid var(--cp-border) !important;
}

/* ── Reference table action buttons ── */
.cp-ref-table .btn-danger  { border-radius: 6px !important; }
.cp-ref-table .btn-primary { border-radius: 6px !important; background: var(--cp-navy); border-color: var(--cp-navy); }

/* ── Required badge ── */
.cp-required-badge {
    display: inline-block;
    margin-left: 8px;
    padding: 1px 7px;
    background: #fff0f0;
    border: 1px solid #fca5a5;
    border-radius: 4px !important;
    font-size: 11px;
    font-weight: 700;
    color: #dc2626;
    vertical-align: middle;
    letter-spacing: .02em;
}

/* ── Additional Info question groups ── */
.cp-question-group-label {
    font-size: 13px;
    font-weight: 700;
    color: var(--cp-navy);
    padding: 6px 0 10px;
    margin-bottom: 14px;
    border-bottom: 2px solid var(--cp-gold);
    display: flex;
    align-items: center;
    gap: 8px;
    letter-spacing: .02em;
}

/* ── Individual question card ── */
.cp-question-card {
    background: #fff;
    border: 1px solid var(--cp-border);
    border-radius: 10px !important;
    margin-bottom: 14px;
    overflow: hidden;
}
.cp-question-card-hdr {
    background: linear-gradient(135deg, #eef2ff 0%, #f0f4ff 100%);
    border-bottom: 1px solid #c7d2fe;
    padding: 11px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.cp-question-num {
    width: 26px;
    height: 26px;
    background: #4f46e5;
    color: #fff;
    border-radius: 50% !important;
    font-size: 12px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.cp-question-text {
    font-size: 13.5px;
    font-weight: 600;
    color: #1e1b4b;
    flex: 1;
}
.cp-question-text label { margin: 0; font-weight: 600; color: inherit; }
.cp-question-card-body {
    padding: 14px 16px 8px;
}

/* Kept for backward-compat in case referenced elsewhere */
.cp-question-prompt {
    background: #e8f4fd;
    border-left: 3px solid #3b82f6 !important;
    border-radius: 6px !important;
    padding: 10px 14px;
    font-size: 13.5px;
    color: #1e3a5f;
    margin-bottom: 10px;
}
.cp-question-prompt label { margin: 0; font-weight: 600; }

/* ── Immigration table ── */
.cp-imm-table { width: 100%; }
.cp-imm-table thead tr { background: var(--cp-navy); }
.cp-imm-table thead th { padding: 10px 12px; font-size: 12.5px; font-weight: 700; color: #fff !important; text-transform: uppercase; letter-spacing: .04em; border: none !important; }
.cp-imm-table tbody tr:nth-child(odd) { background: #f8f9fc; }
.cp-imm-table .data { padding: 9px 12px; vertical-align: middle; font-size: 13.5px; color: var(--cp-text-dark) !important; border-bottom: 1px solid var(--cp-border) !important; }

/* ── Add-more form section intro ── */
.cp-add-form-hdr {
    font-size: 13px;
    font-weight: 700;
    color: var(--cp-navy);
    padding: 8px 0 10px;
    border-bottom: 1px solid var(--cp-border);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 7px;
}

@media (max-width: 767px) {
    .cp-add-more-card-body { padding: 12px 12px 4px; }
    .cp-add-more-actions   { padding: 10px 12px; }
    .cp-question-group     { padding: 12px 10px 4px; }
}


/* ══════════════════════════════════════════════════════════════
   §26  CAREER AUTH PAGES  (Login · Sign Up · Forgot Password)
   ══════════════════════════════════════════════════════════════ */

/* ── Page wrapper ── */
.login-page-career {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 120px);
    padding: 30px 15px;
}

/* ── Two-panel card ── */
.login-container {
    display: -webkit-flex;
    display: flex;
    width: 300mm;
    max-width: 100%;
    border-radius: 20px !important;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 24px 60px rgba(11,31,58,.14);
}

/* ── Left brand panel ── */
.login-brand {
    width: 40%;
    background: linear-gradient(160deg, var(--cp-navy) 0%, var(--cp-navy-mid) 35%, var(--cp-primary-light) 70%, var(--cp-gold) 100%);
    color: #fff;
    padding: 50px 32px;
    text-align: center;
    display: -webkit-flex;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

/* Logo white pill */
.logo-card {
    background: rgba(255,255,255,.96);
    border-radius: 16px !important;
    padding: 18px 22px;
    display: inline-block;
    box-shadow: 0 6px 24px rgba(0,0,0,.18);
    margin: 0 auto 6px;
    position: relative;
    z-index: 1;
}

/* ── Logo fallback — shown when image is absent or fails to load ── */
.logo-fallback {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    gap: 10px;
    padding: 6px 10px;
    min-width: 120px;
}
.logo-fallback .lf-icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 50% !important;
    background: linear-gradient(135deg, var(--cp-navy-mid), var(--cp-primary-light));
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(30,79,163,.30);
}
.logo-fallback .lf-icon-wrap i {
    font-size: 34px;
    color: #fff;
    line-height: 1;
}
.logo-fallback .lf-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--cp-navy-mid);
    text-align: center;
}

/* Decorative blobs */
.login-brand::before,
.login-brand::after {
    content: '';
    position: absolute;
    border-radius: 50% !important;
    background: rgba(255,255,255,.06);
}
.login-brand::before { width: 220px; height: 220px; top: -60px; right: -60px; }
.login-brand::after  { width: 150px; height: 150px; bottom: -40px; left: -40px; }

.login-brand img { margin: 0 auto; position: relative; z-index: 1; }

.brand-tagline { position: relative; z-index: 1; margin-top: 18px; }

.brand-tagline h3 {
    font-size: 20px; font-weight: 700;
    margin-bottom: 10px; color: #fff; letter-spacing: .3px;
}

.brand-tagline p { font-size: 13px; opacity: .88; line-height: 1.7; margin-bottom: 0; }

.brand-features { list-style: none; padding: 0; margin: 22px 0 0; text-align: left; position: relative; z-index: 1; }

.brand-features li {
    font-size: 13px; opacity: .92;
    padding: 7px 0;
    border-bottom: 1px solid rgba(255,255,255,.12);
    display: -webkit-flex; display: flex;
    align-items: center; gap: 10px;
}
.brand-features li:last-child { border-bottom: none; }
.brand-features li i { color: var(--cp-gold-light); font-size: 15px; flex-shrink: 0; }

/* ── Right form panel ── */
.login-box-career { width: 60%; padding: 48px 44px; background: #fff; }

.login-box-career h2 { margin: 0 0 6px; color: var(--cp-navy-mid); font-weight: 700; font-size: 24px; }

.login-box-career .page-subtitle { color: #8898aa; font-size: 13px; margin-bottom: 26px; }

/* ── Welcome badge (Login only) ── */
.welcome-badge {
    display: -webkit-inline-flex; display: inline-flex;
    align-items: center; gap: 7px;
    background: var(--cp-info-bg);
    border: 1px solid var(--cp-info-border);
    border-radius: 50px !important;
    padding: 5px 14px;
    font-size: 12px; font-weight: 600;
    color: var(--cp-primary-light);
    margin-bottom: 16px;
}
.welcome-badge i { color: var(--cp-gold); font-size: 13px; }

/* ── Step indicator (SignUp / ForgotPassword) ── */
.signup-steps { display: -webkit-flex; display: flex; align-items: center; margin-bottom: 28px; }

.signup-steps .step {
    display: -webkit-flex; display: flex;
    align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600;
    color: #b0bec5; white-space: nowrap;
}
.signup-steps .step.active { color: var(--cp-primary-light); }
.signup-steps .step.done   { color: var(--cp-success); }

.signup-steps .step-num {
    width: 26px; height: 26px;
    border-radius: 50% !important;
    background: #e9ecef; color: #999;
    font-size: 12px; font-weight: 700;
    display: -webkit-inline-flex; display: inline-flex;
    align-items: center; justify-content: center; flex-shrink: 0;
}
.signup-steps .step.active .step-num { background: var(--cp-navy); color: #fff; }
.signup-steps .step.done   .step-num { background: var(--cp-success); color: #fff; }

.signup-steps .step-sep {
    -webkit-flex: 1; flex: 1;
    height: 2px; background: #e9ecef;
    margin: 0 10px; min-width: 20px;
}

/* ── Form labels ── */
.login-page-career .form-group label.field-label {
    font-size: 12.5px; font-weight: 600;
    color: #4a5568; margin-bottom: 7px;
    display: block; letter-spacing: .2px;
}

/* ── Input group (Bootstrap 3 flex fix) ── */
.login-page-career .input-group {
    display: -webkit-flex !important; display: flex !important;
    width: 100% !important; align-items: stretch !important;
}

.login-page-career .input-group .input-group-addon {
    display: -webkit-flex !important; display: flex !important;
    align-items: center !important; justify-content: center !important;
    background: var(--cp-info-bg);
    border: 1px solid var(--cp-border); border-right: none;
    border-radius: 10px 0 0 10px !important;
    color: var(--cp-primary-light);
    font-size: 15px; width: 44px; min-width: 44px; flex-shrink: 0; padding: 0;
}

.login-page-career .input-group .form-control {
    -webkit-flex: 1 1 auto !important; flex: 1 1 auto !important;
    width: 1% !important; min-width: 0 !important;
    height: 46px;
    border: 1px solid var(--cp-border); border-left: none;
    border-radius: 0 10px 10px 0 !important;
    font-size: 14px; padding: 10px 14px;
    transition: border-color .2s ease, box-shadow .2s ease;
    box-shadow: none;
}

.login-page-career .input-group .form-control:focus {
    border-color: var(--cp-primary-light);
    box-shadow: 0 0 0 3px rgba(43,108,176,.12);
    outline: none;
}

.login-page-career .input-group:focus-within .input-group-addon {
    border-color: var(--cp-primary-light);
    background: var(--cp-info-bg);
}

.login-page-career .input-group .pwd-wrapper {
    -webkit-flex: 1 1 auto !important; flex: 1 1 auto !important;
    width: 1% !important; min-width: 0 !important;
    display: -webkit-flex !important; display: flex !important;
    align-items: stretch !important; position: relative !important;
}

.login-page-career .input-group .pwd-wrapper .form-control {
    width: 100% !important; border-radius: 0 10px 10px 0 !important;
}

/* ── Password show/hide toggle ── */
.login-page-career .pwd-wrapper { position: relative; }
.login-page-career .pwd-wrapper .form-control { padding-right: 44px; }

.pwd-toggle {
    position: absolute; top: 50%; right: 12px;
    transform: translateY(-50%);
    background: none; border: none;
    color: #8898aa; cursor: pointer;
    padding: 0; font-size: 15px; z-index: 4; line-height: 1;
}
.pwd-toggle:hover { color: var(--cp-primary-light); }

/* ── Password strength bar ── */
.pwd-strength-bar { display: -webkit-flex; display: flex; gap: 4px; margin-top: 7px; }

.pwd-strength-bar span {
    -webkit-flex: 1; flex: 1;
    height: 4px; border-radius: 3px !important;
    background: #e9ecef; transition: background .3s ease;
}

.pwd-strength-bar.strength-1 span:nth-child(1) { background: #e53935; }
.pwd-strength-bar.strength-2 span:nth-child(1),
.pwd-strength-bar.strength-2 span:nth-child(2) { background: #fb8c00; }
.pwd-strength-bar.strength-3 span:nth-child(1),
.pwd-strength-bar.strength-3 span:nth-child(2),
.pwd-strength-bar.strength-3 span:nth-child(3) { background: #fdd835; }
.pwd-strength-bar.strength-4 span { background: var(--cp-success); }

.pwd-strength-label { font-size: 11px; margin-top: 4px; color: #8898aa; font-weight: 600; }

/* ── Password requirement checklist ── */
.pwd-checklist {
    list-style: none; padding: 0; margin: 10px 0 0;
    display: -webkit-flex; display: flex;
    flex-wrap: wrap; gap: 5px 16px;
}

.pwd-checklist li {
    font-size: 11.5px; color: #b0bec5;
    display: -webkit-flex; display: flex;
    align-items: center; gap: 5px; transition: color .2s;
}
.pwd-checklist li.ok { color: var(--cp-success); }
.pwd-checklist li i  { font-size: 12px; }

/* ── OTP countdown timer ── */
.timer-badge {
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: center; gap: 8px;
    background: var(--cp-info-bg);
    border: 1px solid var(--cp-info-border);
    border-radius: 10px !important;
    padding: 10px 16px;
    font-size: 13px; color: #4a5568;
    margin-top: 14px;
    transition: background .3s, border-color .3s;
}
.timer-badge i { color: var(--cp-primary-light); font-size: 16px; }
.timer-badge.timer-urgent { background: #fff5f5; border-color: #feb2b2; color: #c53030; }
.timer-badge.timer-urgent i { color: #e53935; }
.timer-count { font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; }

/* ── Primary action button ── */
.btn-login {
    width: 100%;
    background: linear-gradient(135deg, var(--cp-primary-light), var(--cp-navy-mid));
    color: #fff; border: none; padding: 13px;
    border-radius: 12px !important;
    font-size: 15px; font-weight: 600;
    cursor: pointer; transition: all .25s ease;
    letter-spacing: .3px;
    box-shadow: 0 4px 14px rgba(30,79,163,.30);
    margin-top: 6px;
}
.btn-login:hover {
    background: linear-gradient(135deg, var(--cp-primary), var(--cp-navy));
    box-shadow: 0 8px 22px rgba(30,79,163,.40);
    transform: translateY(-1px);
}
.btn-login:active { transform: translateY(0); }

/* ── Forgot-password link ── */
.forgot-link-row { text-align: right; margin-top: -8px; margin-bottom: 18px; }

.forgot-link-row a {
    font-size: 12.5px; color: var(--cp-primary-light);
    font-weight: 600; text-decoration: none;
}
.forgot-link-row a:hover { text-decoration: underline; }

/* ── OR divider (ForgotPassword) ── */
.or-divider {
    display: -webkit-flex; display: flex;
    align-items: center; gap: 10px;
    margin: 4px 0 16px;
    color: #b0bec5; font-size: 12px;
    font-weight: 600; letter-spacing: .5px;
}
.or-divider::before,
.or-divider::after { content: ''; -webkit-flex: 1; flex: 1; height: 1px; background: #e9ecef; }

/* ── CAPTCHA card (Login only) ── */
.captcha-card {
    background: var(--cp-bg);
    border: 1px solid var(--cp-border);
    border-radius: 12px !important;
    padding: 14px 16px; margin-bottom: 18px;
}
.captcha-card label.field-label { margin-bottom: 10px; }

.captcha-image-row {
    display: -webkit-flex; display: flex;
    align-items: center; gap: 10px; margin-bottom: 10px;
}

.captcha-image-row img {
    border-radius: 8px !important;
    border: 1px solid var(--cp-border);
    height: 44px; flex-shrink: 0;
}

.btn-captcha-refresh {
    display: -webkit-inline-flex; display: inline-flex;
    align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border-radius: 8px !important;
    background: var(--cp-info-bg);
    border: 1px solid var(--cp-info-border);
    color: var(--cp-primary-light);
    cursor: pointer; font-size: 15px;
    transition: all .2s ease; flex-shrink: 0; padding: 0;
}
.btn-captcha-refresh:hover { background: var(--cp-navy); color: #fff; border-color: var(--cp-navy); }

/* ── Bottom nav links ── */
.login-links { margin-top: 22px; text-align: center; }
.login-links p { font-size: 13px; color: #6b7280; margin-bottom: 6px; }
.login-links a { color: var(--cp-primary-light); font-weight: 600; text-decoration: none; }
.login-links a:hover { text-decoration: underline; }

/* ── Validation errors on auth pages ── */
.login-page-career .editor-error {
    font-size: 11.5px; margin-top: 4px; color: #c53030;
    border: none !important; background: none !important; padding: 0 !important;
}

/* ── Alert overrides (scoped to auth pages) ── */
.login-page-career .alert { padding: 12px 16px; border-radius: 6px; margin-bottom: 15px; font-size: 14px; }

.login-page-career .alert-danger {
    background-color: #f8d7da !important; color: #842029 !important;
    border: 1px solid #f5c2c7 !important; border-radius: 8px !important;
}

.login-page-career .alert-warning {
    background-color: #fff3cd !important; color: #664d03 !important;
    border: 1px solid #ffecb5 !important; border-radius: 8px !important;
}

/* ── Security-code confirmation modal header ── */
.cp-code-confirm-modal-hdr {
    background: linear-gradient(135deg, var(--cp-primary-light), var(--cp-navy-mid));
    border-bottom: none !important;
    padding: 14px 20px;
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: space-between;
}

.cp-code-confirm-modal-hdr .modal-title {
    color: #fff; font-size: 16px; font-weight: 700; margin: 0;
    display: -webkit-flex; display: flex;
    align-items: center; gap: 8px;
}

.cp-code-confirm-modal-hdr .close {
    color: #fff !important; opacity: 1 !important;
    font-size: 22px; margin: 0; padding: 0;
    background: none; border: none;
    line-height: 1; cursor: pointer;
    text-shadow: none !important;
}

/* ── Mobile ── */
@media (max-width: 768px) {
    .login-container { flex-direction: column; }
    .login-brand, .login-box-career { width: 100%; }
    .login-brand { padding: 28px 24px; }
    .login-brand::before { width: 130px; height: 130px; top: -30px; right: -30px; }
    .login-brand::after  { width: 90px;  height: 90px;  bottom: -25px; left: -25px; }
    .brand-features { display: none; }
    .login-box-career { padding: 32px 22px; }
    .login-box-career h2 { font-size: 20px; }
    .signup-steps .step span:not(.step-num) { display: none; }
}


/* ══════════════════════════════════════════════════════════════
   §27  APPLICANT DASHBOARD
   ══════════════════════════════════════════════════════════════ */

/* ── Top banner ── */
.dash-banner {
    background: linear-gradient(135deg, var(--cp-navy) 0%, var(--cp-primary-light) 100%);
    color: #fff; padding: 32px 40px 28px;
    /*margin: 10px; border-radius: 10px !important;*/
}
.dash-banner h2 { font-size: 22px; font-weight: 700; margin: 0 0 4px; color: #fff; }
.dash-banner p  { font-size: 14px; color: rgba(255,255,255,.75); margin: 0; }

/* ── Body wrapper ── */
.dash-body { background: var(--cp-bg); padding: 30px 40px 50px; }

@media (max-width: 767px) {
    .dash-banner { padding: 24px 20px 20px; }
    .dash-body   { padding: 20px 14px 40px; }
}

/* ── Profile sidebar card ── */
.profile-card {
    background: #fff; border-radius: 14px !important;
    box-shadow: 0 4px 18px rgba(0,0,0,.08);
    overflow: hidden; margin-bottom: 24px;
}

.profile-card-top {
    background: linear-gradient(135deg, var(--cp-navy), var(--cp-primary-light));
    padding: 28px 20px 20px; text-align: center;
}

.profile-avatar {
    width: 96px; height: 96px;
    border-radius: 50% !important;
    border: 3px solid rgba(255,255,255,.6);
    object-fit: cover; margin-bottom: 12px; background: #fff;
}

.profile-card-top h3 { color: #fff; font-size: 17px; font-weight: 700; margin: 0 0 6px; }
.profile-card-body   { padding: 18px 20px; }

.profile-stat {
    display: -webkit-flex; display: flex;
    align-items: center; gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid #f0f0f0;
    font-size: 13px; color: #374151;
}
.profile-stat:last-child { border-bottom: none; }

.profile-stat .stat-icon {
    width: 32px; height: 32px; border-radius: 8px !important;
    background: var(--cp-info-bg);
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: center;
    color: var(--cp-accent); font-size: 14px; flex-shrink: 0;
}
.profile-stat .stat-label { color: #9ca3af; font-size: 11px; }
.profile-stat .stat-value { font-weight: 600; font-size: 13px; color: #1f2937; }

/* ── Offer letter pill ── */
.offer-badge {
    display: inline-block; margin-top: 8px; padding: 5px 14px;
    border-radius: 20px !important; font-size: 12px; font-weight: 600; color: #fff;
}
.offer-badge.accepted { background: var(--cp-success); }
.offer-badge.rejected { background: #dc2626; }

/* ── Basic Information card ── */
.info-card {
    background: #fff; border-radius: 14px !important;
    box-shadow: 0 4px 18px rgba(0,0,0,.08);
    margin-bottom: 24px; overflow: hidden;
}

.info-card-header {
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: space-between;
    padding: 16px 22px;
    border-bottom: 1px solid var(--cp-border);
    background: #fafbff;
}
.info-card-header h4 { font-size: 15px; font-weight: 700; color: var(--cp-navy-mid); margin: 0; }

.info-card-header .header-icon {
    width: 34px; height: 34px; border-radius: 8px !important;
    background: var(--cp-info-bg);
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: center;
    color: var(--cp-accent); font-size: 15px;
}

.info-card-body { padding: 20px 22px; }

.info-row {
    display: -webkit-flex; display: flex;
    align-items: flex-start;
    padding: 10px 0; border-bottom: 1px solid #f3f4f6; font-size: 13.5px;
}
.info-row:last-child { border-bottom: none; }

.info-label {
    -webkit-flex: 0 0 170px; flex: 0 0 170px;
    font-weight: 600; color: #6b7280;
    font-size: 12.5px; text-transform: uppercase;
    letter-spacing: .03em; padding-top: 1px;
}
.info-value { -webkit-flex: 1; flex: 1; color: #1f2937; font-weight: 500; word-break: break-word; }

@media (max-width: 600px) {
    .info-row   { flex-direction: column; gap: 3px; }
    .info-label { -webkit-flex: none; flex: none; }
}

/* ── Collapsible section panels ── */
.dash-panel {
    background: #fff; border-radius: 14px !important;
    box-shadow: 0 4px 18px rgba(0,0,0,.07);
    margin-bottom: 20px; overflow: hidden;
}

.dash-panel-header {
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: space-between;
    padding: 16px 22px; background: #fafbff;
    border-bottom: 1px solid var(--cp-border);
    cursor: pointer;
    -webkit-user-select: none; user-select: none;
}
.dash-panel-header:hover { background: var(--cp-info-bg); }

.dash-panel-title {
    display: -webkit-flex; display: flex;
    align-items: center; gap: 10px;
    font-size: 15px; font-weight: 700;
    color: var(--cp-navy-mid); margin: 0;
}

.dash-panel-title .panel-icon {
    width: 34px; height: 34px; border-radius: 8px !important;
    background: var(--cp-info-bg);
    display: -webkit-flex; display: flex;
    align-items: center; justify-content: center;
    color: var(--cp-accent); font-size: 14px; flex-shrink: 0;
}

.dash-panel-toggle { color: #9ca3af; font-size: 14px; transition: transform .25s ease; }
.dash-panel-header.collapsed .dash-panel-toggle { transform: rotate(-90deg); }
.dash-panel-body { padding: 18px 22px; }

/* ── Data tables ── */
.dash-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }

.dash-table thead tr { background: linear-gradient(135deg, var(--cp-navy), var(--cp-accent)); }

.dash-table thead th {
    padding: 11px 14px; color: #fff;
    font-weight: 600; font-size: 12px;
    text-transform: uppercase; letter-spacing: .04em;
    white-space: nowrap; border: none;
}

.dash-table tbody tr { border-bottom: 1px solid #f0f0f0; transition: background .15s; }
.dash-table tbody tr:hover { background: #f8faff; }
.dash-table tbody tr:last-child { border-bottom: none; }
.dash-table tbody td { padding: 11px 14px; color: #374151; vertical-align: middle; }

.dash-table .no-record {
    text-align: center; color: #ef4444;
    font-style: italic; padding: 20px;
}

/* ── Status badge ── */
.status-badge {
    display: inline-block; padding: 4px 12px;
    border-radius: 20px !important;
    font-size: 12px; font-weight: 600;
    color: #fff; white-space: nowrap;
}

/* ── Action icon buttons ── */
.action-btn {
    display: -webkit-inline-flex; display: inline-flex;
    align-items: center; justify-content: center;
    width: 30px; height: 30px;
    border-radius: 6px !important;
    background: var(--cp-info-bg); color: var(--cp-accent);
    cursor: pointer; transition: background .2s; margin-right: 4px;
}
.action-btn:hover          { background: var(--cp-accent); color: #fff; }
.action-btn.print          { background: #f0fdf4; color: var(--cp-success); }
.action-btn.print:hover    { background: var(--cp-success); color: #fff; }

/* ── Dashboard modal header ── */
.dash-modal-hdr {
    background: linear-gradient(135deg, var(--cp-navy), var(--cp-primary-light));
    color: #fff;
    border-radius: 4px 4px 0 0 !important;
}

/* ── Scrollbar ── */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: #f1f1f1; }
::-webkit-scrollbar-thumb { background: var(--cp-info-border); border-radius: 3px !important; }

/* ══════════════════════════════════════════════════════════════
   §28  FIELD STATUS BADGES
   (Verified / Auto-Filled inline label pills)
   ══════════════════════════════════════════════════════════════ */

/* ── Base pill ── */
.field-badge {
    display: inline-block;
    padding: 1px 7px;
    border-radius: 4px !important;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.6px;
    vertical-align: middle;
    line-height: 18px;
    text-transform: uppercase;
    white-space: nowrap;
    margin-left: 5px;
}

/* ── VERIFIED — solid green ── */
.badge-verified {
    background: #16a34a;
    color: #fff;
}

/* ── AUTO-FILLED — teal ── */
.badge-auto-filled {
    background: var(--cp-teal);
    color: #fff;
}

/* ── MULTI SELECT — blue ── */
.badge-multi-select {
    background: var(--cp-accent);
    color: #fff;
}

/* ══════════════════════════════════════════════════════════════
   §29  SELECT2 — MATCH NATIVE BOOTSTRAP FORM-CONTROL
   Makes the Select2 (--default theme) look identical to a
   native Bootstrap <select class="form-control">
   ══════════════════════════════════════════════════════════════ */

/* ── Full width like form-control ── */
.select2-container {
    width: 100% !important;
}

/* ── Closed selection box ── */
.select2-container--default .select2-selection--single {
    height: 34px !important;
    padding: 6px 0 6px 12px !important;
    background-color: #fff !important;
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075) !important;
    box-shadow: inset 0 1px 1px rgba(0,0,0,.075) !important;
    -webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s !important;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s !important;
    outline: 0;
}

/* ── Rendered text inside the box ── */
.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #555 !important;
    line-height: 22px !important;
    padding-left: 0 !important;
    padding-right: 24px !important;
    font-size: 14px !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Placeholder colour ── */
.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #999 !important;
}

/* ── Arrow wrapper — match native select right-side caret zone ── */
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 32px !important;
    width: 28px !important;
    top: 1px !important;
    right: 0 !important;
    border-left: 1px solid #ccc !important;
    background-color: #f5f5f5 !important;
    border-radius: 0 4px 4px 0 !important;
}

/* ── Arrow caret triangle ── */
.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #888 transparent transparent transparent !important;
    border-style: solid !important;
    border-width: 5px 4px 0 4px !important;
    margin-top: -3px !important;
    margin-left: -4px !important;
}

/* ── Arrow flips when open ── */
.select2-container--default.select2-container--open
.select2-selection--single .select2-selection__arrow b {
    border-color: transparent transparent #888 transparent !important;
    border-width: 0 4px 5px 4px !important;
}

/* ── Focus / open state — Bootstrap blue glow ── */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open  .select2-selection--single {
    border-color: #66afe9 !important;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102,175,233,.6) !important;
    box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102,175,233,.6) !important;
    outline: 0;
}

/* Also sync the arrow border when focused */
.select2-container--default.select2-container--focus .select2-selection__arrow,
.select2-container--default.select2-container--open  .select2-selection__arrow {
    border-left-color: #66afe9 !important;
}

/* ── Open: connect selection box edge to dropdown ── */
.select2-container--default.select2-container--open.select2-container--below
.select2-selection--single {
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-bottom-color: transparent !important;
}
.select2-container--default.select2-container--open.select2-container--above
.select2-selection--single {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
    border-top-color: transparent !important;
}

/* ── Dropdown panel ── */
.select2-dropdown {
    border: 1px solid #66afe9 !important;
    border-radius: 4px !important;
    -webkit-box-shadow: 0 6px 12px rgba(0,0,0,.175) !important;
    box-shadow: 0 6px 12px rgba(0,0,0,.175) !important;
    font-size: 14px !important;
    z-index: 9999 !important;
}

/* ── Dropdown search field ── */
.select2-container--default .select2-search--dropdown .select2-search__field {
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    padding: 5px 8px !important;
    font-size: 14px !important;
    color: #555 !important;
    outline: 0;
}

/* ── Options ── */
.select2-results__option {
    padding: 6px 12px !important;
    font-size: 14px !important;
    color: #333 !important;
}
.select2-container--default .select2-results__option[aria-selected=true] {
    background-color: #f5f5f5 !important;
    color: #262626 !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #337ab7 !important;
    color: #fff !important;
}
.select2-container--default .select2-results__option[aria-disabled=true] {
    color: #999 !important;
    cursor: not-allowed !important;
}

/* ── Disabled state ── */
.select2-container--default.select2-container--disabled .select2-selection--single {
    background-color: #eee !important;
    border-color: #ccc !important;
    cursor: not-allowed !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}
.select2-container--default.select2-container--disabled .select2-selection__arrow {
    background-color: #e8e8e8 !important;
}

/* ── MULTIPLE selection container ── */
.select2-container--default .select2-selection--multiple {
    min-height: 34px !important;
    padding: 2px 4px !important;
    background-color: #fff !important;
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075) !important;
    box-shadow: inset 0 1px 1px rgba(0,0,0,.075) !important;
    cursor: text !important;
}

/* Focus / open */
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--open  .select2-selection--multiple {
    border-color: #66afe9 !important;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102,175,233,.6) !important;
    box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102,175,233,.6) !important;
    outline: 0;
}

/* ── Each selected tag/chip ── */
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    display: -webkit-inline-flex;
    display: inline-flex;
    -webkit-align-items: center;
    align-items: center;
    background-color: #eff6ff !important;
    border: 1px solid #bfdbfe !important;
    border-radius: 4px !important;
    color: #1e40af !important;
    font-size: 11.5px !important;
    font-weight: 500 !important;
    /*padding: 1px 7px 1px 5px !important;*/
    /*margin: 1px 3px 1px 0 !important;*/
    float: left !important;
    cursor: default !important;
    line-height: 20px !important;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Remove × button ── */
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: #6b7280 !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    margin-right: 5px !important;
    cursor: pointer !important;
    line-height: 1 !important;
    -webkit-flex-shrink: 0;
    flex-shrink: 0;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
    color: #dc2626 !important;
}

/* ── Inline search input inside multi-select ── */
.select2-container--default .select2-selection--multiple .select2-search--inline {
    float: left;
}
.select2-container--default .select2-selection--multiple .select2-search--inline .select2-search__field {
    font-size: 14px !important;
    color: #555 !important;
    height: 26px !important;
    line-height: 26px !important;
    padding: 0 4px !important;
    margin: 1px 0 !important;
    min-width: 60px !important;
}

/* ── Disabled multiple ── */
.select2-container--default.select2-container--disabled .select2-selection--multiple {
    background-color: #eee !important;
    border-color: #ccc !important;
    cursor: not-allowed !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}
.select2-container--default.select2-container--disabled .select2-selection--multiple .select2-selection__choice {
    background-color: #e2e8f0 !important;
    border-color: #cbd5e1 !important;
    color: #94a3b8 !important;
}
.select2-container--default.select2-container--disabled .select2-selection__choice__remove {
    display: none !important;
}
