/**
 * Theme Name:     Petsity Custom Theme
 * Author:         AceInovations Team
 * Description:    This theme is developed by Aceinovations Team
 * Author:         Arindam Mukherjee
 * Author URI:     http://aceinovations.com
 * Template:       service-finder
 * Version:        1.0.0
 * License:        GNU General Public License v2 or later
 * License URI:    http://www.gnu.org/licenses/gpl-2.0.html
 * Tags:           light, dark, two-columns, right-sidebar, responsive-layout, accessibility-ready
 * Text Domain:    service-finder-child
 */

.page-wraper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* Breadcrumbs hide */
.breadcrumb-row {
    visibility: hidden;
}

/* Form border fixes */
.form-control {
    border: 1px solid #dddddd;
}

.petsity-dropdown .bootstrap-select:not([class*=col-]):not([class*=form-control]):not(.input-group-btn) {
    width: 100% !important;
    border-radius: 5px !important;
}

.petsity-dropdown .bootstrap-select .dropdown-toggle {
    border-radius: 5px !important;
    border: 1px solid #ededed !important;
    text-transform: none;
    font-size: 16px;
    padding: 10px 10px;
    height: 45px;
    margin-bottom: 10px;
}

.petsity-dropdown .bootstrap-select div.dropdown-menu ul li {
    padding: 10px 0;
    margin: 0;
    font-size: 16px !important;
}

.home-search-dropdown .btn {
    text-transform: none !important;
    font-size: 14px !important;
}

/** Line height fix banner**/
p {
    line-height: inherit !important;
}

.sf-bnr-text span p {
    line-height: 100% !important;
    max-width: 75%;
    text-align: center;
    margin: auto;
}

.sf-bnr-text strong p {
    line-height: 100% !important;
    font-size: 48px;
}

banner-area2 .aon-bnr-write .text-top-line p {
    line-height: 100% !important;
}

.aon-bnr2-media img {
    border-radius: 10px;
}

/** Navigation button text color **/
.sf-header-inner.is-sticky .extra-nav .extra-cell a.btn {
    color: #000000 !important;
}

.sf-header-inner .extra-nav .extra-cell a.btn {
    padding: 8px 17px !important;
}

.header-style8 .extra-nav .extra-cell a.btn {
    background-color: #fff !important;
    padding: 8px 17px !important;
    color: #515151 !important;
    border-radius: 150px !important;
}

.header-style8 .extra-nav .extra-cell a.btn:hover {
    color: #222222 !important;
    border-color: #E75301 !important;
    box-shadow: 5px 5px 12px rgba(0, 0, 0, 0.056) !important;
}

/* .header-style6 .extra-nav .extra-cell a.btn {
    border: 2px solid #bbbbbb !important;
}
.header-style6 .header-nav .nav > li.active > a, .header-style6 .header-nav .nav > li.current-menu-item > a, .header-style6 .nav > li.current-menu-item.menu-item-has-children:before {
    color: #FF9999 !important;
}
.header-style6 .header-nav .nav > li:hover > a, .header-style6 .nav > li:hover.menu-item-has-children:before, .header-style6.is-sticky .nav > li:hover.menu-item-has-children:before {
    color: #FF9999!important;
} */

.header-style8 .header-nav .nav {
    @media(min-width: 991px) {
        float: inline-end;
        margin-left: 50px;
        margin-right: 50px;
    }

}

/* Navigation header */

.sf-header-inner .header-nav .nav>li {
    font-weight: 800 !important;
    margin: 0 10px 5px 10px !important;
}

.header-nav .nav>li>a {
    font-size: 14px !important;
}

.is-sticky .extra-nav {
    padding: 25px 0 !important;
}

.sf-header-inner.is-sticky>.main-bar {
    box-shadow: 0 -6px 10px 5px rgb(0 0 0 / 10%);
}

@media (max-width: 991px) {
    .extra-nav {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }

    .extra-nav .extra-cell {
        min-width: 0;
        display: flex;
    }

    /* ========================================
       LOGGED OUT STATE - Only 2 buttons (Login & Sign Up)
       Each button should be 50% width
       ======================================== */

    /* When there are only 2 extra-cells (logged out): 
       First child that is also nth-last-child(2) means exactly 2 children */
    .extra-nav .extra-cell:first-child:nth-last-child(2),
    .extra-nav .extra-cell:first-child:nth-last-child(2)~.extra-cell {
        flex: 0 0 calc(50% - 4px);
    }

    /* ========================================
       LOGGED IN STATE - 4 buttons (Messages, Notifications, Username, Logout)
       Layout: 22% | 22% | 56% on first row, 100% on second row
       ======================================== */

    /* When there are exactly 4 extra-cells (logged in): */
    .extra-nav .extra-cell:first-child:nth-last-child(4) {
        flex: 0 0 22%;
    }

    .extra-nav .extra-cell:first-child:nth-last-child(4)~.extra-cell:nth-child(2) {
        flex: 0 0 22%;
    }

    .extra-nav .extra-cell:first-child:nth-last-child(4)~.extra-cell:nth-child(3) {
        flex: 0 0 calc(56% - 16px);
    }

    .extra-nav .extra-cell:first-child:nth-last-child(4)~.extra-cell:nth-child(4) {
        flex: 0 0 100%;
    }

    /* ========================================
       LOGGED IN STATE - 3 buttons (for other configurations)
       ======================================== */
    .extra-nav .extra-cell:first-child:nth-last-child(3) {
        flex: 0 0 22%;
    }

    .extra-nav .extra-cell:first-child:nth-last-child(3)~.extra-cell:nth-child(2) {
        flex: 0 0 22%;
    }

    .extra-nav .extra-cell:first-child:nth-last-child(3)~.extra-cell:nth-child(3) {
        flex: 0 0 calc(56% - 16px);
    }

    .extra-nav .extra-cell a.btn {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
    }

    .userfullname {
        display: block;
        max-width: 100%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}


/* Modern Navigation with Top Border Highlight */
/* Desktop Navigation Styles */
@media (min-width: 992px) {
    #primary-menu {
        display: flex;
        align-items: center;
    }

    #primary-menu li {
        position: relative;
        padding: 20px 0;
    }

    #primary-menu li a {
        padding: 18px 18px;
        font-weight: 500;
        color: #555;
        transition: color 0.3s ease;
    }

    /* Top border for active/current menu item on desktop */
    #primary-menu li.current-menu-item:before {
        content: '';
        position: absolute;
        height: 3px;
        width: 80%;
        background-color: #E75301;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
    }

    /* Active menu item text color */
    #primary-menu li.current-menu-item a {
        color: #E75301;
        font-weight: 600;
    }
}

/* Mobile Navigation Styles */
@media (max-width: 991px) {
    #primary-menu li {
        position: relative;
        border-bottom: 1px solid #f5f5f5;
    }

    #primary-menu li:last-child {
        border-bottom: none;
    }

    #primary-menu li a {
        padding: 15px 10px;
        font-size: 16px;
        font-weight: 500;
        color: #555;
        display: block;
    }

    /* Side indicator for active item on mobile */
    #primary-menu li.current-menu-item:before {
        content: '';
        position: absolute;
        height: 70%;
        width: 3px;
        background-color: #E75301;
        top: 15%;
        left: 0;
    }

    /* Active menu item text color */
    #primary-menu li.current-menu-item a {
        color: #E75301;
        font-weight: 600;
        padding-left: 15px;
    }

    /* Mobile menu container */
    .header-nav.navbar-collapse {
        background-color: white;
        box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
        padding: 15px;
        border-radius: 10px;
        margin-top: 10px;
    }

    #primary-menu {
        margin-top: 15px;
        border-top: 1px solid #eee;
        padding-top: 10px;
    }
}

/* Button Styling - Both Mobile and Desktop */
.extra-cell .btn {
    border-radius: 4px;
    padding: 10px 20px;
    font-weight: 500;
    transition: background-color 0.3s ease;
}

/* Login Button */
.extra-cell .btn:first-child {
    background-color: #fff;
    color: #E75301;
    border: 1px solid #E75301;
}

/* Sign Up Button */
.extra-cell .btn:last-child {
    background-color: #E75301;
    color: white;
    border: 1px solid #E75301;
}


/* Mobile Button Adjustments */
@media (max-width: 991px) {
    .extra-nav {
        display: flex;
        justify-content: space-between;
    }

    .extra-cell {
        flex: 1;
        padding: 0 5px;
    }

    .extra-cell .btn {
        width: 100%;
        display: block;
    }
}

/** Banner fix**/
.text-uppercase {
    text-transform: none !important;
}

.text-bot-line p {
    font-family: 'Poppins';
}

body .aon-bnr2-content-wrap .text-bot-line {
    border: none !important;
}

/* .aon-banner-area2 .aon-bnr-write .text-top-line {
    display: block;
    font-weight: 700;
    font-size: 42px;
    line-height: 50px;
    color: #222222;
}
.aon-banner-area2 .aon-bnr-write .text-bot-line {
    font-family: Open Sans;
    font-weight: 400;
    font-size: 16px;
    line-height: 22px;
    color: #222222;
} */
/** Banner search color **/
.aon-bnr2-search-box {
    padding: 10px;
    row-gap: 10px;
}

.form-control {
    min-height: 41px !important;
}

.expandable-textarea {
    resize: vertical !important;
    overflow: auto !important;
    height: auto !important;
    min-width: 100% !important;
}


.sf-advace-search-two .col-md-6 {
    width: 100% !important;
}

.aon-bnr2-search-box .geolocate {
    top: 25px !important;
    right: 30px !important;
}

/* Hide keyword and city from home */
.aon-search-input .keywords-input {
    display: none !important;
}

/* Advance serach hide */
.aon-bnr2-search-bar .sf-advace-search-btn {
    display: none !important;
}

.pricing-amount-minmax {
    margin: 10px 0;
    display: flex;
    flex-direction: row;
    flex-wrap: no-wrap;
    justify-content: space-between;
}

/**Keyword Hide**/
.aon-bnr2-search-box .aon-search-input {
    width: 100% !important;
}

/** Admin nav subheading padding fix**/
.admin-nav ul li .sub-menu>li a {
    padding-left: 46px;
}

.admin-nav ul>li>a:hover,
.admin-nav ul>li>a:active,
.admin-nav ul>li>a:focus {
    text-decoration: none;
}

/** Fixing navigation **/
/* .header-nav .nav {
    margin-top: 15px;
}
.extra-nav {
	margin-top: 15px;
} */

/** Hide map**/
.sf-map-row {
    display: none;
}

/** homepage category background color **/
.aon-categories-area2-iconbox .aon-cate-area2-icon span {
    background-color: #FFF3F5 !important;
}

/** Homepage section background color change **/
.aon-howit-area2-section {
    background-color: #444F5A !important;
}

.aon-why-choose2-box {
    background-color: #444F5A !important;
}

/* Hide address and phone fields in contact info */
.contact-info li:nth-child(1),
/* Address */
.contact-info li:nth-child(3) {
    /* Phone */
    /*     display: none; */
}

.sf-provi-coInfo-box .col-md-5 {
    /* 	display: none !important; */
}

.sf-search-result-area [class*="col-md-"] {
    width: 100%;
}

@media(min-width: 991px) {
    .sf-provi-coInfo-box .col-md-7 {
        width: 40% !important;
        float: right !important;
    }

    .sf-provi-coInfo-box .col-md-5 {
        width: 55% !important;
    }

}

.sf-provi-coInfo-box .a-b-none {
    /* 	display: none !important; */
}

/** Logo fix **/
.logo-header {
    height: auto !important;
    margin-bottom: 0 !important;
    margin-top: 10px !important;

    @media(min-width: 991px) {
        margin-top: 17px !important;
    }
}

.is-sticky .logo-header {
    margin-bottom: 17px !important
}

/** Hide blog banner **/
.sf-search-benner {
    display: none !important;
}

/** Mobile blog fixes **/
.wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
    @media(max-width: 600px) {
        padding: 0 !important;
    }
}

.post-navigation {
    @media(max-width: 600px) {
        padding: 10px !important;
    }
}

.post-navigation .nav-links {
    @media(max-width: 600px) {
        gap: 10px !important;
    }
}

.nav-links .nav-next {
    @media(max-width: 600px) {
        width: 40% !important;
    }
}

.nav-links .nav-previous {
    @media(max-width: 600px) {
        width: 40% !important;
    }
}

.post-navigation .nav-previous .post-title {
    @media(max-width: 600px) {
        font-size: 14px !important;
    }
}

.post-navigation .nav-next .post-title {
    @media(max-width: 600px) {
        font-size: 14px !important;
    }
}

.blog-post .post-title {
    word-break: break-word !important;
}

/** Provider Heading Text **/
.sf-proBnrfull-heading {
    font-size: 46px !important;
    line-height: 1.4 !important;
    color: #fff !important;
    margin: 0px 0px 10px !important;

}



.sf-bot-divider {
    border-bottom: none !important;
}

.sf-ow-media-img {
    height: 200px;
    width: auto !important;
    margin: auto;
    object-fit: cover;
    object-position: center;
}

/** Provider setting **/
.input-group .alert-info {
    display: none !important;
}

.container.sf-proBnrfull-container {
    width: 100% !important;
    padding: 0 !important;
}

.sf-provi-pic .sf-feaProgrid-label {
    margin: 10px 0 !important;
}

.sf-provi-bio-left .sf-provi-name {
    margin: 45px 0 10px 0 !important
}

.sf-provi-name {
    font-weight: 600;
}

.sf-qes-answerList-full li {
    width: 100% !important;
}

.sf-allCaty-info-wrap .container .row .col-md-6 {
    width: auto !important;
}

.sf-caty-pic {
    width: 245px !important;
    height: 245px !important;
}

.media-img-prev {
    height: 253px !important;
    border-radius: 10px !important;
    object-fit: cover !important;
}

.sf-provi-bio-text p {
    margin-bottom: 25px !important;
}

.scroll-anchor {
    display: block;
    height: 125px;
    margin-top: -125px;
    visibility: hidden;
}

.sf-provi-btn {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
}

.custom-count {
    /* 	border: 1px solid #dadbdd;
    border-radius: 3px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; */
    color: #fff;
    font-size: 14px;
    padding: 6px 0 !important;
    position: relative;
    height: 36px;
    margin: 0 !important;
}

.sf-list-business-hours span:first-child {
    width: 30% !important;
}

@media only screen and (max-width:767px) {
    .sf-page-scroll-nav ul li {
        padding: 0 7px !important;
    }

    .sf-page-scroll-wrap2 {
        overflow: auto;
    }
}


/** Dropdown height **/
.bootstrap-select.btn-group .dropdown-menu {
    max-height: 300px !important;
    overflow-y: auto !important;
    margin-bottom: 0 !important;
    /* Adjust margin if needed */
    padding-bottom: 0 !important;
    /* Adjust padding if needed */
}

.bootstrap-select.btn-group .dropdown-menu .inner {
    max-height: 210px !important;
    height: auto !important;
}

.content-admin-main textarea.form-control-large {
    display: block;
    width: 100%;
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    height: 80px;
    resize: none;
}

/* Availability Calendar Styles */
.sf-availability-calendar {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 25px;
    max-width: 100%;
}

.calendar-header {
    margin-bottom: 15px;
}

.calendar-navigation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 15px;
}

.calendar-month-title {
    font-size: 18px;
    font-weight: 600;
    margin: 0;
    color: #333;
}

.calendar-nav-btn {
    background: #f5f5f5;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 8px 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    min-width: 40px;
}

.calendar-nav-btn:hover {
    background: #e9e9e9;
}

.calendar-legend {
    display: flex;
    gap: 20px;
    font-size: 12px;
    color: #666;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
}

.legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 2px;
}

.legend-available {
    background-color: #8bc34a;
}

.legend-unavailable {
    background: repeating-linear-gradient(45deg,
            #f5f5f5,
            #f5f5f5 3px,
            #ddd 3px,
            #ddd 6px);
}

.calendar-table {
    width: 100%;
    table-layout: fixed;
    /* This ensures equal column widths */
    border-collapse: collapse;
    border: 1px solid #e0e0e0;
}

.calendar-th {
    background-color: #f8f9fa;
    padding: 12px 8px;
    text-align: center;
    font-weight: 600;
    font-size: 12px;
    color: #666;
    border: 1px solid #e0e0e0;
    width: 14.285714%;
    /* 100% / 7 columns = 14.285714% */
}

.calendar-td {
    padding: 0;
    border: 1px solid #e0e0e0;
    height: 40px;
    text-align: center;
    vertical-align: middle;
    position: relative;
    cursor: pointer;
    width: 14.285714%;
    /* 100% / 7 columns = 14.285714% */
    max-width: 14.285714%;
    min-width: 14.285714%;
}

.calendar-day-number {
    display: block;
    width: 100%;
    height: 100%;
    line-height: 40px;
    font-size: 14px;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.calendar-td-available {
    background-color: #8bc34a;
    color: #fff;
}

.calendar-td-available:hover {
    background-color: #7cb342;
}

.calendar-td-unavailable {
    background: repeating-linear-gradient(45deg,
            #f5f5f5,
            #f5f5f5 3px,
            #ddd 3px,
            #ddd 6px);
    color: #999;
    cursor: not-allowed;
}

.calendar-td-past {
    background-color: #f5f5f5;
    color: #999;
    cursor: not-allowed;
}

.calendar-td-today .calendar-day-number {
    font-weight: bold;
    text-decoration: underline;
}

.calendar-td-empty {
    background-color: transparent;
    cursor: default;
}

.calendar-footer {
    margin-top: 15px;
    text-align: center;
}

.calendar-update-note {
    font-size: 12px;
    color: #666;
    margin: 0;
}

.calendar-update-note i {
    color: #4caf50;
    margin-right: 5px;
}

/* Mobile responsiveness */
@media (max-width: 768px) {
    .sf-availability-calendar {
        padding: 15px;
    }

    .calendar-legend {
        flex-direction: column;
        gap: 8px;
    }

    .calendar-th,
    .calendar-td {
        padding: 6px 4px;
        font-size: 12px;
        width: 14.285714%;
        /* Maintain equal widths on mobile too */
    }

    .calendar-td {
        height: 35px;
    }

    .calendar-day-number {
        line-height: 35px;
        font-size: 12px;
    }

    .calendar-nav-btn {
        padding: 6px 10px;
        min-width: 35px;
    }

    .calendar-month-title {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .sf-availability-calendar {
        padding: 10px;
    }

    .calendar-th,
    .calendar-td {
        padding: 4px 2px;
        font-size: 11px;
    }

    .calendar-td {
        height: 32px;
    }

    .calendar-day-number {
        line-height: 32px;
        font-size: 11px;
    }
}


/* Availability Manager Styles */
.availability-manager-container {
    position: relative;
}

/* FIX #4: Better loading overlay */
.custom-loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.custom-loader {
    width: 40px;
    height: 40px;
    border: 4px solid #f3f3f3;
    border-top: 4px solid #E75301;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* FIX #3: Better notification styling */
.custom-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 12px 16px;
    border-radius: 4px;
    color: white;
    z-index: 10000;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    display: flex;
    align-items: center;
    gap: 8px;
    max-width: 300px;
    font-size: 14px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.custom-notification.show {
    transform: translateX(0);
}

.custom-notification-success {
    background: #28a745;
}

.custom-notification-error {
    background: #dc3545;
}

.custom-notification i {
    font-size: 16px;
}

/* Time slot styling */
.time-slot-item {
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 4px;
    padding: 10px;
    margin-bottom: 8px;
    position: relative;
}

.time-slot-item:hover {
    background: #e9ecef;
}

.time-slot-remove {
    position: absolute;
    top: 5px;
    right: 5px;
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    cursor: pointer;
}

.time-slot-time {
    font-weight: bold;
    color: #495057;
}

.time-slot-bookings {
    font-size: 12px;
    color: #6c757d;
    margin-top: 4px;
}

/* FIX #2: Update button colors to #E75301 */
.btn-primary,
.admin-button,
.add-time-slot,
#apply-to-all-days,
#save-time-slot,
#save-unavailability,
#add-unavailability {
    background-color: #E75301 !important;
    border-color: #E75301 !important;
    color: white !important;
}

.btn-primary:hover,
.admin-button:hover,
.add-time-slot:hover,
#apply-to-all-days:hover,
#save-time-slot:hover,
#save-unavailability:hover,
#add-unavailability:hover {
    background-color: #cc4a01 !important;
    border-color: #cc4a01 !important;
}

/* Day toggle buttons */
.day-toggle input:checked+.day-label {
    background-color: #E75301 !important;
    border-color: #E75301 !important;
    color: white !important;
}

/* Copy and toggle buttons */
.copy-day,
.toggle-day,
#copy-schedule {
    background-color: transparent;
    border: 1px solid #E75301;
    color: #E75301;
}

.copy-day:hover,
.toggle-day:hover,
#copy-schedule:hover {
    background-color: #E75301;
    color: white;
}

/* Working Days Selector Improvements */
.working-days-selector {
    margin-top: 15px;
}

.working-days-selector label {
    display: block;
    margin-bottom: 10px;
    font-weight: 600;
    color: #555;
}

.day-buttons {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.day-toggle {
    position: relative;
    margin: 0 !important;
}

.day-toggle input[type="checkbox"] {
    display: none;
}

.day-toggle .day-label {
    display: inline-block;
    padding: 8px 12px;
    background: #f8f9fa;
    border: 2px solid #dee2e6;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 500;
    font-size: 14px;
    color: #495057;
    min-width: 45px;
    text-align: center;
    transition: all 0.3s ease;
    user-select: none;
}

.day-toggle input[type="checkbox"]:checked+.day-label {
    background: #E75301 !important;
    border-color: #E75301 !important;
    color: white !important;
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(231, 83, 1, 0.3);
}

.day-toggle .day-label:hover {
    border-color: #E75301;
    background: #fff8f5;
}

.day-toggle input[type="checkbox"]:checked+.day-label:hover {
    background: #cc4a01 !important;
    border-color: #cc4a01 !important;
}

@media (max-width: 480px) {
    .day-buttons {
        justify-content: center;
    }

    .day-toggle .day-label {
        padding: 6px 10px;
        font-size: 12px;
        min-width: 40px;
    }
}

/* Day column styling */
/* .day-column.disabled {
    opacity: 0.5;
    pointer-events: none;
} */

/* FIX #5: Better unavailability display */
.unavailability-item {
    background: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: 4px;
    padding: 12px;
    margin-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.period-info {
    flex: 1;
}

.period-info strong {
    display: block;
    color: #333;
    font-size: 14px;
    margin-bottom: 4px;
}

.period-reason {
    display: block;
    font-size: 12px;
    color: #6c757d;
    font-style: italic;
}

.remove-unavailability {
    background: #dc3545;
    border: none;
    color: white;
    padding: 6px 8px;
    border-radius: 4px;
    cursor: pointer;
}

.remove-unavailability:hover {
    background: #c82333;
}

/* Dashed button styling */
.btn-dashed {
    border: 2px dashed #E75301;
    background: transparent;
    color: #E75301;
    padding: 10px 15px;
    text-align: center;
    width: 100%;
    margin-top: 10px;
}

.btn-dashed:hover {
    border-color: #cc4a01;
    color: #cc4a01;
    background: rgba(231, 83, 1, 0.05);
}

/* Modal close button styling */
.modal .close {
    color: #aaa;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
}

.modal .close:hover {
    color: #000;
}

.time-slot-remove {
    background: transparent;
    border: none;
    color: #dc3545;
    cursor: pointer;
    padding: 2px 5px;
    border-radius: 3px;
    transition: all 0.2s ease;
}

.time-slot-remove:hover {
    background-color: #dc3545;
    color: white;
}

.time-slot-item {
    position: relative;
    margin-bottom: 5px;
}

/* Calendar navigation buttons - FIX #6 */
.calendar-prev,
.calendar-next {
    background: #E75301;
    border: none;
    color: white;
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    margin: 0 5px;
}

.calendar-prev:hover,
.calendar-next:hover {
    background: #cc4a01;
}

/* Form control focus states */
.form-control:focus {
    border-color: #E75301;
    box-shadow: 0 0 0 0.2rem rgba(231, 83, 1, 0.25);
}

/* Select dropdown styling */
.sf-select-box:focus,
select:focus {
    border-color: #E75301;
    box-shadow: 0 0 0 0.2rem rgba(231, 83, 1, 0.25);
}

/* Quick setup section */
.quick-setup-card {
    background: white;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 20px;
}

.quick-setup-card h5 {
    color: #E75301;
    margin-bottom: 10px;
}

/* Weekly schedule styling */
.weekly-schedule-card {
    background: white;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 20px;
}

.schedule-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.schedule-header h5 {
    color: #E75301;
    margin: 0;
}

.schedule-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
}

.day-column {
    border: 1px solid #dee2e6;
    border-radius: 4px;
    padding: 15px;
}

.day-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid #eee;
}

.day-header h6 {
    margin: 0;
    color: #333;
}

.day-controls {
    display: flex;
    gap: 5px;
}

.day-controls button {
    padding: 4px 6px;
    font-size: 12px;
}

/* Whole Day Checkbox Styling */
#whole-day-group {
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 6px;
    padding: 15px;
    margin: 15px 0;
}

#whole-day-group .sf-radio-checkbox {
    margin-bottom: 5px;
}

#whole-day-group .form-text {
    margin-left: 25px;
    font-size: 12px;
    color: #6c757d;
}

/* Time inputs disabled state */
#time-inputs.disabled {
    opacity: 0.5;
    pointer-events: none;
}

#time-inputs.disabled input {
    background-color: #f8f9fa;
}

/* Preview calendar styling */
.preview-calendar-card {
    display: none !important;
    background: white;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 20px;
    margin-top: 20px;
}

.preview-calendar-card h5 {
    color: #E75301;
    margin-bottom: 10px;
}

/* Unavailability section */
.unavailability-card {
    background: white;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 20px;
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.card-header h5 {
    color: #E75301;
    margin: 0;
}

.unavailability-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

#clear-all-unavailability {
    background: transparent;
    border: 1px solid #dc3545;
    color: #dc3545;
}

#clear-all-unavailability:hover {
    background: #dc3545;
    color: white;
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

@media (max-width: 768px) {
    .unavailability-actions {
        flex-direction: column;
        gap: 5px;
    }

    .unavailability-actions button {
        width: 100%;
    }
}

/* Form validation styles */
.form-control.error {
    border-color: #dc3545;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.form-control.success {
    border-color: #28a745;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.validation-message {
    font-size: 12px;
    margin-top: 5px;
    display: block;
}

.validation-message.error {
    color: #dc3545;
}

.validation-message.success {
    color: #28a745;
}

/* Disable submit buttons when form is invalid */
.btn:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}

/* Enhanced form validation styles */
.text-danger {
    color: #dc3545 !important;
}

.text-muted {
    color: #6c757d !important;
}

.validation-message {
    font-size: 11px;
    margin-top: 3px;
    display: block;
}

.validation-message.error {
    color: #dc3545;
}

/* Required field indicator */
.text-danger {
    font-weight: bold;
}

/* Form control states */
.form-control.error {
    border-color: #dc3545;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.form-control.success {
    border-color: #28a745;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

/* Button disabled state */
#save-unavailability:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Screen reader only labels */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Quick setup enhancements */
#quick-time-inputs {
    transition: all 0.3s ease;
}

#quick-time-inputs.hidden {
    opacity: 0.5;
    pointer-events: none;
}

/* Confirmation modal styling */
#confirmation-modal .modal-dialog {
    max-width: 400px;
}

#confirmation-modal .modal-body {
    padding: 20px;
    text-align: center;
}

#confirmation-modal .modal-footer {
    justify-content: center;
    gap: 10px;
}

/* Copy day modal styling */
#copy-day-modal .modal-body select {
    min-height: 120px;
}

/* Remove button hover effect */
.time-slot-remove {
    transition: all 0.2s ease;
}

.time-slot-remove:hover {
    background: #c82333 !important;
    transform: scale(1.1);
}

/* Working day selector spacing */
.working-days-selector {
    margin-bottom: 15px;
}

.working-days-selector .day-buttons {
    margin-top: 8px;
}

.bootbox.modal .modal-header .close,
.bootbox.modal .modal-header .bootbox-close-button {
    display: none !important;
}

.bootbox-close-button {
    display: none !important;
}

/* Responsive design */
@media (max-width: 768px) {
    .schedule-grid {
        grid-template-columns: 1fr;
    }

    .custom-notification {
        right: 10px;
        left: 10px;
        max-width: none;
    }

    .day-controls {
        flex-direction: column;
    }
}


/**Taxonomy Provider Category Page**/
.taxonomy-provider-gap {
    margin-bottom: 84px !important;
}

/**My accounts area**/
.tab-content-inside-faq {
    padding: 10px;
}

.dropdown-menu>li>a {
    white-space: normal;
    min-width: 270px;
    max-width: 90vw;
}

.pet-size-preferences,
.additional-preferences,
.pet-experience {
    margin-bottom: 30px;
}

table.dataTable td.dataTables_empty,
table.dataTable th.dataTables_empty {
    font-weight: 400;
}

table.dataTable thead th,
table.dataTable tfoot th {
    font-weight: 600;
    font-size: 15px;
}

/* .form-group label {
    margin-bottom: 10px !important;
} */

.panel-instructions {
    padding: 15px 10px 0 13px !important;
}

.help-text-inbetween {
    margin: 10px 0 20px 0;
}

.pagination>li>a:hover,
.pagination>li>span:hover,
.pagination>li>a:focus,
.pagination>li>span:focus {
    background-color: #E75301 !important;
}

/**Question Answer page**/
.sf-ques-body {
    padding: 20px !important;
}

.sf-ques-body-title {
    margin-bottom: 10px !important;
    margin-top: 5px;
}

.sf-ques-ans-author {
    width: 32px !important;
    height: 32px !important;
    /* 	margin-left: 30px !important; */
}

.sf-ques-ans-author img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
}

.sf-ques-title-meta {
    padding: 10px 15px !important;
}

.sf-anstext-body .sf-quesans-meta {
    margin-top: 12px !important;
}

.sf-quesans-meta span {
    padding: 0 3px;
}

.sf-qa-thum a {
    padding: 0 !important;
}

.sf-qa-comments {
    display: none !important;
}

.site-button-link {
    margin-top: 10px !important;
}

.btn-custom {
    background: #444F5A !important;
    color: #fff !important;
}

.btn-custom:hover {
    background: #252b31 !important;
}

.sf-qa-hour {
    display: none !important;
}

.question-icon-img {
    margin-right: 6px;
}

.qa-partition {
    margin-top: 10px;
    margin-bottom: 10px;
    border: 0;
    border-top: 1px solid #eee;
}

.sf-anstext-body {
    padding-top: 0 !important;
}

.sf-ques-header-body {
    padding: 0 !important;
}

.sf-ques-header {
    background: #f9f9f9 !important;
}

@media only screen and (max-width: 991px) {

    #header-part.sf-header-inner .extra-nav .extra-cell a.btn,
    #header-part.sf-header-inner.is-sticky .extra-nav .extra-cell a.btn {
        color: #555555 !important;
    }
}

@media only screen and (max-width: 991px) {
    .sf-vender-list-pic {
        width: 97% !important;
        max-width: 100% !important;
        background-size: contain !important;
    }

    .d-flex {
        flex-direction: column !important;
    }

    .sf-vender-list-info {
        width: 100% !important;
    }
}

.help-tool-icon {
    margin-left: 5px;
}

/**Hide Padding time **/
/* #paddingtime{
	display: none !important;
}
#edit_paddingtime{
	display: none !important;
} */
/**Unavailable active color**/
ul.timeslots li.active,
ul.protimelist li.active {
    background: #fcdede;
    border-bottom: 2px solid #c99798;
    color: #9d6263 !important;
}

/**List padding**/
.sf-provi-service-list li {
    padding: 10px !important;
}

/**Remove filters from search page**/
#avlsrhfilter {
    display: none !important;
}

/**Search bar clear button**/
.sf-searchbar-box {
    padding: 0px 32px 38px !important;
}

.search-clear-all {
    margin: auto;
    text-align: center;
    padding: 20px;
}

.search-clear-all-text {
    font-size: 16px !important;
    margin-left: 5px;
}

.search-clear-all-text:hover {
    cursor: pointer;
}

.search-clear-all-text span {
    text-decoration: underline;
}

/**Hour minute dropdowns listing creation **/
.flex-row {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 0 !important;
}

.flex-row span {
    margin: 0 5px;
}

.has-feedback .form-control {
    padding-right: 5px !important;
}

@media only screen and (max-width:991px) {
    .sf-search-bar-panel {
        left: 0 !important;
    }
}

@media only screen and (max-width:991px) {
    .sf-search-bar-panel {
        max-width: 100% !important;
        display: none;
    }

    .sf-searchbar-area {
        margin-top: 25px !important;
    }
}

.search-close-btn {
    position: fixed;
    padding: 10px 20px;
    background: #fff;
    margin-bottom: 30px;
    width: 100%;
    text-align: end;
    z-index: 2;
}

.search-close-btn:hover {
    cursor: pointer;
}

.sf-searchbar-box {
    /* height: calc(100vh - 110px) !important; */
    height: 100% !important;
}

@media only screen and (max-width:991px) {
    .search-mobile-filter-btn {
        margin: 5px;
        list-style: none;
        display: inline-block;
    }

}

@media only screen and (min-width:992px) {
    .search-mobile-filter-btn {
        display: none !important;
    }
}

.search-close-btn span {
    margin: 0 10px;
    font-size: 14px;
}

.filter-button {
    padding: 10px 15px;
    border-radius: 7px;
    background: #E75301;
    color: #fff;
    border: none;
    vertical-align: bottom;
    margin: 0 0 0 5px;
    text-transform: uppercase;
    font-size: 14px;
}

.pagination>.active>a {
    background-color: #E75301 !important;
    border-color: #E75301 !important;
}

.pagination>.active>a:hover {
    color: #fff !important
}

.pagination>li>a>i {
    color: #717171 !important;
}

.pagination>li>a>i:hover {
    color: #E75301 !important;
}

/*Ask Question guideline*/
.quest-guide {
    margin: 10px 0 20px 0;
}

.quest-guide span a {
    text-decoration: underline;
}

/*Booking Description*/
.booking-dscr {
    text-align: center;
    padding: 10px;
}

/*File format info in profile settings */
.file-format-info {
    margin: 10px 0;
    font-size: 14px;
    text-transform: none;
    color: #8f8f8f;
}

/**Add new group padding**/
.group-outer-bx {
    margin-bottom: 20px !important;
}

/**My services icon align **/
.admin-nav ul li a>i {
    text-align: center;
    padding: 5px;
}

/* .admin-nav ul li a > i[class="fa fa-heart"]{
	margin-right: 18px !important;
}
.admin-nav ul li a > i[class="fa fa-user"] {
	margin-right: 26px !important;
} */
/* Search page fix */
.sf-searchbar-box .sf-search-btn {
    background: #E75301 !important;
    border-color: #E75301 !important;
    border-radius: 150px !important;
    font-family: 'recoleta';
    text-transform: none;
}

.clear-filters-link {
    border-radius: 150px !important;
}

.petsity-search-map {
    display: flex;
    padding-bottom: 0px !important;
    margin-top: 20px;
}

.sf-search-bar-panel {
    position: relative !important;
    width: 100%;
    max-width: 450px;
    height: calc(100vh - 90px);
    padding: 0px;
    background-color: #fff;
    z-index: 98;
}

.sf-search-result-area {
    margin-left: 0px !important;
    flex-grow: 1;
    min-height: calc(100vh - 235px);
}

.google-map-right {
    height: auto;
    margin-right: 5px;
    width: 100%;
    background-color: rgb(230, 232, 235);
    max-width: 33.33vw;
    min-height: calc(100vh - 99px);
    display: none;
}

@media only screen and (max-width: 1024px) {
    .google-map-right {
        display: none;
    }
}

/* make the pet-type radios look like pills */
/* .petsity-parent-cat {
    display: inline-block;
    margin: 0 8px 8px 0;
    cursor: pointer;
}

.petsity-parent-cat input[type=radio] {
    display: none;
}

.petsity-parent-cat span {
    background: #f8f8f8;
    border: 2px solid #ddd;
    border-radius: 30px;
    padding: 6px 18px;
    transition: all .25s;
}

.petsity-parent-cat input:checked+span {
    background: #E75301;
    border-color: #E75301;
    color: #fff;
} */

.search-radio {
    margin-top: 25px;
}

/* .pagination-two .pagination > li > a{
	background-color: #fff !important;
	border: 2px solid #E75301 !important;
	color: #222 !important;
} */

/* flex parent keeps its existing display */
.page-content.petsity-search-map {
    position: relative;
}

.sf-search-result-area {
    flex: 1 1 100%;
    width: 100%;
}

/* ── off-canvas map drawer ─────────────────────── */
.map-overlay {
    position: fixed;
    top: 0;
    right: -100%;
    /* hidden by default */
    width: 40%;
    /* adjust to taste */
    max-width: 500px;
    height: 100vh;
    background: #fff;
    z-index: 9999;
    box-shadow: -3px 0 10px rgba(0, 0, 0, .2);
    transition: right .35s ease;
}

.map-overlay.open {
    right: 0;
}

.map-overlay .google-map-right {
    height: 100%;
}

/* map fills drawer */

/* ── buttons ───────────────────────────────────── */
#toggle-map-btn,
.close-map {
    background: #E75301;
    color: #fff;
    border: none;
    cursor: pointer;
    font-weight: 600;
}

#toggle-map-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    padding: 10px 16px;
    border-radius: 4px;
    z-index: 9998;
}

.close-map {
    position: absolute;
    top: 10px;
    right: 10px;
    line-height: 1;
    padding: 6px 10px;
    border-radius: 50%;
    font-size: 22px;
}

/* Search page grid option hide */
.sf-search-grid-option {
    display: none !important;
}

.sf-search-result-top.flex-wrap {
    align-items: center !important;
}

/**Search page image fix **/

@media only screen and (min-width: 992px) {
    .sf-vender-list-pic {
        width: 97% !important;
        max-width: 200px !important;
        height: auto !important;
        padding-bottom: 50% !important;
        background-color: #fff !important;
        background-repeat: no-repeat !important;
        background-size: contain !important;
        background-position: center center !important;
        position: relative !important;
    }

    .sf-vender-list-info {
        width: calc(100% - 185px) !important;
    }
}

/*Cancelled booking status*/
.sf-booking-cancelled {
    padding: 2px 10px;
    font-size: 10px;
    color: #fff;
    background-color: #ff3131;
    border-radius: 20px;
    font-weight: 600;
    vertical-align: text-top;
    display: inline-block;
}

.sf-calbooking-status-cancelled {
    background-color: #ff3131;
}

.sf-features-list {
    list-style: inside !important;
    margin: 0 0 0 10px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: column !important;
}

.sf-features-list li {
    margin-right: 10px;
}

/* Offer color change */
.sf-provi-service-ttle span {
    background: #ff2a2a !important;
    color: #fff !important;
}

/*Border none on tabs */
.nav-tabs>li.active>a,
.nav-tabs>li.active>a:focus,
.nav-tabs>li.active>a:hover {
    border: none !important;
}

.sf-custom-new .nav-tabs>li>a {
    color: #23262f !important;
    font-family: "Poppins", Sans-serif !important;
    font-size: 18px !important;
    font-weight: 500 !important;
}

.sf-custom-new .nav-tabs>li>a:hover {
    opacity: 0.7;
}

.sf-custom-new .nav-tabs>li.active>a {
    color: #1D1D1D !important;
    font-family: "Poppins", Sans-serif !important;
    font-size: 18px !important;
    font-weight: 500 !important;
}

.tabbable .nav-tabs li.active a,
.tabbable .nav-tabs li:hover a,
.tabbable .nav-tabs li:focus a {
    background: #fff !important;
    color: #555555 !important;
    border: 1px solid #d7d1d1 !important;
    border-bottom: #fff !important;
}

.tabbable .nav-tabs li a {
    color: #c2c2c2 !important;
}

/*Hide comments icon from articles */
.sf-provi-art-comment {
    display: none !important;
}

/*Terms condition on sign up modal */
.sgnupbtn {
    margin: 15px 0;
}

.terms-text {
    color: #5f5f5f !important;
}

.link-href-modal {
    color: #000000 !important;
}

.link-href-modal:hover {
    color: #f49c9e !important;
}

/*Featured title tagline*/
.ele-tagline-featured {
    padding: 10px 0;
}

.full-length {
    width: 100%
}

/*Go to provider page ask question link*/
.provider-link-under-text {
    padding: 15px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    border-radius: 4px;
    background-color: #d9edf7;
}

.provider-link-under-text a {
    text-decoration: underline;
}

.provider-link-under-text a:hover {
    text-decoration: underline;
    color: #31708f;
}

/*Coupon popup fixes*/
.sf-couponcode-popup-overlay {
    opacity: 0.3 !important;
    background-color: #ffffff4a !important;
}

.sf-couponcode-popup {
    height: auto !important;
}

/*Unhide Listings*/
#bookingservices>li.sf-service-visible {
    display: list-item !important;
}

/* Sign up Login form modify */

/* Sign up Login form modify - Updated for single column layout */

.col-md-4,
.col-md-12,
.col-md-6,
.col-md-8 {
    margin-top: 10px !important;
}

.small,
small {
    font-size: 95%;
}

.page-content {
    flex: 1;
    padding-bottom: 0 !important;
}

a:hover,
a:focus {
    text-decoration: none;
}

.form-control:focus {
    border-color: #E75301 !important;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 8px rgb(236 85 35 / 19%);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 8px rgb(236 85 35 / 19%);
}

.sf-register-page {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 50px;
    max-width: 450px;
    margin: 0 auto;
    min-height: calc(100vh - 190px);
    overflow: hidden;
}

/* Single column form styling */
.customer-bx {
    width: 100%;
}

.form-group {
    margin-bottom: 20px;
    width: 100%;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: #555;
    font-size: 14px;
}

.form-control {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
    transition: border-color 0.3s;
    height: auto;
}

.verified-email-box {
    background: #f5f5f5;
    padding: 12px 15px;
    border-radius: 4px;
    border: 1px solid #ddd;
    position: relative;
    margin-bottom: 5px;
    width: 100%;
}

.verified-email-box .fa-check-circle {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
}

.verified-email-display {
    color: #333;
}

.password-hint {
    font-size: 12px;
    color: #777;
    margin-top: 5px;
    display: block;
}

.signup-step-1,
.signup-step-2,
.signup-step-role,
.signup-step-3 {
    width: 100%;
    max-width: 350px;
}

.signup-step-1,
.signup-step-2,
.signup-step-role {
    height: calc(100svh - 380px);
}

.form-button {
    margin-bottom: 5px;
    width: 100%;
}

.or-div {
    width: 100%;
    display: flex;
    flex-direction: row;
    text-transform: uppercase;
    border: none;
    font-size: 12px;
    font-weight: 500;
    margin: 0;
    padding: 35px 0 0;
}

.or-div span {
    text-align: center;
    flex: 0.2 0 auto;
    margin: 0;
}

.or-div:before,
.or-div:after {
    content: "";
    border-bottom: 1px solid #c2c8d0;
    flex: 1 0 auto;
    height: .5em;
    margin: 0;
}

.signup-form-header {
    text-align: center;
    margin: 0 0 35px 0;
    width: 100%;
}

.btn-main {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    height: 50px;
    width: 100%;
    background-color: #E75301;
    color: #fff;
    margin: 24px 0 0;
    border-radius: 6px !important;
    padding: 4px 16px;
    font: inherit;
    border-width: 0;
    cursor: pointer;
}

.btn-main:hover,
.btn-main:active,
.btn-main:focus {
    background-color: #CD4801;
    border-color: #CD4801;
}

.btn-main:active:hover,
.btn-main:active:focus {
    background-color: #CD4801;
    border-color: #CD4801;
}

/* Captcha alignment */
.captchaouter {
    width: 100%;
    margin: 10px 0;
}

/* Form text alignment */
.form-group.text-center {
    text-align: center;
    margin-top: 20px;
}

/* Input with validation */
.has-feedback .form-control {
    padding-right: 42.5px;
}

.has-feedback .form-control-feedback {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    display: block;
    width: 34px;
    height: 34px;
    line-height: 34px;
    text-align: center;
    pointer-events: none;
}

/* Error message styling */
.help-block {
    font-size: 12px;
    color: #a94442;
    margin-top: 5px;
}

/* For smaller screens */
@media (max-width: 767px) {
    .sf-register-page {
        padding: 20px;
    }

    .signup-step-1,
    .signup-step-2,
    .signup-step-role,
    .signup-step-3 {
        max-width: 100%;
    }

    .btn-main {
        width: 100%;
    }
}

/* Button text */
.header-style8.sf-header-inner .extra-nav .extra-cell a.btn {
    background-color: #fff !important;
}

.header-style8.sf-header-inner .extra-nav .extra-cell a.btn:hover {
    border: 2px solid #bdbdbd;
    color: #222222 !important;
}

a.btn.btn-primary:focus,
.btn-primary:hover,
.btn-primary.focus,
.btn-primary:focus {
    background-color: #CD4801 !important;
    color: #fff !important;
}

.form-submit #submit:hover {
    background-color: #CD4801;
}

.btn-primary {
    background-color: #E75301 !important;
    color: #FFFFFF;
    padding: 10px 14px;
    margin: 0px;
    font-weight: 500 !important;
    border-radius: 10px;
    border: 1px solid #E75301;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: #CD4801 !important;
    color: #FFFFFF;
}

.btn-secondary {
    background-color: #ffffff !important;
    color: #222 !important;
    padding: 10px 14px;
    margin: 0px 10px;
    font-weight: 500 !important;
    border-radius: 10px;
    border: 1px solid #222 !important;
}

.btn-secondary:hover {
    background-color: #f9f9f9 !important;
}

.nav-btn-admin {
    background: #E75301 !important;
}

/* .nav-btn-admin:hover {
    background: #022279 !important;
} */


/* Hide the dashboard menu button on desktop */
.nav-btn-admin {
    display: none;
}

.mobile-sidebar-toggle {
    display: none;
}

@media (max-width: 767px) {
    .mobile-sidebar-toggle {
        display: block;
        position: absolute;
        left: -5px;
        top: 50%;
        transform: translateY(-50%);
    }

    .my-account-logo {
        padding-left: 40px !important;
    }
}

.admin-top-area {
    display: none !important;
}

/* Base styles for the dropdown container */
.aon-admin-messange {
    display: flex;
    align-items: center;
    position: relative;
    padding-right: 15px;
    /* Create space for the arrow */
}

/* Style for the dropdown icon */
.aon-admin-messange .fa-caret-down {
    position: absolute;
    right: 5px !important;
    font-size: 14px !important;
    color: #555;
}

/* Style for the avatar container */
.aon-admin-messange .feather-user-pic {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Responsive adjustments for mobile */
@media (max-width: 767px) {
    .aon-admin-messange {
        padding-right: 12px !important;
        /* Slightly less padding on mobile */
    }

    .aon-admin-messange .fa-caret-down {
        display: none !important;
        /* Smaller icon on mobile */
    }
}


.aon-messenger-icon-btn .btn {
    background-color: transparent !important;
}



/* Booking summary button hide */
.booking-summary-btn {
    display: none !important;
}


/* Roles card section Signup */
.form-card-group {
    display: flex;
    width: 100%;
    justify-content: center;
    align-items: center;
    gap: 40px;
    flex-wrap: wrap;
}

.petsity-card-button {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 20px;
    transition: box-shadow .3s, border .3s, background-color .3s;
    width: 280px;
    height: 200px;
    border-radius: 10px;
    border: 1px solid #ccc;
    background: #fff;
    gap: 20px;
}

.petsity-card-button:hover {
    box-shadow: 0 0 11px #e7530159;
    border: 1px solid #E75301;
    background-color: #fff8f5;
}

.card-btn-img {
    width: 85px;
    object-fit: fill;
}

.card-btn-txt {
    font-size: 20px;
    font-weight: 500;
}

.btn-primary[disabled] {
    background-color: #CD4801 !important;
    border-color: #CD4801 !important;
}

/* Notifications styles */

.notification {
    position: fixed;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    padding: 15px 25px;
    border: 1px solid transparent;
    border-radius: 4px;
    z-index: 9999;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    min-width: 300px;
    max-width: 90%;
    text-align: center;
    animation: slideDown 0.3s ease-out;
}

.notification-success {
    color: #155724;
    background-color: #d4edda;
    border-color: #c3e6cb;
}

.notification-error {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
}

.alert.alert-success {
    background-color: #d4edda;
    border-color: #c3e6cb;
    color: #155724;
    font-size: 14px;
    font-weight: 400;
}

.alert.alert-success:before,
.alert.alert-success:after {
    color: #155724;
}

.alert.alert-danger {
    background-color: #f8d7da;
    border-color: #f5c6cb;
    color: #721c24;
    font-size: 14px;
    font-weight: 400;
}

.alert.alert-danger:before,
.alert.alert-danger:after {
    color: #721c24;
}

.sf-card-group {
    text-align: center;
}

@keyframes slideDown {
    from {
        top: -100px;
        opacity: 0;
    }

    to {
        top: 20px;
        opacity: 1;
    }
}

.bootstrap-select.disabled {
    background-color: #f8f9fa;
    opacity: 0.9;
}

.bootstrap-select.disabled .dropdown-toggle {
    cursor: not-allowed !important;
    background-color: #f8f9fa !important;
    opacity: 0.9;
}

.bootstrap-select.disabled .dropdown-toggle:hover,
.bootstrap-select.disabled .dropdown-toggle:focus {
    background-color: #f8f9fa !important;
}

.bootstrap-select.disabled .dropdown-menu {
    display: none !important;
}

/* Login form UI */
.loginform_dx_outer {
    display: flex;
    justify-content: center;
    height: calc(100vh - 190px);
}

.loginform_dx {
    max-width: 320px;
    padding-top: 50px;
}

.sf-otherlogin-wrap {
    display: flex;
    justify-content: center;
}

.sf-nextend-center {
    width: 100% !important;
}

.nsl-container {
    text-align: center !important;
}

/* Identity check section */
.aon-card-body div.RWMB-drag-drop {
    height: 260px !important;
}

.drag-drop-inside.text-center {
    font-size: 16px !important;
    padding: 10px !important;
}

.drag-drop-buttons .button {
    background-color: #f9f9f9 !important;
    color: #222 !important;
    border: 1px solid #bfbfbf !important;
}

.drag-drop-buttons .button:active,
.drag-drop-buttons .button:hover,
.drag-drop-buttons .button:focus {
    background-color: #fff !important;
    color: #000 !important;
    border: 1px solid #7A7A7A !important;
    cursor: pointer;
}

.items-center {
    text-align: center;
}

/* Forgot password UI */

.reset-new-pass-cnt {
    padding-top: 20px;
    min-height: calc(100vh - 318px);
}

.forgot-pass-page-cont {
    padding-top: 50px;
    flex-wrap: wrap;
    justify-content: center;
    height: calc(100vh - 250px);
    display: none;
}

.forgot-pass-page-cont.show {
    display: flex !important;
}

.forgot-pass-wrap {
    max-width: 320px;
}

/* Provider cards UI */
.petsity-provider-card-wrap {
    margin: 0;
}

.petsity-provider-card {
    background-color: #ffffff;
    border-radius: 10px;
    position: relative;
    overflow: hidden;
    margin: 0.15rem;
    transition: box-shadow 0.3s ease;
}

.card-link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: inherit;
    z-index: 1;
}

.petsity-provider-card:hover {
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
    border: 1px solid #E75301;
}

.featured-tag {
    background-color: #e6f7ff;
    color: #0088cc;
    padding: 4px 8px;
    position: absolute;
    top: 12px;
    left: 12px;
    border-radius: 4px;
    font-size: 12px;
    z-index: 2;
}

.card-content {
    padding: 45px 24px;
    position: relative;
}

.provider-header {
    display: flex;
    gap: 20px;
    position: relative;
}

.provider-image-container {
    position: relative;
    width: 80px;
    height: 80px;
    flex-shrink: 0;
}

.provider-image {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}

.verified-badge {
    position: absolute;
    bottom: -4px;
    right: -4px;
    width: 24px;
    height: 24px;
    background: white;
    border-radius: 50%;
    padding: 2px;
    z-index: 2;
}

.provider-info {
    flex: 1;
}

.provider-top-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.provider-name {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
}

.provider-name span {
    color: inherit;
}

.provider-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    position: absolute;
    top: -28px;
    right: -8px;
    z-index: 2;
}

.favorite-button,
.more-button {
    background: none;
    border: none;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #666;
    transition: all 0.3s ease;
    position: relative;
}

.favorite-button i,
.more-button i {
    font-size: 18px;
    transition: all 0.3s ease;
}

.favorite-button:hover,
.more-button:hover {
    background-color: rgba(0, 0, 0, 0.05);
    transform: translateY(-2px);
}

.favorite-button:active,
.more-button:active {
    transform: translateY(0);
}

.favorite-button.removefromfavoriteshort i {
    color: #ff4444;
}

.favorite-button.removefromfavoriteshort:hover {
    background-color: rgba(255, 68, 68, 0.1);
}

.provider-address {
    display: flex;
    align-items: center;
    gap: 6px;
    color: #666;
    font-size: 14px;
    margin: 0 0 12px 0;
}

.provider-address i {
    font-size: 16px;
}

.provider-rating {
    margin-bottom: 20px;
}

.provider-description {
    color: #7a7a7a;
    font-size: 15px;
    line-height: 1.5;
    margin: 10px 0;
}

/* Pet service provider categories column */
.three-col-layout {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}

.three-col-layout .category-group {
    flex: 1 1 250px;
    /* 3 columns on wide screen, auto stacks on small */
    min-width: 200px;
}

.three-col-layout .category-group h5 {
    margin-bottom: 10px;
    font-weight: 600;
}

.sf-radio-checkbox {
    margin-bottom: 6px;
}


/* Enhanced Pet Preferences Styling */
.pets-at-home-options,
.living-conditions-options,
.dog-size-preferences {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
    margin-top: 10px;
}

/* Radio button styling improvements */
.radio-inline-box {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-top: 10px;
}

.radio-inline-box .radio.sf-radio-checkbox {
    margin: 0;
    min-width: 120px;
}

/* Checkbox styling improvements */
.checkbox.sf-radio-checkbox {
    margin-bottom: 12px;
}

.checkbox.sf-radio-checkbox input[type="checkbox"]:checked+label,
.radio.sf-radio-checkbox input[type="radio"]:checked+label {
    color: #E75301;
    font-weight: 600;
}

/* Form section spacing */
#aon-pet-preferences-panel .form-group {
    margin-bottom: 25px;
}

#aon-pet-preferences-panel .form-group:last-child {
    margin-bottom: 0;
}

/* Dog size section transition */
#dog-size-section {
    border-left: 3px solid #E75301;
    padding-left: 15px;
    margin-left: 10px;
    background-color: #fff8f5;
    border-radius: 0 8px 8px 0;
    padding: 15px;
    margin-top: 15px;
}

#dog-size-section label {
    color: #E75301;
    font-weight: 600;
}

/* Enhanced form validation styling */
.has-error .form-control,
.has-error .sf-form-control {
    border-color: #dc3545;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.error-message {
    display: block;
    color: #dc3545;
    font-size: 12px;
    margin-top: 5px;
    font-weight: 500;
}



/* Loading states */
.loading-avatar {
    opacity: 0.6;
    pointer-events: none;
}

.loading-avatar::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 20px;
    height: 20px;
    border: 2px solid #E75301;
    border-top: 2px solid transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: translate(-50%, -50%) rotate(0deg);
    }

    100% {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}


/* Rest of your existing CSS remains the same */

@media (max-width: 480px) {
    .petsity-provider-card {
        position: relative;
    }

    .provider-header {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .provider-top-row {
        flex-direction: column;
        align-items: center;
        width: 100%;
    }

    .provider-actions {
        position: absolute;
        top: -28px;
        right: -8px;
        margin: 0;
        background: rgba(255, 255, 255, 0.9);
        padding: 4px;
        border-radius: 20px;
        backdrop-filter: blur(4px);
        gap: 4px;
    }

    .provider-address {
        justify-content: center;
    }

    .provider-name {
        margin-top: 10px;
    }

    .favorite-button,
    .more-button {
        width: 32px;
        height: 32px;
    }

    .favorite-button i,
    .more-button i {
        font-size: 16px;
    }
}

.close-btn-bx {
    display: none;
}


/* Dashboard UI */
/* Profile Cards Layout */
.dashboard-card {
    padding: 20px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
    height: 100%;
    transition: transform 0.2s ease;
}

.dashboard-card:hover {
    transform: translateY(-3px);
}

.dashboard-card-icon {
    width: 45px;
    height: 45px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 15px;
}

.dashboard-card-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
}

.dashboard-card-text {
    font-size: 13px;
    color: #666;
    margin-bottom: 15px;
}

.dashboard-card-link {
    color: #007bff;
    font-size: 14px;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 5px;
}

/* Icon Background Colors */
.bg-primary-light {
    background: #e8f0fe;
}

.bg-success-light {
    background: #e6f4ea;
}

.bg-warning-light {
    background: #fef7e6;
}

.bg-info-light {
    background: #e8f0fe;
}

.sf-provi-service-price {
    color: #E75301 !important;
    font-weight: 600;
}

.aon-pro-avtar-pic img {
    width: 200px;
    height: 200px;
    object-fit: cover;
    border-radius: 50%;
    /* Optional for circle avatar */
    display: block;
    margin: 0 auto;
}

.aon-pro-avtar-pic {
    width: 200px;
    height: 200px;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.become-sitter-alert {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1.2rem;
}

.aon-staff-avtar-header {
    background-color: #e4e4e4 !important;
}

.aon-backto-account {
    background: #E75301 !important;
}

.sf-radio-checkbox input[type=checkbox]:checked+label:before {

    border-width: 10px;
    border-color: #E75301 !important;
}

.sf-radio-checkbox input[type=radio]:checked+label:before {

    border-color: #E75301 !important;

    border-width: 5px;
}

.sf-radio-checkbox input[type=checkbox]+label:hover:before,
.sf-radio-checkbox input[type=radio]+label:hover:before {

    border-color: #E75301 !important;
}

.alert-info {
    color: #E75301 !important;
    background-color: #fff6f0 !important;
    border-color: #ffd5be !important;
}

#plavatarupload-browse-button {
    color: #000 !important;
    cursor: pointer;
    opacity: 0;
    height: 100%;
    width: 100%;
}

/* ───────── Petsitter onboarding form tweaks ───────── */

/* logical spacing between the major blocks */
.petsitter-section {
    margin-bottom: 35px;
}

.petsitter-section:last-of-type {
    margin-bottom: 0;
}

/* lightweight horizontal divider after each section-heading */
.petsitter-section>.section-head {
    font: 600 18px/1.4 "Poppins", sans-serif;
    margin: 0 0 15px;
    /* title spacing */
}

.petsitter-section:not(:first-of-type)>.section-head:before {
    content: "";
    display: block;
    height: 1px;
    background: #eee;
    margin: 32px 0 24px;
}

/* two-column grid on ≥768 px, stacked on mobile  */
.petsitter-grid {
    display: grid;
    grid-gap: 20px 24px;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

/* avatar pick-box keeps the square aspect ratio */
.aon-pro-avtar-pic {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px dashed #ddd;
    display: flex;
    align-items: center;
    justify-content: center;
}

.aon-pro-avtar-pic img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* pill-style radio/checkbox (dog size, housing, etc.)  */
.petsity-pill {
    position: relative;
    display: inline-block;
    margin: 6px 8px 6px 0;
}

.petsity-pill input {
    display: none
}

.petsity-pill span {
    display: inline-block;
    padding: 6px 18px;
    border: 2px solid #ddd;
    border-radius: 22px;
    background: #fafafa;
    font-size: 14px;
    cursor: pointer;
    transition: all .25s;
}

.petsity-pill input:checked+span {
    background: #E75301;
    border-color: #E75301;
    color: #fff;
    box-shadow: 0 2px 4px rgba(231, 83, 1, .25);
}

.petsity-pill input:focus+span {
    outline: 2px solid #E7530170
}

/* validation helper */
.validation-message {
    font-size: 12px;
    color: #dc3545;
    margin-top: 4px
}

/* dog-size block hidden by default on DOM load */
.dog-size-group {
    display: none
}

/* compact three-column category chooser that you already have */
.three-col-layout .sf-radio-checkbox {
    margin-bottom: 8px
}

/* submit button full-width and sticky on very long screens */
#submit-fixed {
    width: 100%
}

@media(min-width:992px) {
    #submit-fixed.fixed {
        position: fixed;
        bottom: 25px;
        right: 25px;
        left: auto;
        width: auto
    }
}

/* Fixed Cropper Modal Styles */
.custom-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.custom-modal-content {
    background: #fff;
    padding: 20px;
    border-radius: 10px;
    max-width: 600px;
    /* Increased from 420px */
    width: 90%;
    max-height: 90vh;
    position: relative;
    display: flex;
    flex-direction: column;
}

.custom-modal-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 20px;
    font-weight: bold;
    cursor: pointer;
    color: #999;
    z-index: 10001;
}

.custom-modal-close:hover {
    color: #000;
}

.cropper-wrapper {
    width: 100%;
    height: 400px;
    /* Increased from 300px */
    position: relative;
    margin: 15px 0;
    overflow: visible;
    /* Changed from hidden */
}

.cropper-wrapper img {
    max-width: 100%;
    display: block;
    max-height: 400px;
}

/* Remove problematic cropper overrides - let cropper.js handle positioning */
.custom-modal-content .cropper-container {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
}

.custom-modal-content .cropper-canvas,
.custom-modal-content .cropper-crop-box,
.custom-modal-content .cropper-drag-box,
.custom-modal-content .cropper-wrap-box {
    position: absolute !important;
    max-width: none !important;
    max-height: none !important;
}

/* Avatar Preview Styling */
.aon-pro-avtar-pic {
    position: relative;
    width: 150px;
    height: 150px;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 50%;
    background: #f5f5f5;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 3px solid #E75301;
}

.aon-pro-avtar-pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.upload-label {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background-color: #E75301;
    color: #fff;
    border-radius: 50%;
    padding: 6px 7px;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.upload-label:hover {
    background-color: #d64500;
}

/* Button styling */
.btn-secondary {
    background-color: #6c757d;
    border-color: #6c757d;
    color: #fff;
    padding: 8px 16px;
    border-radius: 4px;
    margin-right: 10px;
}

.btn-secondary:hover {
    background-color: #5a6268;
    border-color: #545b62;
}

.btn-primary {
    background-color: #E75301;
    border-color: #E75301;
    color: #fff;
    padding: 8px 16px;
    border-radius: 4px;
}

.btn-primary:hover {
    background-color: #d64500;
    border-color: #d64500;
}

/* Mobile responsive adjustments */
@media (max-width: 768px) {
    .custom-modal-content {
        padding: 15px;
        margin: 10px;
        max-width: 95%;
    }

    .cropper-wrapper {
        height: 300px;
    }
}

@media (max-width: 480px) {
    .custom-modal-overlay {
        padding: 10px;
    }

    .cropper-wrapper {
        height: 250px;
    }
}

/*Account bottom buttons */
.account-btns {
    flex-wrap: nowrap !important;
    gap: 20px;

}

.sf-check-my-profile {
    min-width: 160px !important;
    display: flex;
    flex-grow: 1;
    gap: 20px;
}

.sf-submit-my-profile {
    width: auto !important;
    float: right;
}

@media only screen and (max-width: 1200px) {
    .slider .tooltip.tooltip-main {
        opacity: 0;
    }
}

.profiles-content h3,







.profiles-content h4,







.profiles-content h5,







.profiles-content h6 {







    margin-top: 20px !important;
    margin-bottom: 15px !important;







}

/* Hero background */
.petsity-hero {
    position: relative;
    min-height: 90vh;
    display: flex;
    align-items: center;
    justify-content: center;
    /* padding: 0px 0px 30px 0px; */
}

.petsity-hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    /* background: rgba(255, 255, 255, 0.65); */
    background: #FDF3EB91;
    z-index: 0;
}

.petsity-hero .container {
    position: relative;
    z-index: 2;
    color: #fff;
    padding-top: 100px;
}

/* Text */
.hero-title {
    font-size: 58px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #2c2c2c;
}

.hero-subtitle {
    font-size: 18px;
    font-weight: 400;
    color: #404040;
    padding-bottom: 20px;
}

.search-label {
    font-weight: 600;
    margin-bottom: 10px;
    display: block;
}

/* Pills */
.option-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.pill-option input {
    display: none;
}

.pill-option span {
    padding: 10px 20px;
    border: 2px solid #ddd;
    border-radius: 30px;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 15px;
    background: #f9f9f9;
}

.pill-option input:checked+span {
    background: #E75301;
    border-color: #E75301;
    color: #fff;
}

.pill-input {
    color: #222 !important;
}

/* Pill inputs (text fields styled same) */
/* .pill-input {
    width: 100%;
    border-radius: 30px;
    border: 2px solid #ddd;
    padding: 10px 20px;
    font-size: 15px;
} */

/* Location field with button */
.location-wrapper {
    position: relative;
}

.btn-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: 18px;
    color: #E75301;
    cursor: pointer;
}

/* Search Button */
.btn-search {
    background: #E75301;
    color: #fff;
    padding: 14px 40px;
    border-radius: 30px;
    font-family: "recoleta", Sans-serif;
    font-size: 2.4rem;
    font-weight: 500;
    border: none;
    cursor: pointer;
    transition: 0.3s;
}

.btn-search:hover {
    background: #cc4a01;
}

/* ---------------------------
   Petsity hero search improvements
   (Spacing, readable labels, pill radios like PetBae)
   --------------------------- */

.petsity-search-card {
    max-width: 820px;
    margin: 0 auto 30px;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 18px;
    padding: 28px;
    box-shadow: 0 6px 26px rgba(0, 0, 0, 0.08);
    text-align: left;
}

.petsity-search-card .search-group {
    display: block;
    margin-bottom: 30px;
}

.petsity-search-card .search-label {
    display: block;
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
    font-size: 15px;
}

.option-row {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

/* Pills (pet type / service / pets count) */
.pill-option {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    cursor: pointer;
}

.pill-option input[type="radio"],
.pill-option input[type="checkbox"] {
    display: none;
}

.pill-option span {
    display: inline-block;
    padding: 10px 18px;
    border-radius: 28px;
    border: 2px solid #e8e8e8;
    background: #fff;
    font-weight: 600;
    color: #444;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .18s ease;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
}

/* active */
.pill-option input:checked+span,
.pill-option .service-pill input:checked+span,
.petsity-pill input:checked+span {
    background: #E75301;
    color: #fff;
    border-color: #E75301;
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(231, 83, 1, 0.14);
}

/* Hover */
.pill-option:hover span {
    transform: translateY(-2px);
    border-color: #E75301;
}

/* Service pills card spacing */
.service-type-options {
    margin-top: 6px;
    min-height: 44px;
}

/* placeholder message */
.service-placeholder {
    color: #666;
    font-style: italic;
    padding: 10px 12px;
}

/* Inputs (date, location) styled with pill look */
.pill-input {
    width: 100%;
    padding: 12px 16px;
    border-radius: 26px !important;
    border: 2px solid #e9e9e9;
    font-size: 15px;
    background: #fff;
    transition: box-shadow .15s ease, border-color .15s ease;
}

.pill-input:focus {
    outline: none;
    border-color: #E75301;
    box-shadow: 0 6px 18px rgba(231, 83, 1, 0.08);
}

/* location wrapper */
.location-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
}

.location-wrapper .btn-icon {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    font-size: 18px;
    color: #E75301;
    cursor: pointer;
}

/* Search button centered */
.petsity-search-card .search-submit {
    text-align: center;
}

/* .btn-search {
    background: #E75301;
    color: #fff;
    padding: 12px 42px;
    border-radius: 28px;
    border: 0;
    font-weight: 700;
    font-size: 18px;
    box-shadow: 0 8px 18px rgba(231, 83, 1, 0.12);
} */

/* Responsive */
@media (max-width: 880px) {
    .petsity-search-card {
        padding: 18px;
    }

    .pill-option span {
        padding: 9px 14px;
        font-size: 14px;
        min-height: 36px;
    }

    .btn-search {
        width: 80%;
    }
}

.pet-type-options .pill-option span {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 30px;
    border: 2px solid #ddd;
    background: #fff;
    font-weight: 500;
    font-size: 15px;
    transition: all 0.2s ease;
    cursor: pointer;
}

.pet-type-options .pill-option input:checked+span {
    background: #E75301;
    border-color: #E75301;
    color: #fff;
    box-shadow: 0 4px 10px rgba(231, 83, 1, 0.2);
}

.pet-type-options .pill-option:hover span {
    border-color: #E75301;
}

.pill-option>span img {
    width: 22px;
    height: 22px;
    object-fit: contain;
}

.pill-option input:checked+span img {
    filter: brightness(0) invert(1);
}


/* Triton Verified Profile Styles */
.triton-verified-profile {
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
}

.triton-profile-image-wrapper {
    position: relative;
    text-align: center;
}

.triton-profile-image {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid #fff;
    background-color: #fff;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    position: relative;
}

.triton-profile-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.triton-verification-badge-animated {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 75px;
    height: 75px;
    z-index: 10;
    /* Changed to infinite loop instead of single animation */
    animation: badgeShine 3s ease-in-out infinite;
}

@keyframes badgeShine {

    0%,
    100% {
        filter: brightness(1);
        transform: scale(1);
    }

    50% {
        filter: brightness(1.3) drop-shadow(0 0 10px rgba(0, 255, 26, 0.6));
        transform: scale(1.2);
    }
}

/* Verified Actions Section */
.triton-verified-actions {
    display: flex;
    justify-content: center;
    margin-top: 20px;
    gap: 10px;
}

.triton-verified-actions a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.triton-verified-actions a i {
    font-size: 16px;
}

/* Responsive adjustments */
@media (max-width: 767px) {
    .triton-profile-image {
        width: 150px;
        height: 150px;
    }

    .triton-verification-badge-animated {
        width: 60px;
        height: 60px;
    }

    .triton-verified-actions {
        flex-direction: column;
    }

    .triton-verified-actions a {
        width: 100%;
        justify-content: center;
    }
}

/*============= Google text suggestion ================ */

/* Force the container to have a solid background and reset text colors */
.pac-container {
    background-color: #ffffff !important;
    border: 1px solid #e6e6e6 !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    z-index: 999999 !important;
    margin-top: 5px !important;

    /* Safari-specific text rendering */
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;

    /* Reset webkit text fill color - THIS IS THE KEY FIX */
    -webkit-text-fill-color: initial !important;
    color: #333333 !important;
}

/* Force all elements inside pac-container to have visible text */
.pac-container * {
    -webkit-text-fill-color: initial !important;
    color: inherit !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* ==========================================================================
   PAC Items - Individual dropdown rows
   ========================================================================== */

.pac-item {
    padding: 12px 16px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    border-top: 1px solid #f0f0f0 !important;
    background-color: #ffffff !important;

    /* Force text color */
    color: #333333 !important;
    -webkit-text-fill-color: #333333 !important;

    /* Safari text rendering */
    -webkit-font-smoothing: antialiased !important;
    text-rendering: optimizeLegibility !important;
}

.pac-item:first-child {
    border-top: none !important;
}

/* Hover state */
.pac-item:hover,
.pac-item.pac-item-selected,
.pac-item-selected {
    background-color: #f7f7f7 !important;
    color: #1a1a1a !important;
    -webkit-text-fill-color: #1a1a1a !important;
}

/* ==========================================================================
   PAC Item Query - Main location text (e.g., "Toronto")
   ========================================================================== */

.pac-item-query {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    -webkit-text-fill-color: #1a1a1a !important;
    padding-right: 5px !important;

    /* Ensure visibility */
    display: inline !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* ==========================================================================
   PAC Matched - Highlighted/matched text
   ========================================================================== */

.pac-matched {
    font-weight: 700 !important;
    color: #E75301 !important;
    -webkit-text-fill-color: #E75301 !important;
}

/* ==========================================================================
   Secondary text (city, province, country)
   ========================================================================== */

.pac-item>span:not(.pac-item-query):not(.pac-icon) {
    font-size: 13px !important;
    color: #666666 !important;
    -webkit-text-fill-color: #666666 !important;
    display: inline !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Alternative selector for secondary text */
.pac-item span+span {
    color: #666666 !important;
    -webkit-text-fill-color: #666666 !important;
}

/* ==========================================================================
   PAC Icon - Location pin icon
   ========================================================================== */

.pac-icon,
.pac-icon-marker {
    width: 20px !important;
    height: 20px !important;
    margin-right: 12px !important;
    flex-shrink: 0 !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Fallback icon styling if default doesn't show */
.pac-icon-marker {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23E75301'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z'/%3E%3C/svg%3E") !important;
}

/* ==========================================================================
   Google logo at bottom
   ========================================================================== */

.pac-logo::after,
.pac-container::after {
    background-position: right center !important;
    padding: 8px 10px !important;
    display: block !important;
}

/* ==========================================================================
   Safari-specific media query
   ========================================================================== */

/* Target Safari specifically using feature detection */
@supports (-webkit-touch-callout: none) {
    .pac-container {
        -webkit-text-fill-color: #333333 !important;
    }

    .pac-item {
        -webkit-text-fill-color: #333333 !important;
    }

    .pac-item-query {
        -webkit-text-fill-color: #1a1a1a !important;
    }

    .pac-item span {
        -webkit-text-fill-color: #666666 !important;
    }

    .pac-matched {
        -webkit-text-fill-color: #E75301 !important;
    }
}

/* ==========================================================================
   Additional Safari Webkit fixes
   ========================================================================== */

/* Reset any transform that might cause rendering issues */
.pac-container,
.pac-item,
.pac-item * {
    -webkit-transform: translateZ(0) !important;
    transform: translateZ(0) !important;
    -webkit-backface-visibility: hidden !important;
    backface-visibility: hidden !important;
}

/* Fix for Safari input styling that might affect autocomplete */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-text-fill-color: #333333 !important;
    transition: background-color 5000s ease-in-out 0s;
}

/* ==========================================================================
   Override any theme styles that might interfere
   ========================================================================== */

/* Reset from parent containers */
.aon-bnr2-search-box .pac-container,
.sf-advace-search-two .pac-container,
.petsity-search-card .pac-container,
.location-wrapper .pac-container,
body .pac-container {
    color: #333333 !important;
    -webkit-text-fill-color: initial !important;
}

.aon-bnr2-search-box .pac-item,
.sf-advace-search-two .pac-item,
.petsity-search-card .pac-item,
.location-wrapper .pac-item,
body .pac-item {
    color: #333333 !important;
    -webkit-text-fill-color: #333333 !important;
}

.aon-bnr2-search-box .pac-item-query,
.sf-advace-search-two .pac-item-query,
.petsity-search-card .pac-item-query,
.location-wrapper .pac-item-query,
body .pac-item-query {
    color: #1a1a1a !important;
    -webkit-text-fill-color: #1a1a1a !important;
}

/* ==========================================================================
   Force text visibility with pseudo-elements fallback
   ========================================================================== */

/* Ensure the text content is never hidden */
.pac-item::before {
    content: none !important;
}

/* Override any filter or blend mode effects */
.pac-container,
.pac-container * {
    filter: none !important;
    mix-blend-mode: normal !important;
}

#primary-menu {
    max-height: 100px;
}

.pcr-error-message {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-top: 50px;
}

.pcr-error-message a {
    font-family: 'recoleta';
    text-transform: none;
    font-size: 1.7rem;
    margin-top: 20px;
    padding: 10px 24px;
}