/* CIPFA Brand Colors
   Primary purple:  #5B4B8A
   Dark purple:     #3D2F6B
   Accent purple:   #7B6BA0
   Light bg:        #F5F4F8
   Border:          #D9D4E8
*/

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

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 16px;
    color: #333;
    background: #F5F4F8;
}

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ── Header ─────────────────────────────────────────────── */
.cipfa-header {
    background: #fff;
    border-bottom: 3px solid #5B4B8A;
    padding: 12px 0;
}

.cipfa-header-inner {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    gap: 24px;
}

.cipfa-logo-link {
    flex-shrink: 0;
    text-decoration: none;
}

.cipfa-logo {
    height: 52px;
    width: auto;
    display: block;
}

.cipfa-header-tagline {
    font-size: 0.8rem;
    color: #666;
    letter-spacing: 0.01em;
    line-height: 1.3;
}

/* ── Purple nav bar ──────────────────────────────────────── */
.cipfa-nav-bar {
    background: #5B4B8A;
    color: #fff;
    padding: 0;
}

.cipfa-nav-inner {
    max-width: 1140px;
    margin: 0 auto;
    padding: 10px 24px;
    font-size: 0.95rem;
    font-weight: bold;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

/* ── Main content ────────────────────────────────────────── */
.cipfa-main {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
}

/* ── Login card ──────────────────────────────────────────── */
.cipfa-login-card {
    background: #fff;
    border: 1px solid #D9D4E8;
    border-top: 4px solid #5B4B8A;
    border-radius: 4px;
    width: 100%;
    max-width: 440px;
    padding: 40px 40px 36px;
    box-shadow: 0 2px 12px rgba(91, 75, 138, 0.10);
}

.cipfa-login-title {
    font-size: 1.5rem;
    font-weight: bold;
    color: #5B4B8A;
    margin: 0 0 6px 0;
}

.cipfa-login-subtitle {
    font-size: 0.9rem;
    color: #666;
    margin: 0 0 28px 0;
}

.cipfa-divider {
    border: none;
    border-top: 1px solid #D9D4E8;
    margin: 0 0 28px 0;
}

/* ── Form fields ─────────────────────────────────────────── */
.cipfa-label {
    display: block;
    font-size: 0.875rem;
    font-weight: bold;
    color: #333;
    margin-bottom: 6px;
}

.cipfa-input {
    display: block;
    width: 100%;
    padding: 10px 12px;
    font-size: 1rem;
    border: 1px solid #bbb;
    border-radius: 3px;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.cipfa-input:focus {
    border-color: #5B4B8A;
    box-shadow: 0 0 0 3px rgba(91, 75, 138, 0.18);
}

.cipfa-form-group {
    margin-bottom: 20px;
}

.cipfa-field-error {
    display: block;
    font-size: 0.8rem;
    color: #c0392b;
    margin-top: 4px;
}

/* ── Alert ───────────────────────────────────────────────── */
.cipfa-alert {
    background: #fdf0ef;
    border-left: 4px solid #c0392b;
    color: #a93226;
    padding: 12px 16px;
    border-radius: 3px;
    font-size: 0.9rem;
    margin-bottom: 24px;
}

/* ── Submit button ───────────────────────────────────────── */
.cipfa-btn {
    display: inline-block;
    width: 100%;
    padding: 12px 24px;
    background: #5B4B8A;
    color: #fff;
    font-size: 1rem;
    font-weight: bold;
    border: none;
    border-radius: 3px;
    cursor: pointer;
    text-align: center;
    letter-spacing: 0.02em;
    transition: background 0.2s;
}

.cipfa-btn:hover,
.cipfa-btn:focus {
    background: #3D2F6B;
    outline: none;
}

.cipfa-btn:active {
    background: #2e2350;
}

/* ── Footer ──────────────────────────────────────────────── */
.cipfa-footer {
    background: #3D2F6B;
    color: rgba(255,255,255,0.75);
    padding: 20px 0;
    font-size: 0.8rem;
    text-align: center;
}

.cipfa-footer-inner {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 24px;
}

.cipfa-footer a {
    color: rgba(255,255,255,0.85);
    text-decoration: none;
}

.cipfa-footer a:hover {
    color: #fff;
    text-decoration: underline;
}

.cipfa-footer-sep {
    margin: 0 8px;
    opacity: 0.5;
}

@media (max-width: 500px) {
    .cipfa-login-card {
        padding: 28px 20px 24px;
    }

    .cipfa-header-tagline {
        display: none;
    }
}


a.navbar-brand {
    white-space: normal;
    text-align: center;
    word-break: break-all;
}

a {
    color: #0077cc;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.border-top {
    border-top: 1px solid #e5e5e5;
}

.border-bottom {
    border-bottom: 1px solid #e5e5e5;
}

.box-shadow {
    box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .05);
}

button.accept-policy {
    font-size: 1rem;
    line-height: inherit;
}

.footer {
    position: absolute;
    bottom: 0;
    width: 100%;
    white-space: nowrap;
    line-height: 60px;
}