/* COC Permits — Branded Login / Register Page */

/* ── Page background ──────────────────────────────────────────────────────── */
html {
    background: #f4f6fa !important;
}

body.login {
    background: #f4f6fa !important;
    font-family: 'Public Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
}

/* ── Logo ─────────────────────────────────────────────────────────────────── */
#login h1 a,
.login h1 a {
    background-image: url('../../uploads/2025/03/cottleville_logo.png') !important;
    background-size: contain !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    width: 260px !important;
    height: 90px !important;
    margin-bottom: 8px !important;
}

/* ── Tagline under logo ───────────────────────────────────────────────────── */
.coc-login-tagline {
    text-align: center;
    color: #2B3E84;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin: 0 0 20px;
}

/* ── Form box ─────────────────────────────────────────────────────────────── */
#login,
.login #loginform,
.login #registerform,
.login #lostpasswordform {
    padding: 0 !important;
}

.login form,
#loginform,
#registerform,
#lostpasswordform {
    background: #fff !important;
    border: none !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 24px rgba(43,62,132,.10) !important;
    padding: 36px 36px 28px !important;
    margin-top: 0 !important;
}

/* ── Form heading (register type label) ───────────────────────────────────── */
.coc-reg-heading {
    text-align: center;
    color: #2B3E84;
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 20px;
}

/* ── Account type toggle ──────────────────────────────────────────────────── */
.coc-account-type {
    display: flex;
    gap: 10px;
    margin-bottom: 22px;
}
.coc-account-type label {
    flex: 1;
    border: 2px solid #dde1ea;
    border-radius: 8px;
    padding: 12px 10px;
    text-align: center;
    cursor: pointer;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #555 !important;
    transition: border-color .2s, background .2s, color .2s;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: auto !important;
    float: none !important;
}
.coc-account-type input[type="radio"] {
    display: none !important;
}
.coc-account-type label .coc-type-icon {
    font-size: 22px;
    line-height: 1;
}
.coc-account-type input[type="radio"]:checked + label,
.coc-account-type label.active {
    border-color: #2B3E84;
    background: #eef1fa;
    color: #2B3E84 !important;
}

/* ── Field rows ───────────────────────────────────────────────────────────── */
.coc-field-row {
    display: flex;
    gap: 14px;
}
.coc-field-row .form-group {
    flex: 1;
}

/* ── Form paragraph spacing (WP wraps each field in <p>) ─────────────────── */
.login form p,
#registerform p,
#loginform p {
    margin: 0 0 16px !important;
    padding: 0 !important;
}
.login form p:last-child {
    margin-bottom: 0 !important;
}

/* ── Standard WP label/input overrides ───────────────────────────────────── */
.login label {
    font-size: 13px !important;
    color: #374151 !important;
    font-weight: 600 !important;
    margin-bottom: 4px !important;
}
.login input[type="text"],
.login input[type="email"],
.login input[type="password"],
.login input[type="tel"] {
    border: 1.5px solid #d1d5db !important;
    border-radius: 7px !important;
    padding: 10px 12px !important;
    font-size: 14px !important;
    box-shadow: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: border-color .2s !important;
    height: auto !important;
}
.login input[type="text"]:focus,
.login input[type="email"]:focus,
.login input[type="password"]:focus,
.login input[type="tel"]:focus {
    border-color: #2B3E84 !important;
    box-shadow: 0 0 0 3px rgba(43,62,132,.12) !important;
    outline: none !important;
}

/* ── Business fields (hidden by default) ──────────────────────────────────── */
.coc-business-fields {
    display: none;
}
.coc-business-fields.visible {
    display: block;
}

/* ── Submit button ────────────────────────────────────────────────────────── */
.login .button-primary,
#login .button-primary {
    background: #2B3E84 !important;
    border: none !important;
    border-radius: 7px !important;
    padding: 11px 20px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: .02em !important;
    box-shadow: none !important;
    width: 100% !important;
    height: auto !important;
    text-shadow: none !important;
    transition: background .2s !important;
}
.login .button-primary:hover,
.login .button-primary:focus {
    background: #1e2d6b !important;
}

/* ── Nav links ────────────────────────────────────────────────────────────── */
#nav, #backtoblog {
    text-align: center !important;
    padding: 0 !important;
}
#nav a, #backtoblog a {
    color: #2B3E84 !important;
    font-size: 13px !important;
}
#nav a:hover, #backtoblog a:hover {
    color: #1e2d6b !important;
    text-decoration: underline !important;
}

/* ── Error / notice messages ─────────────────────────────────────────────── */
.login #login_error,
.login .message,
.login .success {
    border-radius: 7px !important;
    border-left: 4px solid #2B3E84 !important;
    background: #eef1fa !important;
    color: #2B3E84 !important;
    margin-bottom: 16px !important;
}
.login #login_error {
    border-left-color: #c0392b !important;
    background: #fdf2f2 !important;
    color: #c0392b !important;
}

/* ── Divider ──────────────────────────────────────────────────────────────── */
.coc-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 4px 0 16px;
    color: #9ca3af;
    font-size: 12px;
}
.coc-divider::before,
.coc-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #e5e7eb;
}

/* ── Privacy note ─────────────────────────────────────────────────────────── */
.coc-privacy-note {
    font-size: 11px !important;
    color: #9ca3af !important;
    text-align: center;
    margin-top: 10px;
    line-height: 1.5;
}
