﻿/* ====================================================
 * site.css — Merged & deduplicated
 * Sources: site.css (original) + site_latest.css
 * ==================================================== */

/* ====================================================
   FONT-FACE
   ==================================================== */
@font-face {
    font-family: "Droid Arabic Kufi";
    src: url("/fonts/DroidArabicKufi.woff2") format("woff2"), url("/fonts/DroidArabicKufi.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Nunito";
    src: url("/fonts/Nunito-ExtraLight.woff2") format("woff2"), url("/fonts/Nunito-ExtraLight.woff") format("woff");
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Nunito";
    src: url("/fonts/Nunito-ExtraLightItalic.woff2") format("woff2"), url("/fonts/Nunito-ExtraLightItalic.woff") format("woff");
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "Open Sans";
    src: url("/fonts/OpenSans-Regular.woff2") format("woff2"), url("/fonts/OpenSans-Regular.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Open Sans";
    src: url("/fonts/OpenSans-Italic.woff2") format("woff2"), url("/fonts/OpenSans-Italic.woff") format("woff");
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("/fonts/Poppins-Light.woff2") format("woff2"), url("/fonts/Poppins-Light.woff") format("woff");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("/fonts/Poppins-Regular.woff2") format("woff2"), url("/fonts/Poppins-Regular.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("/fonts/Poppins-Medium.woff2") format("woff2"), url("/fonts/Poppins-Medium.woff") format("woff");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("/fonts/Poppins-SemiBold.woff2") format("woff2"), url("/fonts/Poppins-SemiBold.woff") format("woff");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Roboto Flex";
    src: url("/fonts/RobotoFlex-Regular.woff2") format("woff2"), url("/fonts/RobotoFlex-Regular.woff") format("woff");
    font-weight: 300 700;
    font-style: normal;
    font-display: swap;
}

/* ====================================================
   CSS CUSTOM PROPERTIES
   ==================================================== */
:root {
    --admin-header-sticky-top: 82px;
    --admin-page-header-current-height: 0px;
    --cp-sticky-gap: 0px;
    --cp-sticky-top: 82px;
    --cp-bottom-actions-offset: 1rem;
    --cp-global-header-height: 60px;
    --cp-addedit-main-height: calc(100vh - var(--cp-global-header-height, 60px));
    --cp-addedit-actions-height: 96px;
}

/* ====================================================
   GLOBAL — FONT & COMPACT SPACING
   ==================================================== */
body {
    font-size: 0.85rem !important;
    line-height: 1.4;
}

h1,
.h1 {
    font-size: 1.5rem;
}

h2,
.h2 {
    font-size: 1.3rem;
}

h3,
.h3 {
    font-size: 1.1rem;
}

h4,
.h4,
h5,
.h5,
h6,
.h6 {
    font-size: 1rem;
}

small,
.small,
.text-muted {
    font-size: 0.8rem;
}

a {
    text-decoration: none !important;
}

.en {
    direction: ltr;
}

.ar {
    direction: rtl;
}

.txt-ar {
    font-family: "Roboto flex", "Droid Arabic Kufi";
}

.txt-en {
    font-family: "Open Sans", sans-serif;
}

.no-scroll {
    overflow: hidden !important;
}

.min-vh-90 {
    min-height: 90vh !important;
}

/* Password / email / number inputs keep Latin font */
input[type="password"],
input[type="email"],
input[type="number"] {
    font-family: Arial, sans-serif !important;
}

/* ====================================================
   BOOTSTRAP OVERRIDES — FORM / BUTTON / CARD
   ==================================================== */
.container-fluid,
.card-body,
.form-control,
.form-select,
.btn {
    font-size: 0.85rem !important;
}

.form-control {
    font-family: "Droid Arabic Kufi", serif;
    color: #495057;
}

.btn {
    padding: 0.25rem 0.6rem !important;
    font-weight: 500;
}

    .btn:disabled,
    .btn.disabled {
        background-color: #999 !important;
        color: #fff !important;
        cursor: not-allowed;
        opacity: 0.65;
    }

.card {
    border-radius: 0.4rem !important;
}

.card-header {
    font-size: 0.9rem !important;
    padding: 0.4rem 0.75rem !important;
}

.header-card h2 {
    font-size: 1.2rem !important;
    margin-bottom: 0.1rem;
}

.header-card small {
    font-size: 0.8rem !important;
    color: #666;
}

/* Required label asterisk — two approaches merged */
label[required]::after,
label:has(+ input[required])::after,
label:has(+ select[required])::after,
label:has(+ textarea[required])::after,
label:has(+ .input-group input[required])::after {
    content: " *";
    color: red;
    display: inline-block;
    font-size: medium;
}

label:has(+ input[required]),
label:has(+ select[required]),
label:has(+ textarea[required]),
label:has(+ .input-group input[required]) {
    position: relative;
}

.modal-title {
    font-weight: 500;
    font-size: 1.2rem;
}

.modal-header {
    padding: 0.8rem 1rem;
}

.modal-body {
    padding: 0.5rem;
}

.modal-backdrop.show {
    opacity: 0.1;
}

.modal-dialog.modal-alert-custom {
    margin-top: 1.5rem;
    margin-bottom: auto;
    width: 100%;
}

.btn-outline-warning {
    color: #dfa802;
    border-color: #dfa802;
}

/* ====================================================
   BTN-MAIN  (primary brand colour)
   ==================================================== */
.btn-main {
    background-color: #f45035;
    border-color: #f45035;
    color: #fff;
    transition: all 0.2s ease-in-out;
}

    .btn-main:hover {
        background-color: #d63f29;
        border-color: #d63f29;
        color: #fff;
        box-shadow: 0 4px 10px rgba(244, 80, 53, 0.4);
    }

    .btn-main:focus,
    .btn-main:active {
        background-color: #c93a25 !important;
        border-color: #c93a25 !important;
        box-shadow: 0 0 0 0.25rem rgba(244, 80, 53, 0.4);
    }

/* ====================================================
   BREADCRUMB
   ==================================================== */
.breadcrumb {
    --bs-breadcrumb-divider: "/" !important;
}

.breadcrumb-item + .breadcrumb-item::before {
    float: none !important;
    content: "/" !important;
    padding: 0 0.5rem;
    color: var(--bs-breadcrumb-divider-color);
}

[dir="rtl"] .breadcrumb-item + .breadcrumb-item {
    padding-right: 0 !important;
}

.header-card {
    background: #f45035;
    color: white;
    padding: 15px;
}

    .header-card .breadcrumb {
        background: transparent;
        margin-bottom: 0;
    }

    .header-card .breadcrumb-item + .breadcrumb-item::before {
        color: rgba(255, 255, 255, 0.7);
    }

    .header-card .breadcrumb-item a {
        color: white;
        text-decoration: none;
    }

    .header-card .breadcrumb-item.active {
        color: #fff;
        font-weight: 600;
    }

/* ====================================================
   NAV PILLS
   ==================================================== */
.nav-pills .nav-link {
    padding: 0.5rem 1rem;
    font-weight: 500;
    transition: all 0.2s ease-in-out;
}

    .nav-pills .nav-link:hover {
        background-color: #f8f9fa;
        color: #f45035;
        transform: translateY(-2px);
        box-shadow: 0 2px 8px rgba(244, 80, 53, 0.2);
    }

    .nav-pills .nav-link.active {
        background-color: #f45035;
        color: #fff;
        box-shadow: 0 4px 12px rgba(244, 80, 53, 0.4);
    }

/* ====================================================
   TOGGLE CARD
   ==================================================== */
.toggle-card {
    cursor: pointer;
    background-color: #fff;
    border: 1px solid #e9ecef;
    border-radius: 0.5rem;
    transition: background-color 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

    .toggle-card .form-check-input:checked {
        background-color: #198754 !important;
        border-color: #198754 !important;
    }

    .toggle-card:has(.form-check-input:checked) {
        background-color: #d1e7dd;
        border-color: #198754;
        box-shadow: 0 6px 18px rgba(25, 135, 84, 0.14);
    }

        .toggle-card:has(.form-check-input:checked) .form-check-label {
            color: #155724;
            font-weight: 600;
        }

/* ====================================================
   PERMISSION BOX
   ==================================================== */
.permission-box {
    transition: all 0.2s ease-in-out;
    cursor: pointer;
    border-radius: 0.75rem;
}

    .permission-box:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    }

    .permission-box.bg-success {
        color: #fff;
    }

    .permission-box.bg-warning {
        border: 1px solid #ffeeba !important;
        color: #fff;
    }

    .permission-box.border-warning {
        border-color: #ffc107 !important;
    }

/* ====================================================
   SELECT2 — TYPOGRAPHY + RTL FIXES
   ==================================================== */

/* Global font size (single source of truth) */
.select2-container--bootstrap-5 .select2-selection,
.select2-container--bootstrap-5 .select2-selection__rendered,
.select2-container--bootstrap-5 .select2-selection__placeholder,
.select2-container--bootstrap-5 .select2-results__option,
.select2-container--bootstrap-5 .select2-search__field,
.select2-container .select2-selection--single .select2-selection__rendered,
.select2-container .select2-results__option,
.select2-container .select2-search__field {
    font-size: 0.85rem !important;
    line-height: 1.35 !important;
}

/* Single select RTL — move arrow & clear to left */
.select2-container[dir="rtl"]
.select2-selection--single
.select2-selection__arrow,
.select2-container[dir="rtl"]
.select2-selection--single
.select2-selection__clear {
    right: auto;
    left: 1rem;
}

.select2-container[dir="rtl"]
.select2-selection--single
.select2-selection__rendered {
    padding-right: 0.75rem;
    padding-left: 2.5rem;
    text-align: right;
}

/* Multiple select RTL — × on right side of chip */
[dir="rtl"]
.select2-container--bootstrap-5
.select2-selection--multiple
.select2-selection__rendered
.select2-selection__choice {
    flex-direction: row-reverse;
    margin-right: 0;
    margin-left: 0.375rem;
}

    [dir="rtl"]
    .select2-container--bootstrap-5
    .select2-selection--multiple
    .select2-selection__rendered
    .select2-selection__choice
    .select2-selection__choice__remove {
        margin-right: 0.35rem;
        margin-left: 0;
    }

/* RTL: "Clear all" × button — move to left side */
[dir="rtl"] .select2-container--bootstrap-5
.select2-selection--multiple
.select2-selection__clear {
    right: auto !important;
    left: 0.75rem !important;
}

/* Multiple choice chip font size (override theme 1rem) */
.select2-container--bootstrap-5
.select2-selection--multiple
.select2-selection__rendered
.select2-selection__choice {
    font-size: 0.85rem !important;
}

/* Validation error border */
.select2-container--bootstrap-5.select2-validation-error .select2-selection,
.select2-container--bootstrap-5 .select2-selection.is-invalid {
    border-color: var(--bs-form-invalid-border-color, #dc3545) !important;
    box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.16) !important;
}

/* ====================================================
   DATATABLES — COMPACT STYLING
   ==================================================== */
table.dataTable {
    font-size: 0.85rem !important;
    border-collapse: collapse !important;
}

    table.dataTable th,
    table.dataTable td {
        padding: 0.4rem 0.5rem !important;
        vertical-align: middle !important;
        white-space: nowrap;
    }

    table.dataTable thead th {
        background-color: #f8f9fa !important;
        font-weight: 700;
        text-align: start !important;
    }

    table.dataTable tbody td {
        font-weight: 600;
    }

    table.dataTable th.dt-type-numeric,
    table.dataTable th.dt-type-date,
    table.dataTable td.dt-type-numeric,
    table.dataTable td.dt-type-date {
        text-align: start !important;
    }
    /* Multi-row thead */
    table.dataTable thead:has(tr:nth-child(2)) tr:first-child th {
        text-align: center;
        vertical-align: middle;
        font-weight: 700;
    }

    table.dataTable thead:has(tr:nth-child(2)) tr:nth-child(2) th {
        text-align: start;
        font-weight: 600;
    }

    table.dataTable thead:has(tr:nth-child(2)) tr:nth-child(n + 3) th {
        text-align: start;
        font-weight: normal;
    }

.dataTables_length label,
.dataTables_filter label,
.dataTables_info,
.dataTables_paginate {
    font-size: 0.8rem !important;
}

.dataTables_wrapper .form-control {
    height: calc(1.8rem + 2px) !important;
    font-size: 0.8rem !important;
    padding: 0.2rem 0.5rem;
}

.dataTables_wrapper .paginate_button {
    padding: 0.25rem 0.6rem !important;
    font-size: 0.8rem !important;
}

/* ====================================================
   SEARCH CARD AREA
   ==================================================== */
.card-header i {
    font-size: 1rem !important;
}

.card-body form .form-control,
.card-body form .btn {
    font-size: 0.85rem !important;
}

.card-body form .btn {
    padding: 0.3rem 0.75rem;
}

form.row.g-3 {
    row-gap: 0.5rem !important;
}

/* ====================================================
   DROPDOWN / RTL FIXES
   ==================================================== */
.dropdown-toggle::after {
    margin-right: 0.255em !important;
    margin-left: 0;
}

html[dir="rtl"] .header-nav {
    margin-left: 0 !important;
    margin-right: auto !important;
}

html[dir="rtl"] .dropdown-menu-end {
    right: auto;
    left: 0;
}

/* ====================================================
   LOADER OVERLAY  (used by loader-global.js)
   ==================================================== */
.overlay {
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.8);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

    .overlay.show {
        opacity: 1;
        visibility: visible;
    }

/* ====================================================
   INPUT-GROUP PARSLEY
   ==================================================== */
.input-group .parsley-errors-list {
    width: 100%;
    margin-top: 0.25rem;
    margin-bottom: 0;
}

/* ====================================================
   SIDEBAR NAV
   ==================================================== */
.sidebar-nav i.size-default {
    font-size: 14px !important;
}

.sidebar-nav .sub-nav-content a {
    padding: 10px 0 10px 60px;
}

main.main {
    min-height: 80vh;
}

/* ====================================================
   LEGACY COMPONENTS
   ==================================================== */
.cp-item {
    background-color: #fff;
    flex-direction: column;
    margin: 10px;
    padding: 5px;
    border-radius: 4px;
    box-shadow: 1px 1px 8px #ccc;
    transition: all 0.25s ease;
}

    .cp-item:hover {
        background-color: #efefef;
    }

    .cp-item a {
        display: flex;
        flex-direction: column;
        text-decoration: none;
        color: #333;
    }

    .cp-item img {
        align-self: center;
        height: 100px;
        width: auto;
        margin: auto;
    }

.cp-group-header {
    background-color: var(--primary-color);
    color: var(--accent-color);
    font-weight: 500;
    margin-bottom: 5px;
    border-radius: 2px;
}

.content-card {
    background-color: #fff;
    padding: 0;
    border-radius: 10px;
    box-shadow: 1px 1px 8px #ccc;
}

.panel-title {
    color: var(--accent-color);
}

.accent-color {
    color: var(--accent-color);
}

.action-btns-grp {
    direction: ltr;
    text-align: center;
    margin-top: 10%;
}

.close {
    float: right;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    color: #000;
    text-shadow: 0 1px 0 #fff;
    opacity: 0.5;
}

.table-responsive {
    display: table;
}

#mTable tr {
    font-size: 11pt;
}

.card-content .inner-content h4.value {
    margin-right: 5px;
    font-size: 20px;
    color: #012970;
    font-weight: 700;
    padding: 0;
}

/* ====================================================
   DEVEXTREME OVERRIDES
   ==================================================== */
.dx-datagrid-rowsview .dx-center-content {
    text-align: center !important;
}

.dx-left-content .dx-texteditor-input {
    text-align: left !important;
    direction: ltr;
}

.dx-left-content .dx-button-content {
    text-align: left !important;
    direction: ltr;
}

.dx-col-6 .dx-field-item-label,
.dx-col-6 .dx-field-item-content {
    width: 30%;
}

/* ====================================================
   ADMIN PAGE HEADER  (reusable component)
   ==================================================== */
.admin-page-header {
    border-inline-start: 4px solid var(--aph-accent, #f45035);
    transition: padding 0.25s ease, box-shadow 0.25s ease, border-radius 0.25s ease, transform 0.25s ease;
}

    .admin-page-header.is-sticky {
        position: sticky;
        top: var(--admin-header-sticky-top, 82px);
        z-index: 1015;
    }

.admin-page-header__main,
.admin-page-header__icon,
.admin-page-header__title,
.admin-page-header__description,
.admin-breadcrumb-nav {
    transition: all 0.25s ease;
}

.admin-page-header__icon {
    width: 52px;
    height: 52px;
    background: linear-gradient( 135deg, var(--aph-start, #f45035), var(--aph-end, #ff7b5e) );
}

.admin-page-header__description {
    display: inline-block;
    margin-top: 0.2rem;
}

.admin-breadcrumb-nav {
    border-top: 1px solid #f2f4f7;
    padding-top: 0.75rem;
}

.admin-breadcrumb {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    padding: 0;
    margin: 0;
}

.admin-breadcrumb-item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.78rem;
    color: #7f8b9a;
}

    .admin-breadcrumb-item + .admin-breadcrumb-item::before {
        content: "\f285";
        font-family: bootstrap-icons !important;
        font-size: 0.64rem;
        color: #b5bdc8;
    }

    .admin-breadcrumb-item a,
    .admin-breadcrumb-item span {
        display: inline-flex;
        align-items: center;
        min-height: 28px;
        padding: 0.25rem 0.65rem;
        border-radius: 999px;
        border: 1px solid #e6eaf0;
        background: #f8fafc;
    }

    .admin-breadcrumb-item a {
        color: #5e6b7d;
        transition: all 0.2s ease;
    }

        .admin-breadcrumb-item a:hover {
            color: #f45035;
            border-color: #ffd8cf;
            background: #fff6f3;
        }

    .admin-breadcrumb-item.active span {
        color: #f45035;
        border-color: #ffd8cf;
        background: #fff4f0;
        font-weight: 700;
    }

/* Compact mode */
.admin-page-header.is-compact {
    padding-top: 0.55rem !important;
    padding-bottom: 0.55rem !important;
    border-radius: 0.75rem !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08) !important;
}

    .admin-page-header.is-compact .admin-page-header__icon {
        width: 40px;
        height: 40px;
    }

        .admin-page-header.is-compact .admin-page-header__icon i {
            font-size: 1rem !important;
        }

    .admin-page-header.is-compact .admin-page-header__title {
        font-size: 1.03rem;
    }

    .admin-page-header.is-compact .admin-page-header__description {
        margin-top: 0;
        max-height: 0;
        opacity: 0;
        overflow: hidden;
    }

    .admin-page-header.is-compact .admin-breadcrumb-nav {
        margin-top: 0.35rem !important;
        padding-top: 0.4rem;
    }

    .admin-page-header.is-compact .admin-breadcrumb-item {
        font-size: 0.72rem;
    }

        .admin-page-header.is-compact .admin-breadcrumb-item a,
        .admin-page-header.is-compact .admin-breadcrumb-item span {
            min-height: 24px;
            padding: 0.15rem 0.55rem;
        }

.admin-page-stack {
    width: 100%;
    margin-bottom: 3rem;
}

    .admin-page-stack.is-sticky {
        position: sticky;
        top: var(--admin-header-sticky-top, 82px);
        z-index: 1014;
    }

.admin-page-stack__surface {
    display: grid;
    gap: 0.75rem;
    width: 100%;
}

.admin-page-stack__header > .admin-page-header {
    margin-bottom: 0 !important;
}

.admin-page-stack.is-compact .admin-page-header {
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08) !important;
}

/* ====================================================
   CHILDPARENTS ADD/EDIT
   ==================================================== */
.civilid-counter {
    font-size: 0.72rem;
    color: #8b93a1;
}

    .civilid-counter.is-complete {
        color: #198754;
        font-weight: 600;
    }

#main.cp-main-tight-top {
    padding-top: 0 !important;
}

body.cp-addedit-scroll-lock {
    overflow: hidden;
}

    body.cp-addedit-scroll-lock #main {
        box-sizing: border-box;
        height: var(--cp-addedit-main-height);
        max-height: var(--cp-addedit-main-height);
        overflow: hidden;
        margin-top: 20px !important;
    }

    body.cp-addedit-scroll-lock #footer,
    body.cp-addedit-scroll-lock .back-to-top {
        display: none !important;
    }

.cp-addedit-page-shell {
    height: 100%;
    min-height: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 1rem;
    margin-top: 0 !important;
    padding-inline: clamp(0.75rem, 2vw, 1.5rem) !important;
    padding-bottom: 0;
    overflow: hidden;
}

.cp-addedit-form {
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 1rem;
    overflow: hidden;
}

.cp-form-scroll-region {
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
    scroll-behavior: smooth;
    padding-inline: 0.2rem;
    padding-block-end: 0.75rem;
}

.cp-form-scroll-region__inner {
    min-height: min-content;
    padding-bottom: 0.5rem;
}

.cp-admin-page-stack__surface {
    gap: 0.5rem;
}

/* Section navigator */
.cp-section-navigator-wrap {
    display: grid;
    gap: 0.65rem;
}

.cp-section-navigator {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.5rem;
    align-items: center;
    padding: 0.75rem 0.85rem;
    border: 1px solid #e7ecf3;
    border-radius: 0.85rem;
    background: #fff;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.05);
    overflow-x: auto;
    scrollbar-width: thin;
}

    .cp-section-navigator::-webkit-scrollbar {
        height: 6px;
    }

    .cp-section-navigator::-webkit-scrollbar-thumb {
        background: #d8e0ea;
        border-radius: 999px;
    }

.cp-section-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex: 0 0 auto;
    border: 1px solid #d7dfeb;
    border-radius: 999px;
    padding: 0.3rem 0.8rem;
    font-size: 0.8rem;
    color: #4f6074;
    background: #f8fafd;
    transition: all 0.2s ease;
}

    .cp-section-link:hover {
        border-color: #f45035;
        color: #f45035;
        background: #fff4f0;
    }

    .cp-section-link.is-active {
        border-color: #f45035;
        background: #f45035;
        color: #fff;
    }

    .cp-section-link .cp-section-dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #b9c4d3;
    }

    .cp-section-link.is-ready .cp-section-dot {
        background: #1f9d65;
    }

    .cp-section-link.is-error .cp-section-dot {
        background: #dc3545;
    }

    .cp-section-link.is-active .cp-section-dot {
        background: #fff;
    }

.cp-section-draft-btn {
    flex: 0 0 auto;
    margin-inline-start: auto;
    white-space: nowrap;
}

.cp-section-toggle .cp-chevron {
    transition: transform 0.2s ease;
}

.cp-section-toggle.is-collapsed .cp-chevron {
    transform: rotate(-90deg);
}

.cp-entry-section {
    border: 1px solid #e7ecf3;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.cp-section-ready {
    border-color: #b9ebd3;
}

.cp-section-optional {
    border-color: #e7ecf3;
}

.cp-section-attention {
    border-color: #f3b3ba;
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.08);
}

.cp-section-status {
    font-size: 0.72rem;
    border: 1px solid transparent;
}

.cp-status-ready {
    color: #1f9d65 !important;
    background: #e8f7ef;
    border-color: #b8e9cf;
}

.cp-status-optional {
    color: #6c7b8d !important;
    background: #f2f5f9;
    border-color: #e1e8f1;
}

.cp-status-attention {
    color: #b42331 !important;
    background: #fcecef;
    border-color: #f6c7ce;
}

.cp-feedback {
    display: none;
    font-size: 0.76rem;
}

.cp-warning-feedback {
    display: none;
    color: #b26a00;
    font-size: 0.76rem;
}

/* Form validation styles */
#childParentForm .form-control.is-valid,
#childParentForm .form-select.is-valid {
    border-color: #25a56a;
    background-image: none;
    box-shadow: 0 0 0 0.12rem rgba(37, 165, 106, 0.12);
}

#childParentForm .form-control.is-invalid,
#childParentForm .form-select.is-invalid {
    border-color: #dc3545;
    background-image: none;
    box-shadow: 0 0 0 0.12rem rgba(220, 53, 69, 0.12);
}

#childParentForm .form-control.is-warning,
#childParentForm .form-select.is-warning {
    border-color: #f0ad4e;
    background-image: none;
    box-shadow: 0 0 0 0.12rem rgba(240, 173, 78, 0.18);
}

#formValidationSummary,
.cp-section-summary {
    border: 1px solid #f6c7ce;
    background: #fff7f8;
    color: #8f1f2c;
}

.cp-form-summary {
    margin-top: 0.55rem;
    max-height: 180px;
    overflow: auto;
}

.cp-summary-list {
    margin: 0;
    padding-inline-start: 1.15rem;
}

.cp-form-actions-bar {
    position: relative;
    z-index: 1011;
    margin-top: 0;
    padding-bottom: var(--cp-bottom-actions-offset, 1rem);
}

.cp-form-actions-bar__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
    border: 1px solid #e5ebf2;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
    backdrop-filter: blur(10px);
}

/* ====================================================
   DELETE CONFIRM MODAL
   ==================================================== */
.delete-confirm-modal {
    border: 0;
    border-radius: 1.35rem;
    box-shadow: 0 1.5rem 3rem rgba(15, 23, 42, 0.16);
}

.delete-confirm-icon-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 1rem;
}

.delete-confirm-icon {
    width: 4.25rem;
    height: 4.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 1.25rem;
    background: linear-gradient( 135deg, rgba(220, 53, 69, 0.12), rgba(255, 111, 89, 0.2) );
    color: #dc3545;
    font-size: 1.5rem;
    box-shadow: inset 0 0 0 1px rgba(220, 53, 69, 0.12);
}

.delete-confirm-title {
    font-weight: 700;
    color: #1f2937;
}

.delete-confirm-message {
    color: #374151;
    font-size: 0.98rem;
}

.delete-confirm-hint {
    color: #6b7280;
    font-size: 0.875rem;
}

.delete-confirm-modal .modal-footer {
    justify-content: center;
    gap: 0.75rem;
}

/* ====================================================
   GENERIC FORM ALERT LIST
   ==================================================== */
.generic-form-alert-list {
    margin-bottom: 0;
    padding-inline-start: 1.25rem;
}

/* ====================================================
   CHILD CLASSROOM PAGE
   ==================================================== */
.chk-scale {
    transform: scale(1.4);
    transform-origin: center;
    cursor: pointer;
    margin-top: 2px;
    width: 1em;
    height: 1em;
}

.child-row {
    border-bottom: 1px solid #eaeaea;
}

.check-col {
    flex: 0 0 48px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.child-info {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.childFullName {
    min-width: 140px;
}

.badgeHost {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.25rem;
}

    .badgeHost .badge {
        font-weight: 600;
        border-radius: 0.5rem;
        padding: 0.4rem 0.6rem;
        white-space: nowrap;
    }

.classroom-full {
    width: 100%;
    margin: 0;
}

.classroom-grid {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.classroom-option {
    display: flex;
    align-items: center;
    padding: 0.55rem 0.9rem;
    background-color: #f9f9f9;
    border: 1px solid #dee2e6;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

    .classroom-option:hover {
        background-color: #f1f1f1;
        border-color: #bbb;
    }

    .classroom-option.active {
        background-color: #e9f7ff;
        border-color: #0d6efd;
    }

    .classroom-option.no-classroom {
        background-color: #fff0f0;
        border-color: #f5c2c7;
    }

        .classroom-option.no-classroom.active {
            background-color: #f8d7da;
            border-color: #dc3545;
        }

    .classroom-option input[type="radio"] {
        accent-color: #0d6efd;
        margin-inline-end: 0.6rem;
        transform: scale(1.2);
        cursor: pointer;
    }

.classroom-label {
    flex: 1;
    font-weight: 500;
    color: #212529;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ====================================================
   RESPONSIVE
   ==================================================== */
@media (max-width: 992px) {
    .classroom-full .col-lg-4 {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .child-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .childFullName {
        text-align: center;
        width: 100%;
    }

    .badgeHost {
        justify-content: center;
    }
}

@media (max-width: 991.98px) {
    .admin-page-header.is-sticky,
    .admin-page-stack.is-sticky {
        top: calc(var(--admin-header-sticky-top, 70px) - 2px);
    }

    .admin-page-header__main {
        align-items: flex-start !important;
    }

    .admin-page-header.is-compact .admin-page-header__title {
        font-size: 0.95rem;
    }

    .cp-addedit-page-shell {
        padding-inline: 0.75rem !important;
    }

    .cp-section-navigator {
        padding: 0.65rem;
    }

    .cp-section-link {
        font-size: 0.74rem;
        padding: 0.28rem 0.65rem;
    }

    .cp-section-draft-btn {
        width: 100%;
        justify-content: center;
        margin-inline-start: 0;
    }

    .cp-form-actions-bar__inner {
        justify-content: stretch;
        padding: 0.8rem;
    }

        .cp-form-actions-bar__inner .btn {
            width: 100%;
        }
}

@media (max-width: 767.98px) {
    .admin-page-stack__surface {
        gap: 0.65rem;
    }

    body.cp-addedit-scroll-lock #main {
        padding-inline: 0.75rem !important;
        padding-bottom: 0.75rem !important;
    }

    .admin-page-header {
        padding: 0.9rem 1rem !important;
        border-radius: 0.95rem !important;
    }

    .admin-page-header__main {
        flex-direction: column;
        justify-content: flex-start !important;
        gap: 0.85rem !important;
    }

        .admin-page-header__main > div:last-child {
            width: 100%;
        }

            .admin-page-header__main > div:last-child .btn,
            .admin-page-header__main > div:last-child a.btn {
                width: 100%;
            }

    .admin-breadcrumb-nav {
        margin-top: 0.65rem !important;
        padding-top: 0.65rem;
    }
}
