/*Admins Dashboard*/
:root {
    --silver: #C7C9C9;
    --ecru: #C0B58E;
    --cambridge: #93A989;
    --hunter: #386939;
    --dark-green: #12341B;
}

.admin-shell {
    min-height: 100vh;
}

.sidebar {
    background-color: var(--dark-green);
    min-height: 100vh;
    color: white;
    padding: 2rem 1rem;
}

.sidebar-brand {
    font-size: 22px;
    text-transform: uppercase;
    margin-bottom: 2rem;
}

.sidebar .nav-link {
    color: rgba(255,255,255,0.88);
    border-radius: 4px;
    padding: 0.9rem 1rem;
    margin-bottom: 0.5rem;
    font-weight: 600;
}

.sidebar .nav-link.active,
.sidebar .nav-link:hover {
    background-color: var(--hunter);
    color: white;
}

.main-panel {
    padding: 2rem;
}

.top-card {
    background-color: var(--cambridge);
    border: none;
    border-radius: 4px;
    color: white;
}

.stat-card {
    border: none;
    border-radius: 4px;
    color: var(--dark-green);
    height: 100%;
}

.stat-card.soft {
    background-color: var(--silver);
}

.stat-card.warm {
    background-color: var(--ecru);
}

.stat-card.green {
    background-color: var(--cambridge);
}

.panel-card {
    background: white;
    border: none;
    border-radius: 4px;
    box-shadow: 0 10px 24px rgba(0,0,0,0.06);
}

.panel-card .text-muted {
    font-size: 1.5rem;
}

.alert {
    font-size: 1.5rem;
}

.section-title {
    color: var(--dark-green);
    font-weight: 700;
    font-size: 2rem;
}

.btn-admin {
    background-color: var(--hunter);
    border: 1px solid var(--hunter);
    color: white;
    border-radius: 4px;
    font-weight: 600;
}

.btn-admin:hover {
    background-color: var(--dark-green);
    border-color: var(--dark-green);
    color: white;
}

.form-select {
    border-radius: 4px;
    font-size: 1.5rem;
    padding-right: 2rem;
    text-align: center;
}

.message-row + .message-row {
    border-top: 1px solid #e9ecef;
}

.message-subject {
    font-weight: 700;
    color: var(--dark-green);
}

.message-preview {
    color: #38433a;
}

.message-meta {
    font-size: 1.15rem;
    color: #5e6a60;
    line-height: 1.5;
}

.pill-service,
.pill-date {
    width: 220px;
    min-height: 92px;
    padding: 0 1rem;
    border-radius: 4px;
    font-weight: 600;
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    box-sizing: border-box;
}

.pill-date {
    line-height: 1.4;
}

@media (max-width: 991px) {
    .sidebar {
        min-height: auto;
        border-radius: 0 0 20px 20px;
    }

    .main-panel {
        padding: 1rem;
    }
}

.small-label {
    font-size: 1.35rem;
    text-transform: uppercase;
    font-weight: 600;
    color: #5e6a60;
    margin-bottom: 0.75rem;
}

.stat-value {
    font-weight: 700;
    color: var(--dark-green);
    font-size: 2.2rem;
}

/*Messages*/
.hero-card {
    background-color: var(--cambridge);
    color: white;
    border: 0;
    border-radius: 4px;
}

.messages-heading {
    font-size: 2.2rem;
    font-weight: 700;
}

.message-row {
    border-bottom: 1px solid #ececec;
    padding: 1.2rem 0;
}

.message-row:last-child {
    border-bottom: 0;
}

.message-subject {
    font-weight: 700;
    font-size: 1.7rem;
    color: var(--dark-green);
    line-height: 1.3;
}

.message-meta {
    color: #5f6b66;
    font-size: 1.15rem;
    line-height: 1.5;
}

.message-preview {
    color: #33413d;
    line-height: 1.6;
    font-size: 1.15rem;
}

 .read-badge {
     background-color: #93A989;
     color: white;
 }

#reply-message {
    font-size: 15px !important;
}

#reply-message::placeholder {
    font-size: 15px !important;
}

.pill-service,
.pill-date {
    display: inline-block;
    padding: 0.55rem 0.8rem;
    border-radius: 999px;
    font-size: 1.3rem;
    font-weight: 600;
}

.top-card {
    position: relative;
    overflow: hidden;
    border: none !important;
    border-radius: 24px !important;
    min-height: 165px;
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0) 30%),
        radial-gradient(circle at 86% 16%, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 28%),
        linear-gradient(135deg, #7f946f 0%, #72885f 45%, #63784f 100%) !important;
    box-shadow: 0 16px 36px rgba(24, 49, 30, 0.14);
}

.top-card::before {
    content: "";
    position: absolute;
    left: -8%;
    bottom: -95px;
    width: 72%;
    height: 220px;
    background: rgba(52, 78, 46, 0.18);
    border-radius: 50%;
    filter: blur(2px);
}

.top-card::after {
    content: "";
    position: absolute;
    right: -6%;
    top: -70px;
    width: 360px;
    height: 220px;
    background: rgba(255, 255, 255, 0.09);
    border-radius: 50%;
}

.top-card .card-body {
    position: relative;
    z-index: 2;
    padding: 34px 42px !important;
}

.top-card h1,
.top-card h2 {
    text-align: left !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
    font-size: 34px !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    letter-spacing: 2px;
    margin-bottom: 12px;
    line-height: 1.15;
    text-transform: uppercase;
}

.top-card p {
    text-align: left !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
    font-size: 18px;
    color: rgba(255, 255, 255, 0.92) !important;
    margin-bottom: 0;
}

.top-card .text-end {
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 18px;
    padding: 18px 24px;
    min-width: 260px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.top-card .fw-semibold {
    color: #ffffff !important;
    font-size: 20px;
    letter-spacing: 1px;
}

.top-card .small {
    color: rgba(255, 255, 255, 0.88) !important;
    font-size: 15px;
}

.admin-list-card {
    background: #ffffff;
    border: none;
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(24, 49, 30, 0.06);
    padding: 28px 32px;
    margin-bottom: 32px;
}

.admin-list-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 28px;
}

.admin-list-title {
    font-size: 26px;
    font-weight: 800;
    color: #0f2f1a;
    letter-spacing: 5px;
    text-transform: uppercase;
    margin: 0;
}

.admin-filter-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.admin-filter-bar .input {
    margin-bottom: 0;
}

.admin-search-input,
.admin-select-input {
    height: 46px;
    border: 1px solid #d8ded5;
    border-radius: 8px;
    padding: 0 16px;
    font-size: 16px;
    color: #333;
    background: #fff;
}

.admin-search-input {
    min-width: 260px;
}

.admin-select-input {
    min-width: 150px;
}

.admin-reset-btn {
    height: 46px;
    border-radius: 8px;
    border: none;
    padding: 0 18px;
    background: #6b7280;
    color: #ffffff !important;
    font-size: 16px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-table thead th {
    color: #111827;
    font-size: 17px;
    font-weight: 800;
    padding: 18px 14px;
    border-bottom: 1px solid #dfe5dc;
    white-space: nowrap;
}

.admin-table tbody td {
    font-size: 16px;
    color: #111827;
    padding: 18px 14px;
    border-bottom: 1px solid #edf0eb;
    vertical-align: middle;
}

.admin-table tbody tr:hover {
    background: #f7faf5;
}

.admin-action-btn {
    min-width: 110px;
    height: 42px;
    border-radius: 8px;
    background: #3f7f4f;
    color: #ffffff !important;
    border: none;
    text-decoration: none;
    padding: 0 18px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 1px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-transform: none;
}

.admin-action-btn:hover {
    background: #346b42;
    color: #ffffff !important;
}

.admin-action-btn.disabled,
.admin-action-btn:disabled {
    background: #9ca3af;
    cursor: not-allowed;
}

.booking-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 92px;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 700;
}

.booking-status.status-paid {
    background: #dff0df;
    color: #2f6f3e;
}

.booking-status.status-unpaid {
    background: #f7e5e5;
    color: #9b2c2c;
}

.status-upcoming {
    background: #e8f0e3;
    color: #315c35;
}

.status-completed {
    background: #e5e7eb;
    color: #374151;
}

.status-paid {
    background: #dff0df;
    color: #2f6f3e;
}

.status-unpaid {
    background: #f7e5e5;
    color: #9b2c2c;
}

.status-cancelled {
    background: #f7e5e5;
    color: #9b2c2c;
}

.admin-select-input {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    background-color: #ffffff !important;
    background-image: none !important;

    height: 46px;
    min-width: 150px;
    border: 1px solid #d8ded5;
    border-radius: 10px;
    padding: 0 38px 0 16px;
    font-size: 16px;
    color: #374151;
}

.admin-pagination {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 24px;
}

.admin-pagination .pagination {
    justify-content: center;
    margin-bottom: 0;
}

.admin-pagination-count {
    text-align: center;
    color: #6b7280;
    font-size: 15px;
    margin: 0;
}

.admin-action-btn {
    min-width: 110px;
    height: 42px;
    border-radius: 8px;
    background-color: #2f8f6b !important;
    border: 1px solid #2f8f6b !important;
    color: #ffffff !important;
    text-decoration: none;
    padding: 10px 22px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 1px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-transform: none;
    transition: all 0.18s ease;
    box-shadow: 0 4px 10px rgba(47, 143, 107, 0.25) !important;
}

.admin-action-btn:hover {
    background-color: #287a5c !important;
    border-color: #287a5c !important;
    color: #ffffff !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(47, 143, 107, 0.32) !important;
}

.admin-action-btn:active {
    background-color: #2f8f6b !important;
    border-color: #2f8f6b !important;
    color: #ffffff !important;
    transform: translateY(1px);
    box-shadow: 0 2px 5px rgba(47, 143, 107, 0.25) !important;
}

.admin-action-btn:focus,
.admin-action-btn:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.22) !important;
}

.admin-action-btn.disabled,
.admin-action-btn:disabled {
    background: #9ca3af !important;
    border-color: #9ca3af !important;
    cursor: not-allowed;
    box-shadow: none !important;
}

.admin-action-btn.small {
    min-width: 64px;
    height: 36px;
    padding: 0 14px;
    font-size: 14px;
    border-radius: 7px;
    box-shadow: 0 4px 10px rgba(47, 143, 107, 0.18) !important;
}

.admin-action-btn.small + .admin-action-btn.small {
    margin-left: 6px;
}

.admin-action-btn.outline {
    background: #ffffff !important;
    color: #2f8f6b !important;
    border: 1px solid #bfd3bd !important;
    box-shadow: none !important;
}

.admin-action-btn.outline:hover {
    background: #2f8f6b !important;
    color: #ffffff !important;
    border-color: #2f8f6b !important;
    box-shadow: 0 4px 10px rgba(47, 143, 107, 0.18) !important;
}

.admin-search-form {
    display: flex;
    align-items: center;
    margin: 0;
}

.admin-search-form .input {
    margin: 0;
}

.admin-pagination {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 24px;
}

.admin-pagination .pagination {
    justify-content: center;
    margin-bottom: 0;
    gap: 6px;
}

.admin-pagination .pagination li {
    list-style: none;
}

.admin-pagination .pagination a,
.admin-pagination .pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 36px;
    padding: 0 12px;
    border-radius: 8px;
    color: #3f7f4f;
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
}

.admin-pagination .pagination a:hover {
    background: #e8f0e3;
    color: #315c35;
}

.admin-pagination-count {
    text-align: center;
    color: #6b7280;
    font-size: 15px;
    margin: 0;
}

.content-blocks-card {
    padding: 34px 40px;
}

.content-block-quick-links {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 30px;
    color: #5f6b66;
    font-size: 16px;
}

.content-block-quick-links span {
    font-weight: 700;
    color: #33413d;
}

.content-block-quick-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 72px;
    height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: #e8f0e3;
    color: #315c35;
    font-weight: 700;
    text-decoration: none;
    font-size: 14px;
    transition: all 0.18s ease;
}

.content-block-quick-links a:hover {
    background: #2f8f6b;
    color: #ffffff;
}

.content-block-section {
    margin-top: 28px;
}

.content-block-section h3 {
    font-size: 22px;
    font-weight: 800;
    color: #0f2f1a;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 14px;
}

.content-block-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.content-block-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    padding: 22px 24px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 6px 16px rgba(24, 49, 30, 0.04);
    transition: all 0.18s ease;
}

.content-block-item:hover {
    background: #f7faf5;
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(24, 49, 30, 0.07);
}

.content-block-text h4 {
    margin: 0 0 6px;
    color: #111827;
    font-size: 18px;
    font-weight: 700;
}

.content-block-text p {
    margin: 0;
    color: #7a837d;
    font-size: 15px;
    line-height: 1.5;
}

.content-block-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.content-edit-card {
    padding: 34px 40px;
}

.content-edit-description {
    margin-top: 10px;
    margin-bottom: 0;
    color: #6b7280;
    font-size: 16px;
    line-height: 1.5;
}

.content-editor-wrapper {
    margin-top: 24px;
}

.content-text-input {
    width: 100%;
    max-width: 700px;
}

.content-html-input {
    width: 100%;
    min-height: 360px;
}

.content-editor-wrapper .ck-editor {
    width: 100%;
}

.content-editor-wrapper .ck-toolbar {
    border-radius: 10px 10px 0 0 !important;
    border-color: #d8ded5 !important;
}

.content-editor-wrapper .ck-editor__editable {
    border-color: #d8ded5 !important;
    border-radius: 0 0 10px 10px !important;
    font-size: 16px;
    line-height: 1.6;
}

.content-editor-wrapper .ck-editor__editable:focus {
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16) !important;
    border-color: #2f8f6b !important;
}

.content-edit-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 24px;
}

.content-image-preview-wrap {
    margin-bottom: 18px;
    padding: 18px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #f7faf5;
}

.content-image-preview {
    max-width: 260px;
    border-radius: 12px;
    display: block;
}

.content-file-input {
    font-size: 16px;
}

.content-edit-actions .admin-action-btn,
.content-edit-actions button.admin-action-btn,
.content-edit-actions a.admin-action-btn {
    min-width: 120px;
    height: 44px;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    margin: 0 !important;
}

.admin-message-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.admin-message-item {
    display: grid;
    grid-template-columns: 260px 1fr 260px;
    gap: 24px;
    align-items: center;
    padding: 22px 24px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 6px 16px rgba(24, 49, 30, 0.04);
    transition: all 0.18s ease;
}

.admin-message-item:hover {
    background: #f7faf5;
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(24, 49, 30, 0.07);
}

.admin-message-customer h3 {
    margin: 0 0 4px;
    color: #111827;
    font-size: 17px;
    font-weight: 800;
}

.admin-message-customer p {
    margin: 0 0 4px;
    color: #6b7280;
    font-size: 14px;
}

.admin-message-customer span {
    display: block;
    color: #6b7280;
    font-size: 13px;
}

.message-status-badge {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin-top: 10px;
    padding: 5px 13px;
    border-radius: 999px;
    font-size: 12px !important;
    font-weight: 700;
}

.message-status-read {
    background: #e8f0e3;
    color: #315c35 !important;
}

.message-status-unread {
    background: #f7e5e5;
    color: #9b2c2c !important;
}

.message-status-replied {
    background: #dff0df;
    color: #2f6f3e !important;
}

.admin-message-preview h4 {
    margin: 0 0 8px;
    color: #111827;
    font-size: 16px;
    font-weight: 700;
    font-family: "Inter", sans-serif;
}

.admin-message-preview p {
    margin: 0;
    color: #4b5563;
    font-size: 15px;
    line-height: 1.5;
}

.admin-message-action {
    display: grid;
    grid-template-columns: 90px 170px;
    align-items: center;
    justify-content: end;
    column-gap: 18px;
}

.admin-message-action .admin-action-btn {
    width: 90px !important;
    min-width: 90px !important;
    height: 42px !important;
    padding: 0 !important;
    justify-self: start;
}

.admin-message-date {
    width: 170px;
    text-align: left;
    color: #111827;
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
}

@media (max-width: 1100px) {
    .admin-message-item {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .admin-message-action {
        justify-content: flex-start;
    }
}

.admin-list-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    flex-wrap: nowrap;
}

.admin-list-title {
    margin: 0;
    flex-shrink: 0;
}

#messageFilterForm {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: nowrap;
    margin: 0;
}

#messageFilterForm .admin-search-input {
    width: 320px;
    min-width: 320px;
}

#messageFilterForm #sort {
    width: 130px;
    min-width: 130px;
    max-width: 130px;
}

#messageFilterForm #status {
    width: 95px;
    min-width: 95px;
    max-width: 95px;
}

.enquiry-detail-card {
    padding: 34px 40px;
}

.enquiry-subtitle {
    margin: 8px 0 0;
    color: #6b7280;
    font-size: 15px;
    font-weight: 600;
}

.enquiry-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-top: 26px;
}

.enquiry-detail-item {
    padding: 18px 20px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #f7faf5;
}

.enquiry-detail-item span {
    display: block;
    margin-bottom: 6px;
    color: #6b7280;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.enquiry-detail-item strong {
    color: #111827;
    font-size: 16px;
    font-weight: 700;
}

.enquiry-section {
    margin-top: 30px;
}

.enquiry-section h3 {
    margin-bottom: 12px;
    color: #0f2f1a;
    font-size: 20px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.enquiry-text-box {
    min-height: 70px;
    padding: 20px 22px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #ffffff;
    color: #374151;
    font-size: 16px;
    line-height: 1.6;
    box-shadow: 0 6px 16px rgba(24, 49, 30, 0.04);
}

.enquiry-message-box {
    min-height: 110px;
}

.enquiry-status-select {
    width: 160px;
    min-width: 160px;
}

.enquiry-reply-textarea {
    width: 100%;
    min-height: 120px;
    padding: 16px 18px;
    border: 1px solid #d8ded5;
    border-radius: 12px;
    color: #374151;
    font-size: 16px;
    line-height: 1.6;
    resize: vertical;
}

.enquiry-reply-textarea:focus {
    outline: none;
    border-color: #2f8f6b;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16);
}

.enquiry-reply-date {
    margin-top: 10px;
    margin-bottom: 0;
    color: #6b7280;
    font-size: 14px;
}

@media (max-width: 900px) {
    .enquiry-detail-grid {
        grid-template-columns: 1fr;
    }
}

.enquiry-status-form {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: 0;
}

.enquiry-status-form .input {
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
}

.enquiry-status-form .admin-select-input,
.enquiry-status-form select {
    width: 170px !important;
    min-width: 170px !important;
    height: 44px !important;
    padding: 0 18px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
    font-size: 15px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
}

.enquiry-status-form .admin-action-btn,
.enquiry-status-form button.admin-action-btn {
    min-width: 170px !important;
    height: 44px !important;
    padding: 0 22px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
    font-size: 15px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    vertical-align: middle !important;
}

.enquiry-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 18px;
    flex-wrap: wrap;
}

.enquiry-actions .admin-action-btn,
.enquiry-actions button.admin-action-btn,
.enquiry-actions a.admin-action-btn {
    min-width: 170px !important;
    height: 44px !important;
    padding: 0 22px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
    font-size: 15px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    vertical-align: middle !important;
    text-decoration: none !important;
}

.enquiry-actions a.admin-action-btn {
    min-width: 210px !important;
}

.enquiry-status-form .admin-action-btn:hover,
.enquiry-actions .admin-action-btn:hover {
    transform: translateY(-1px);
}

.enquiry-status-form .admin-action-btn:active,
.enquiry-actions .admin-action-btn:active {
    transform: translateY(1px);
}

.customer-profile-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 20px;
}

.customer-profile-item {
    padding: 18px 20px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #f7faf5;
}

.customer-profile-item span {
    display: block;
    margin-bottom: 6px;
    color: #6b7280;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.customer-profile-item strong {
    color: #111827;
    font-size: 16px;
    font-weight: 700;
}

.customer-section-card {
    margin-top: 22px;
}

.customer-edit-card {
    padding: 34px 40px;
}

.customer-edit-form .input {
    margin-bottom: 18px;
}

.customer-edit-form label {
    display: block;
    margin-bottom: 8px;
    color: #111827;
    font-size: 16px;
    font-weight: 700;
}

.customer-edit-form input,
.customer-edit-form select {
    width: 100%;
    height: 44px;
    border: 1px solid #d8ded5;
    border-radius: 8px;
    padding: 0 14px;
    color: #374151;
    font-size: 15px;
    background: #ffffff;
}

.customer-edit-form input:focus,
.customer-edit-form select:focus {
    outline: none;
    border-color: #2f8f6b;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16);
}

.customer-edit-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 24px;
    flex-wrap: wrap;
}

.customer-edit-actions .admin-action-btn,
.customer-edit-actions button.admin-action-btn,
.customer-edit-actions a.admin-action-btn {
    min-width: 150px !important;
    height: 44px !important;
    padding: 0 22px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    margin: 0 !important;
}

.admin-empty-text {
    margin: 0;
    color: #6b7280;
    font-size: 15px;
}

.admin-empty-cell {
    color: #6b7280 !important;
    font-size: 15px !important;
    text-align: center;
    padding: 22px !important;
}

@media (max-width: 900px) {
    .customer-profile-grid {
        grid-template-columns: 1fr;
    }
}

.admin-back-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.45);
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.3px;
    text-decoration: none !important;
    transition: all 0.18s ease;
}

.admin-back-link:hover {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.75);
    color: #ffffff !important;
    transform: translateY(-1px);
}

.admin-back-link:active {
    transform: translateY(1px);
}

 .top-card {
     position: relative;
     overflow: hidden;
     border: none;
     border-radius: 24px;
     min-height: 170px;
     background:
         radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0) 30%),
         radial-gradient(circle at 86% 16%, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 28%),
         linear-gradient(135deg, #7f946f 0%, #72885f 45%, #63784f 100%);
     box-shadow: 0 16px 36px rgba(24, 49, 30, 0.14);
 }

.top-card::before {
    content: "";
    position: absolute;
    left: -8%;
    bottom: -95px;
    width: 72%;
    height: 220px;
    background: rgba(52, 78, 46, 0.18);
    border-radius: 50%;
    filter: blur(2px);
}

.top-card::after {
    content: "";
    position: absolute;
    right: -6%;
    top: -70px;
    width: 360px;
    height: 220px;
    background: rgba(255, 255, 255, 0.09);
    border-radius: 50%;
}

.top-card .card-body {
    position: relative;
    z-index: 2;
    padding: 36px 42px !important;
}

.top-card h1 {
    display: block;
    text-align: left !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
    font-size: 38px;
    font-weight: 800;
    color: #ffffff;
    letter-spacing: 2px;
    margin-bottom: 12px;
    line-height: 1.15;
}

.top-card p {
    text-align: left !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
    font-size: 18px;
    color: rgba(255, 255, 255, 0.92);
    margin-bottom: 0;
}

.top-card .text-end {
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 18px;
    padding: 18px 24px;
    min-width: 260px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.top-card .fw-semibold {
    color: #ffffff;
    font-size: 20px;
    letter-spacing: 1px;
}

.top-card .small {
    color: rgba(255, 255, 255, 0.88);
    font-size: 15px;
}

.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}

.dashboard-title {
    font-size: 36px;
    font-weight: 800;
    color: #111827;
    margin-bottom: 6px;
    letter-spacing: -0.5px;
}

.dashboard-subtitle {
    font-size: 17px;
    color: #6b7280;
    margin-bottom: 0;
}

/* ===== Dashboard Metric Cards Alignment ===== */

.metric-card {
    background: #ffffff;
    border: 1px solid #e7e9e4;
    border-radius: 18px;
    padding: 24px 24px;
    min-height: 220px;
    height: 100%;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
    display: flex;
    flex-direction: column;
}

.metric-top {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 58px;
    margin-bottom: 18px;
}

.metric-icon {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: #e8f0e3;
    color: #2f6f3e;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
}

.metric-label {
    font-size: 17px;
    font-weight: 800;
    color: #4b5563;
    line-height: 1.25;
    margin: 0;
}

.metric-value {
    font-size: 34px;
    font-weight: 800;
    color: #111827;
    line-height: 1;
    margin-bottom: 18px;
}

.metric-note {
    margin-top: auto;
    font-size: 15px;
    color: #3f7f4f;
    font-weight: 700;
}

.metric-note.positive,
.metric-note.neutral {
    color: #3f7f4f;
    font-weight: 700;
}

/* Keep cards without mini bars visually aligned */
.metric-card:not(:has(.mini-bars)) .metric-value {
    margin-bottom: 58px;
}

.mini-bars {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    height: 48px;
    margin: 0 0 18px;
}

.mini-bar {
    display: inline-block;
    width: 12px;
    min-height: 8px;
    border-radius: 3px 3px 0 0;
    background: #5f7f58;
}

.dashboard-report-card {
    margin-bottom: 24px;
}

.dashboard-report-summary {
    margin: 10px 0 0;
    color: #374151;
    font-size: 16px;
}

.dashboard-report-summary strong {
    color: #2f8f6b;
    font-weight: 800;
}

.dashboard-report-filter {
    margin: 22px 0 28px;
}

.dashboard-filter-grid {
    display: grid;
    grid-template-columns: minmax(360px, 1fr) minmax(360px, 1fr) 190px;
    gap: 18px;
    align-items: end;
}

.dashboard-filter-field .input {
    margin: 0 !important;
}

.dashboard-filter-field label {
    display: block;
    margin-bottom: 8px;
    color: #111827;
    font-size: 15px;
    font-weight: 800;
}

.dashboard-date-input {
    width: 100% !important;
    height: 48px !important;
    border: 1px solid #d8ded5;
    border-radius: 8px;
    padding: 0 16px !important;
    color: #374151;
    font-size: 16px !important;
    background: #ffffff;
    box-sizing: border-box;
}

.dashboard-date-input:focus {
    outline: none;
    border-color: #2f8f6b;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16);
}

.dashboard-filter-action {
    display: flex;
    align-items: flex-end;
    height: 100%;
}

.dashboard-filter-action .admin-action-btn,
.dashboard-filter-btn {
    width: 100% !important;
    height: 48px !important;
    padding: 0 18px !important;
    font-size: 15px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    margin: 0 !important;
    white-space: nowrap;
}

.dashboard-report-table {
    margin-top: 8px;
}

.dashboard-report-table .booking-status {
    min-width: 88px;
}

.dashboard-money {
    color: #111827;
    font-weight: 800;
}

.dashboard-activity-card {
    margin-bottom: 24px;
}

.dashboard-activity-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.dashboard-activity-column {
    padding: 22px 24px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 6px 16px rgba(24, 49, 30, 0.04);
}

.dashboard-activity-column h3 {
    margin: 0 0 16px;
    color: #0f2f1a;
    font-size: 18px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.dashboard-activity-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    padding: 16px 0;
    border-top: 1px solid #edf0eb;
}

.dashboard-activity-item:first-of-type {
    border-top: 0;
    padding-top: 0;
}

.dashboard-activity-item:last-child {
    padding-bottom: 0;
}

.dashboard-activity-item h4 {
    margin: 0 0 6px;
    color: #111827;
    font-size: 17px;
    font-weight: 800;
}

.dashboard-activity-item p {
    margin: 0;
    color: #4b5563;
    font-size: 15px;
    line-height: 1.4;
}

.dashboard-activity-item span {
    color: #6b7280;
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
}

@media (max-width: 1000px) {
    .dashboard-filter-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-filter-btn {
        width: auto !important;
        min-width: 160px;
    }

    .dashboard-activity-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-activity-item {
        align-items: flex-start;
        flex-direction: column;
    }
}

.customer-dashboard-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.customer-metric-card {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 24px 26px;
    border-radius: 18px;
    border: 1px solid #edf0eb;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
}

.customer-metric-card.green {
    background: #f7faf5;
}

.customer-metric-icon {
    width: 54px;
    height: 54px;
    border-radius: 16px;
    background: #e8f0e3;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    flex-shrink: 0;
}

.customer-metric-label {
    color: #0f2f1a;
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.customer-metric-value {
    margin-top: 6px;
    color: #111827;
    font-size: 34px;
    font-weight: 800;
    line-height: 1;
}

.customer-metric-note {
    margin-top: 6px;
    color: #6b7280;
    font-size: 14px;
    font-weight: 600;
}

.customer-dashboard-card {
    margin-bottom: 24px;
}

.customer-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.customer-action-card {
    display: block;
    padding: 24px 26px;
    border: 1px solid #edf0eb;
    border-radius: 16px;
    background: #ffffff;
    text-decoration: none !important;
    box-shadow: 0 6px 16px rgba(24, 49, 30, 0.04);
    transition: all 0.18s ease;
}

.customer-action-card:hover {
    background: #f7faf5;
    transform: translateY(-2px);
    box-shadow: 0 12px 26px rgba(24, 49, 30, 0.08);
}

.customer-action-tag {
    margin-bottom: 12px;
    color: #5f6b66;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.customer-action-title {
    color: #0f2f1a;
    font-size: 20px;
    font-weight: 800;
    margin-bottom: 8px;
}

.customer-action-card p {
    margin: 0;
    color: #6b7280;
    font-size: 15px;
    line-height: 1.5;
}

.customer-reminder-card {
    padding: 24px 26px;
    border: 1px solid #edf0eb;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 6px 16px rgba(24, 49, 30, 0.04);
}

.customer-reminder-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    margin-bottom: 18px;
}

.customer-reminder-top span {
    color: #0f2f1a;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.customer-reminder-top strong {
    color: #111827;
    font-size: 18px;
    font-weight: 800;
    white-space: nowrap;
}

.customer-reminder-message {
    margin: 0 0 20px;
    color: #374151;
    font-size: 16px;
    line-height: 1.6;
}

.customer-reminder-details {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.customer-reminder-details div {
    padding: 16px 18px;
    border-radius: 14px;
    background: #f7faf5;
    border: 1px solid #edf0eb;
}

.customer-reminder-details span {
    display: block;
    margin-bottom: 6px;
    color: #6b7280;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.customer-reminder-details strong {
    color: #111827;
    font-size: 15px;
    font-weight: 700;
}

.customer-reminder-empty {
    padding: 24px 26px;
    border-radius: 16px;
    background: #f7faf5;
    border: 1px solid #edf0eb;
    color: #374151;
}

.customer-reminder-empty strong {
    color: #0f2f1a;
    font-size: 16px;
}

.customer-reminder-empty p {
    margin: 8px 0 0;
    color: #6b7280;
    font-size: 15px;
}

@media (max-width: 900px) {
    .customer-dashboard-metrics,
    .customer-action-grid,
    .customer-reminder-details {
        grid-template-columns: 1fr;
    }

    .customer-reminder-top {
        align-items: flex-start;
        flex-direction: column;
    }
}

.customer-profile-edit-card {
    padding: 34px 40px;
    margin-bottom: 24px;
}

.customer-profile-helper {
    margin: 10px 0 0;
    color: #6b7280;
    font-size: 15px;
}

.customer-profile-form {
    margin-top: 24px;
}

.customer-profile-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px 22px;
}

.customer-profile-form .input {
    margin: 0;
}

.customer-profile-form label {
    display: block;
    margin-bottom: 8px;
    color: #111827;
    font-size: 15px;
    font-weight: 800;
}

.customer-profile-input {
    width: 100% !important;
    height: 46px !important;
    border: 1px solid #d8ded5;
    border-radius: 8px;
    padding: 0 15px !important;
    color: #374151;
    font-size: 15px !important;
    background: #ffffff;
    box-sizing: border-box;
}

.customer-profile-input:focus {
    outline: none;
    border-color: #2f8f6b;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16);
}

.customer-password-note {
    margin: 16px 0 0;
    color: #6b7280;
    font-size: 14px;
}

.customer-profile-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 24px;
    flex-wrap: wrap;
}

.customer-profile-actions .admin-action-btn,
.customer-profile-actions button.admin-action-btn,
.customer-profile-actions a.admin-action-btn {
    min-width: 150px !important;
    height: 44px !important;
    padding: 0 22px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    margin: 0 !important;
}

@media (max-width: 900px) {
    .customer-profile-form-grid {
        grid-template-columns: 1fr;
    }
}

.customer-booking-summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.customer-booking-summary-card {
    padding: 24px 26px;
    border: 1px solid #edf0eb;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
}

.customer-booking-summary-card.green {
    background: #f7faf5;
}

.customer-booking-summary-card span {
    display: block;
    margin-bottom: 8px;
    color: #0f2f1a;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.customer-booking-summary-card strong {
    display: block;
    color: #111827;
    font-size: 30px;
    font-weight: 800;
    line-height: 1;
}

.customer-booking-summary-card p {
    margin: 10px 0 0;
    color: #6b7280;
    font-size: 14px;
    font-weight: 600;
}

.customer-bookings-card {
    margin-bottom: 24px;
}

.customer-booking-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.customer-booking-card {
    display: grid;
    grid-template-columns: 1fr 220px;
    gap: 24px;
    align-items: center;
    padding: 26px 30px;
    border: 1px solid #edf0eb;
    border-radius: 18px;
    background: #f7faf5;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
}

.customer-booking-header {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.customer-booking-header h3 {
    margin: 0;
    color: #0f2f1a;
    font-size: 20px;
    font-weight: 800;
}

.customer-booking-details {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.customer-booking-details div {
    padding: 15px 16px;
    border: 1px solid #edf0eb;
    border-radius: 14px;
    background: #ffffff;
}

.customer-booking-details span {
    display: block;
    margin-bottom: 6px;
    color: #6b7280;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.customer-booking-details strong {
    color: #111827;
    font-size: 15px;
    font-weight: 700;
}

.customer-booking-actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.customer-booking-actions .admin-action-btn,
.customer-booking-actions button.admin-action-btn,
.customer-booking-actions a.admin-action-btn {
    width: 100%;
    height: 44px !important;
    padding: 0 20px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    line-height: 1 !important;
    margin: 0 !important;
}

.customer-booking-empty {
    padding: 24px 26px;
    border-radius: 16px;
    background: #f7faf5;
    border: 1px solid #edf0eb;
    color: #374151;
}

.customer-booking-empty strong {
    color: #0f2f1a;
    font-size: 16px;
}

.customer-booking-empty p {
    margin: 8px 0 0;
    color: #6b7280;
    font-size: 15px;
}

@media (max-width: 900px) {
    .customer-booking-summary-grid,
    .customer-booking-card,
    .customer-booking-details {
        grid-template-columns: 1fr;
    }
}


.customer-reschedule-card {
    padding: 34px 40px;
    margin-bottom: 24px;
}

.customer-reschedule-helper {
    margin: 10px 0 0;
    color: #6b7280;
    font-size: 15px;
}

.admin-list-card .payment-options {
    display: flex;
    width: 100%;
    justify-content: space-between;
    gap: 20px;
}

.admin-list-card .payment-card {
    flex: 1;
    min-height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.customer-reschedule-form {
    margin-top: 24px;
}

.customer-reschedule-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px 22px;
}

.customer-reschedule-form .input {
    margin: 0;
}

.customer-reschedule-form label {
    display: block;
    margin-bottom: 8px;
    color: #111827;
    font-size: 15px;
    font-weight: 800;
}

.customer-reschedule-input {
    width: 100% !important;
    height: 46px !important;
    border: 1px solid #d8ded5;
    border-radius: 8px;
    padding: 0 15px !important;
    color: #374151;
    font-size: 15px !important;
    background: #ffffff;
    box-sizing: border-box;
}

.customer-reschedule-input:focus {
    outline: none;
    border-color: #2f8f6b;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16);
}

.customer-reschedule-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.customer-reschedule-actions .admin-action-btn,
.customer-reschedule-actions button.admin-action-btn,
.customer-reschedule-actions a.admin-action-btn {
    min-width: 170px !important;
    height: 44px !important;
    padding: 0 22px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    margin: 0 !important;
}

@media (max-width: 1000px) {
    .customer-reschedule-grid {
        grid-template-columns: 1fr;
    }
}

/* ===== Customer Reminders Page ===== */

.customer-reminder-summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.customer-reminder-summary-grid.single {
    grid-template-columns: minmax(0, 1fr);
}

.customer-reminder-summary-card {
    padding: 24px 26px;
    border: 1px solid #edf0eb;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
}

.customer-reminder-summary-card span {
    display: block;
    margin-bottom: 8px;
    color: #0f2f1a;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.customer-reminder-summary-card strong {
    display: block;
    color: #111827;
    font-size: 30px;
    font-weight: 800;
    line-height: 1;
}

.customer-reminder-summary-card p {
    margin: 10px 0 0;
    color: #6b7280;
    font-size: 14px;
    font-weight: 600;
}

.customer-reminders-card {
    margin-bottom: 24px;
}

.customer-reminder-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.customer-reminder-full-card {
    display: grid;
    grid-template-columns: 1fr 190px;
    gap: 24px;
    align-items: center;
    padding: 26px 30px;
    border: 1px solid #edf0eb;
    border-radius: 18px;
    background: #f7faf5;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
}

.customer-reminder-main {
    min-width: 0;
}

.customer-reminder-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 18px;
}

.customer-reminder-header span {
    display: block;
    margin-bottom: 8px;
    color: #6b7280;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 1.3px;
    text-transform: uppercase;
}

.customer-reminder-header h3 {
    margin: 0;
    color: #0f2f1a;
    font-size: 20px;
    font-weight: 800;
}

.customer-reminder-header strong {
    color: #111827;
    font-size: 16px;
    font-weight: 800;
    white-space: nowrap;
}

.customer-reminder-message {
    margin: 0;
    color: #374151;
    font-size: 16px;
    line-height: 1.6;
}

/* Simple text info, no separate small boxes */
.customer-reminder-info {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid #dfe8d8;
}

.customer-reminder-info p {
    margin: 0 0 6px;
    color: #4b5563;
    font-size: 15px;
    line-height: 1.5;
}

.customer-reminder-info p:last-child {
    margin-bottom: 0;
}

.customer-reminder-info strong {
    color: #111827;
    font-weight: 800;
}

.customer-reminder-actions {
    display: flex;
    justify-content: flex-end;
}

.customer-reminder-actions .admin-action-btn,
.customer-reminder-actions a.admin-action-btn {
    width: 100%;
    height: 44px !important;
    padding: 0 20px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    line-height: 1 !important;
    margin: 0 !important;
}

.customer-reminder-empty {
    padding: 24px 26px;
    border-radius: 16px;
    background: #f7faf5;
    border: 1px solid #edf0eb;
    color: #374151;
}

.customer-reminder-empty strong {
    color: #0f2f1a;
    font-size: 16px;
}

.customer-reminder-empty p {
    margin: 8px 0 0;
    color: #6b7280;
    font-size: 15px;
}

@media (max-width: 900px) {
    .customer-reminder-summary-grid,
    .customer-reminder-full-card {
        grid-template-columns: 1fr;
    }

    .customer-reminder-header {
        flex-direction: column;
    }

    .customer-reminder-actions {
        justify-content: flex-start;
    }

    .customer-reminder-actions .admin-action-btn {
        width: auto;
        min-width: 160px;
    }
}

/* ===== Customer Billing History Page ===== */

.customer-billing-summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.customer-billing-summary-grid.single {
    grid-template-columns: minmax(0, 1fr);
}

.customer-billing-summary-card {
    padding: 24px 26px;
    border: 1px solid #edf0eb;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(20, 38, 24, 0.06);
}

.customer-billing-summary-card span {
    display: block;
    margin-bottom: 8px;
    color: #0f2f1a;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.customer-billing-summary-card strong {
    display: block;
    color: #111827;
    font-size: 30px;
    font-weight: 800;
    line-height: 1;
}

.customer-billing-summary-card p {
    margin: 10px 0 0;
    color: #6b7280;
    font-size: 14px;
    font-weight: 600;
}

.customer-billing-card {
    margin-bottom: 24px;
}

.customer-billing-table .admin-action-btn.small {
    min-width: 120px;
}

.customer-billing-money {
    color: #111827;
    font-weight: 800;
}

.customer-billing-empty {
    padding: 24px 26px;
    border-radius: 16px;
    background: #f7faf5;
    border: 1px solid #edf0eb;
    color: #374151;
}

.customer-billing-empty strong {
    color: #0f2f1a;
    font-size: 16px;
}

.customer-billing-empty p {
    margin: 8px 0 0;
    color: #6b7280;
    font-size: 15px;
}

/* Invoice modal */
.customer-invoice-modal {
    border: none;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 18px 45px rgba(24, 49, 30, 0.22);
}

.customer-invoice-modal .modal-header {
    background: #f7faf5;
    border-bottom: 1px solid #edf0eb;
    padding: 20px 24px;
}

.customer-invoice-modal .modal-title {
    color: #0f2f1a;
    font-size: 20px;
    font-weight: 800;
    letter-spacing: 1px;
}

.customer-invoice-modal .modal-body {
    padding: 26px 28px;
}

.invoice-heading {
    margin-bottom: 22px;
}

.invoice-heading h4 {
    margin: 0 0 6px;
    color: #0f2f1a;
    font-size: 24px;
    font-weight: 800;
}

.invoice-heading p {
    margin: 0;
    color: #6b7280;
    font-size: 15px;
}

.invoice-section {
    padding: 18px 0;
    border-top: 1px solid #edf0eb;
}

.invoice-section h5 {
    margin: 0 0 12px;
    color: #0f2f1a;
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 1.2px;
    text-transform: uppercase;
}

.invoice-section p {
    margin: 0 0 8px;
    color: #4b5563;
    font-size: 15px;
}

.invoice-section p:last-child {
    margin-bottom: 0;
}

.invoice-section strong {
    color: #111827;
}

.invoice-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 14px;
    padding: 18px 20px;
    border-radius: 14px;
    background: #f7faf5;
    border: 1px solid #edf0eb;
}

.invoice-total span {
    color: #0f2f1a;
    font-size: 15px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.invoice-total strong {
    color: #111827;
    font-size: 22px;
    font-weight: 800;
}

@media (max-width: 900px) {
    .customer-billing-summary-grid {
        grid-template-columns: 1fr;
    }
}

.admin-shell .sidebar {
    position: fixed !important;
    left: 24px !important;
    width: 260px !important;
    height: calc(100vh - 130px) !important;
    overflow-y: auto !important;
    z-index: 50 !important;
}

.admin-shell .main-panel {
    margin-left: 290px !important;
    width: calc(100% - 290px) !important;
}

/* ===== Customer Make Booking Modal ===== */

.customer-booking-modal .modal-dialog {
    max-width: 720px;
}

.customer-modal-content {
    border: none;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 22px 55px rgba(15, 47, 26, 0.28);
}

.customer-modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 26px 30px;
    border-bottom: 1px solid #edf0eb;
    background:
        radial-gradient(circle at 85% 10%, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0) 30%),
        linear-gradient(135deg, #5a8f67 0%, #3f7f4f 100%);
}

.customer-modal-header .modal-title {
    margin: 0;
    color: #ffffff;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: 1px;
}

.customer-modal-header p {
    margin: 8px 0 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 15px;
}

.customer-modal-close {
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.16);
    color: #ffffff;
    font-size: 28px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.18s ease;
}

.customer-modal-close:hover {
    background: rgba(255, 255, 255, 0.25);
    transform: translateY(-1px);
}

.customer-modal-body {
    padding: 30px;
    background: #ffffff;
}

.customer-modal-note {
    margin: 0 0 24px;
    color: #6b7280;
    font-size: 16px;
    line-height: 1.5;
}

.customer-modal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.customer-modal-field {
    margin-bottom: 20px;
}

.customer-modal-field .input {
    margin: 0;
}

.customer-modal-field label {
    display: block;
    margin-bottom: 8px;
    color: #111827;
    font-size: 15px;
    font-weight: 800;
}

.customer-modal-input {
    width: 100% !important;
    height: 48px !important;
    border: 1px solid #d8ded5;
    border-radius: 10px;
    padding: 0 15px !important;
    color: #374151;
    font-size: 15px !important;
    background: #ffffff;
    box-sizing: border-box;
}

.customer-modal-input:focus {
    outline: none;
    border-color: #2f8f6b;
    box-shadow: 0 0 0 3px rgba(47, 143, 107, 0.16);
}

.customer-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 22px 30px 28px;
    border-top: 1px solid #edf0eb;
    background: #f7faf5;
}

.customer-modal-footer .admin-action-btn,
.customer-modal-footer button.admin-action-btn {
    min-width: 170px !important;
    height: 46px !important;
    padding: 0 22px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    line-height: 1 !important;
    margin: 0 !important;
}

@media (max-width: 700px) {
    .customer-booking-modal .modal-dialog {
        margin: 16px;
    }

    .customer-modal-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .customer-modal-footer {
        flex-direction: column;
    }

    .customer-modal-footer .admin-action-btn {
        width: 100%;
    }
}

.customer-modal-input,
.customer-modal-field select,
.customer-modal-field .form-control {
    background-image: none !important;
    background-repeat: no-repeat !important;
    appearance: auto !important;
    -webkit-appearance: auto !important;
    -moz-appearance: auto !important;
}
