body {
    /*font-family: Arial, Helvetica, sans-serif;*/
    font-family: "Nunito", sans-serif;
    margin: 0;
}

a {
    color: #0056b3;
    text-decoration: none;
}

.inline {
    display: inline-block !important;
    vertical-align: top;
}

.no-margin {
    margin: 0 !important;
}

#navigation-menu {
    background-color: #3b8956;
    display: block;
    height: 4rem;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1;
}

#navigation-logo {
    color: #FFF;
    display: inline-block;
}

#navigation-logo img {
    margin: 1.3rem 2rem;
    height: 1.5rem;
}

#navigation-menu-buttons {
    float: right; 
    margin: 0 1rem;
}

.navigation-primary-cta {
    background-color: #FFF;
    border-radius: 3rem;
    color: #000;
    cursor: pointer;
    display: inline-block;
    font-weight: bold;
    font-size: 0.9rem;
    margin: 0.95rem 0.5rem 0;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

.navigation-primary-cta:hover {
    background-color: #EEE;
}

.navigation-secondary-cta {
    background-color: transparent;
    border: 2px solid #FFF;
    border-radius: 3rem;
    color: #FFF;
    cursor: pointer;
    display: inline-block;
    font-size: 0.9rem;
    margin: 0.95rem 0.5rem 0;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

.navigation-secondary-cta:hover {
    color: #EEE;
}

.centre-dialog {
    background: #FFF;
    border: 1px solid #AAA;
    display: inline-block;
    margin: 3rem 0 0 0;
    padding: 1rem 3rem;
}

main {
    height: calc(100vh - 6rem);
    margin: 1rem;
}

#sidebar-menu-container {
    background-color: #EEE;
    border-radius: 1rem;
    display: inline-block;
    height: calc(100% - 6rem);
    position: fixed;
    top: 5rem;
    vertical-align: top;
    width: 10rem;
    z-index: 3;
}

#sidebar-menu-bottom-container {
    bottom: 0;
    margin-bottom: 2rem;
    position: absolute;
    width: 100%;
}

#sidebar-menu {
    margin: 2rem 0;
    padding: 0;
}

#sidebar-menu li {
    list-style-type: none;
}

#sidebar-menu li a {
    display: block;
    color: #000;
    font-size: 1.15rem;
    text-decoration: none;
    transition: background-color 0.2s;
    padding: 0.5rem 1rem; 
}

#sidebar-menu li a:hover {
    background-color: #DDD;
}

#sidebar-menu li.active a {
    background-color: transparent !important;
    font-weight: bold;
}

#sidebar-menu-btn {
    align-items: center;
    background-color: #FFF;
    border: 1px solid #AAA;
    height: 3rem;
    width: 3rem;
    cursor: pointer;
    display: none;
    justify-content: center;
    left: 0;
    top: 4rem;
    transition: background-color 0.2s;
    position: fixed;
    z-index: 2;
}

#sidebar-menu-btn:hover {
    background-color: #EEE;
}

#sidebar-menu-btn svg {
    width: 1.25rem;
}

@media only screen and (max-width: 1200px) {
    .row {
        display: block !important;
    }

    #full-width-container {
        display: block !important;
    }

    #main-container {
        width: 100% !important;
    }

    .calendar {
        width: 225px !important;
    }

    .calendar-weekdays div, .calendar-week div {
        height: 1.85rem !important;
        width: 1.85rem !important;
    }

    .calendar-weekdays {
        font-size: 0.85rem;
    }

    .calendar-dates div.date-cell {
        font-size: 0.85rem;
    }

    .week-calendar-container {
        display: block !important;
        width: 100% !important;
    }

    .content-item-title, .content-item-description {
        width: calc(100vw - 14rem) !important;
    }

    .content-item-text-container > h2 {
        width: calc(100vw - 14rem) !important;
    }

    .list-img {
        height: 6rem !important;
        width: 6rem !important;
    }

    .list-item-open-btn, .list-item-edit-btn, .list-item-delete-btn {
        margin: 0.25rem 0.5rem 0 0 !important;
        padding: 0.25rem 0.75rem !important;
    }

    #main-container-fixed-banner {
        width: calc(100% - 14rem) !important;
    }

    .main-organisation-name-container {
        width: calc(100% - 4rem) !important;
    }
}

@media only screen and (max-width: 1000px) {
    #categories-container {
        display: block !important;
    }

    #services-container {
        display: block !important;
        width: 100% !important;
    }
}

@media only screen and (max-width: 900px) {
    .form-inline-row {
        display: block;
        width: calc(100% - 4rem) !important; 
    }
}

@media only screen and (max-width: 700px) {    
    .carousel-container {
        height: 20rem !important;
    }

    .carousel-slide {
        height: 20rem !important;
    }
    
    #main-organisation-book-btn {
        font-size: 1rem !important;
        left: 8rem !important;
        right: auto !important;
        top: 6rem !important;
        padding: 0.5rem 0.75rem !important;
    }

    #main-organisation-name {
        font-size: 1.5rem !important;
        margin: 0 !important; 
    }

    .list-item-title {
        font-size: 0.9rem !important;
        margin: 0 0 0.15rem !important;
    }

    .list-item-subtitle {
        font-size: 0.65rem !important;
    }

    /*.form-primary-btn {
        float: none !important;
        margin: 0.5rem 0 !important;
        padding: 0.25rem 0.75rem !important;
    }*/
}

@media only screen and (max-width: 600px) {
    #navigation-logo img {
        margin: 1.5rem 0 0 1rem;
        height: 1rem;
    }
    
    #sidebar-menu-btn {
      display: flex;
    }
    
    #sidebar-menu-container {
        display: none;
        height: calc(100% - 8rem);
        top: 7rem;
    }

    #sidebar-menu-container.visible {
        display: block !important;
    }

    #full-width-container {
        height: calc(100% - 1rem) !important;
        margin-left: 0rem !important;
        top: 5rem !important;
        width: 100% !important;
    }

    .centre-popup {
        width: calc(100% - 7rem) !important;
    }

    .default-hours-item {
        width: calc(100% - 2rem) !important;
    }

    .content-item {
        height: 5.5rem !important;
    }

    .content-item-text-container {
        padding: 0.5rem 1rem !important;
    }

    .content-item-title {
        font-size: 1rem !important;
    }

    .content-item-subtitle {
        font-size: 0.85rem !important;
        margin: 0.25rem 0 !important;
    }

    .content-item-description {
        font-size: 0.75rem !important;
        margin: 0.25rem 0 !important;
        -webkit-line-clamp: 1 !important;
    }

    .content-item-title, .content-item-description {
        width: calc(100vw - 12rem) !important;
    }

    .content-item-text-container > h2 {
        width: calc(100vw - 12rem) !important;
    }

    .content-item-img-container {
        height: 5.5rem !important;
    }

    .content-item-img {
        height: 5.5rem !important;
        width: 5.5rem !important;
    }

    .content-item-img-overlay {
        font-size: 1rem !important;
    }

    #main-container-fixed-banner {
        margin: -2rem 0rem !important;
        width: calc(100% - 2rem) !important;
    }

    .main-container-title {
        font-size: 1.5rem;
        margin: 1rem 3rem !important;
    }

}

@media only screen and (max-width: 500px) {
    #service-container .service .service-title {
        font-size: 1rem !important;
        margin: 0.5rem 0;
    }

    #service-container .service .service-book-btn {
        border-radius: 1rem !important;
        font-size: 0.75rem !important;
        margin: 0 1rem 0 0 !important;
        padding: 0.5rem 1rem !important;
    }

    #service-container .service {
        padding: 0 !important;
        overflow: hidden !important;
    }

    #service-container .service .service-subtitle {
        font-size: 0.75rem !important;
    }

    .list-img {
        margin: 0 0.5rem 0 0 !important;
    }
}

@media only screen and (max-width: 400px) {
    #map-container {
        height: 15rem !important;
    }
    
    .carousel-container {
        height: 15rem !important;
    }

    .carousel-slide {
        height: 15rem !important;
    }

    .centre-dialog {
        padding: 1rem 2rem;
        width: calc(100vw - 8rem);
    }

    .gsi-material-button {
        width: 100% !important;
    }

    .gsi-material-button-contents {
        font-size: 0.75rem;
    }
}

#centre-container {
    margin: 4rem 0;
    text-align: center;
}

#full-width-container {
    display: inline-flex;
    min-height: 100%;
    justify-content: center;
    margin: 0 0 0 1rem;
    margin-left: 11rem; 
    position: relative;
    top: 4rem;
    vertical-align: top;
    width: calc(100% - 12rem);
}

#full-width-container.full-width {
    margin: 1rem !important;
    top: 0rem !important; 
    width: calc(100% - 2rem) !important;
}

#main-container {
    display: inline-block;
    min-height: calc(100% - 2rem);
    margin: 0 auto;
    width: 60rem;
}

#main-container-fixed-banner {
    align-items: center;
    background-color: #FFF;
    border-bottom: 1px solid #AAA;
    display: flex;
    margin: -1rem 0;
    position: fixed;
    width: 60rem;
    z-index: 1;
}

.main-container-title {
    display: inline-block;
    color: #444;
    flex: 1;
    font-size: 1.75rem;
    margin: 1rem;
}

.main-container-subtitle {
    display: inline-block;
    color: #444;
    font-size: 1.5rem;
    margin: 1rem;
}

.main-container-button {
    background-color: #3b8956;
    border: none; 
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    font-size: 0.9rem;
    float: right;
    margin: 0.5rem 0.5rem 0;
    padding: 0.75rem 1.5rem;
}

.main-container-button:hover {
    background-color: #295f3c;
}

.main-container-button.centre {
    display: block;
    float: none;
    margin: 1rem auto;
    width: fit-content;
}

.main-content-container {
    border-radius: 1rem;
    display: block;
    min-height: calc(100% - 4rem);
    padding: 1rem;
}

.centre-popup {
    background-color: #EEE;
    border-radius: 1rem;
    display: block;
    padding: 2rem;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 4;
    width: 30rem; 
}

.centre-popup.large {
    width: auto; 
}

.centre-popup.hidden {
    display: none;
}

.centre-popup h1 {
    font-size: 1.5rem;
    margin: 0 0 1rem;
}

.form-label {
    display: block;
    font-size: 0.85rem;
    font-weight: bold;
    margin: 1rem 0 0.5rem 0;
}

.form-units {
    background-color: #FCFCFC;
    border: none;
    border-bottom: 2px solid #AAA;
    font-size: 0.85rem;
    height: 1.5rem;
    margin-left: 0.5rem;
    outline: none;
}

input[type=text], input[type=number] {
    background-color: #FCFCFC;
    border: none;
    border-bottom: 2px solid #AAA;
    font-size: 0.85rem;
    height: 1.5rem;
    outline: none;
    width: 100%;
}

input[type=number] {
    width: 4rem;
}

textarea {
    background-color: #FCFCFC;
    border: none;
    border-bottom: 2px solid #AAA;
    font-size: 0.85rem;
    outline: none;
    width: 100%;
}

.form-inline-row {
    display: inline-block;
    text-align: left;
    margin: 0 2rem;
    vertical-align: top;
    max-width: 350px;
    width: calc(50% - 4rem); 
}

.form-colour-option {
    color: #FFF;
}

.form-colour-option.blue {
    color: #4169E1;
}

.form-colour-option.red {
    color: #DC143C;
}

.form-colour-option.green {
   color: #228B22;
}

.form-colour-option.yellow {
    color: #DAA520;
}

.form-colour-option.orange {
    color: #FF8C00;
}

.form-colour-option.purple {
    color: #9370DB;
}

.form-colour-option.turquoise {
    color: #40E0D0;
}

.form-colour-option.pink {
    color: #FF1493;
}

.form-colour-option.brown {
    color: #8B4513;
}

.form-colour-option.grey {
    color: #708090;
}

.hidden {
    visibility: hidden;
}

.content-hidden {
    display: none !important;
}

.form-primary-btn {
    background-color: #3b8956;
    border: none;
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    display: inline-block;
    font-weight: bold;
    margin: 1rem 0.5rem 0 0;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

.form-secondary-btn {
    background-color: #FFF;
    border: none;
    border-radius: 0.5rem;
    color: #000;
    cursor: pointer;
    display: inline-block;
    font-weight: bold;
    margin: 1rem 0.5rem 0 0;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

.form-primary-btn:hover, .form-secondary-btn:hover {
    opacity: 0.8;
}

.form-error {
    color: red;
    font-size: 0.85rem;
}

.overlay {
    background-color: rgba(0,0,0,0.5);
    display: block;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 3;
}

.overlay.hidden {
    display: none;
}

.popup-container {
    max-height: 30rem;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 1rem;
}

.list-item {
    background-color: #F2F2F2;
    display: block;
    margin: 1rem 0;
    padding: 0 1rem 0 0;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.list-item.colour-0 {
    border-left: 2px solid #4169E1;
}

.list-item.colour-1 {
    border-left: 2px solid #DC143C;
}

.list-item.colour-2 {
    border-left: 2px solid #228B22;
}

.list-item.colour-3 {
    border-left: 2px solid #DAA520;
}

.list-item.colour-4 {
    border-left: 2px solid #FF8C00;
}

.list-item.colour-5 {
    border-left: 2px solid #9370DB;
}

.list-item.colour-6 {
    border-left: 2px solid #40E0D0;
}

.list-item.colour-7 {
    border-left: 2px solid #FF1493;
}

.list-item.colour-8 {
    border-left: 2px solid #8B4513;
}

.list-item.colour-9 {
    border-left: 2px solid #708090;
}

.list-item.flex, .list-item.inline-flex {
    align-items: center;
    display: flex !important;
}

.list-item.flex .list-text, .list-item.inline-flex .list-text {
    flex: 1;
}

.list-item.inline-flex button {
    margin: 0 !important;
}

.list-img {
    height: 8rem;
    margin: 0 1.5rem 0 0;
    object-fit: cover;
    width: 8rem;
    user-drag: none;
    -webkit-user-drag: none;
    pointer-events: auto;
}

.list-item-title {
    font-size: 1rem;
    font-weight: bold;
    margin: 0 0 0.5rem; 
}

.list-item-subtitle {
    font-size: 0.75rem;
}

.list-item-open-btn, .list-item-edit-btn, .list-item-delete-btn {
    background-color: #FFF;
    border: none;
    border-radius: 0.5rem;
    color: #000;
    cursor: pointer;
    display: inline-block;
    font-size: 0.75rem;
    font-weight: bold;
    margin: 1rem 0.5rem 0 0;
    padding: 0.5rem 1rem;
}

.list-item-open-btn:hover, .list-item-edit-btn:hover, .list-item-delete-btn:hover {
    opacity: 0.6;
}

.list-item-open-btn, .list-item-edit-btn {
    border: 1px solid #3b8956;
    color: #3b8956;
}

.list-item-delete-btn {
    background-color: red;
    border: 1px solid red;
    color: white;
}

.list-item-link-btn {
    color: #000;
    float: right;
    padding: 0.5rem;
}

.list-item-link-btn svg {
    width: 1.5rem;
}

#upcoming-bookings .list-item, #past-bookings .list-item {
    background-color: #F2F2F2;
    border: none;
    border-bottom: 1px solid #888;
    display: block;
    margin: 0;
    padding: 0.25rem 1rem;
}

#upcoming-bookings .list-item:last-child, #past-bookings .list-item:last-child {
    border-bottom: none;
}

#upcoming-bookings .list-item.colour-0, #past-bookings .list-item.colour-0 {
    border-left: 2px solid #4169E1;
}

#upcoming-bookings .list-item.colour-1, #past-bookings .list-item.colour-1 {
    border-left: 2px solid #DC143C;
}

#upcoming-bookings .list-item.colour-2, #past-bookings .list-item.colour-2 {
    border-left: 2px solid #228B22;
}

#upcoming-bookings .list-item.colour-3, #past-bookings .list-item.colour-3 {
    border-left: 2px solid #DAA520;
}

#upcoming-bookings .list-item.colour-4, #past-bookings .list-item.colour-4 {
    border-left: 2px solid #FF8C00;
}

#upcoming-bookings .list-item.colour-5, #past-bookings .list-item.colour-5 {
    border-left: 2px solid #9370DB;
}

#upcoming-bookings .list-item.colour-6, #past-bookings .list-item.colour-6 {
    border-left: 2px solid #40E0D0;
}

#upcoming-bookings .list-item.colour-7, #past-bookings .list-item.colour-7 {
    border-left: 2px solid #FF1493;
}

#upcoming-bookings .list-item.colour-8, #past-bookings .list-item.colour-8 {
    border-left: 2px solid #8B4513;
}

#upcoming-bookings .list-item.colour-9, #past-bookings .list-item.colour-9 {
    border-left: 2px solid #708090;
}

#upcoming-bookings .list-item-title, #past-bookings .list-item-title {
    font-size: 0.95rem;
    font-weight: bold;
    margin: 0 0 0.5rem; 
}

#upcoming-bookings .list-item-subtitle, #past-bookings .list-item-subtitle {
    font-size: 0.75rem;
}

#organisation {
    background-color: #e2ece5;
    border: 3px solid #AAA;
    border-radius: 1rem;
    padding: 1rem;
}

#organisation h2 {
    font-size: 1.25rem;
}

.member-content #organisation {
    border: none;
    padding: 0;
}

.member-content #organisation .organisation-cover-image {
    align-items: center;
    border-radius: 1rem;
    display: flex;
    height: 8rem;
}

.member-content #organisation .organisation-logo-image {
    margin: 1rem;
    position: absolute;
}

.member-content #organisation .organisation-text-content {
    display: inline-block;
    margin: 0 0 0 8rem;
}

.member-content #organisation .organisation-text-content > p {
    background-color: #FFF;
    display: block;
    margin: 0;
    font-size: 1rem;
    padding: 0.5rem; 
}

.member-content #organisation .organisation-text-content #member-organisation-business-name {
    font-size: 1.5rem;
    font-weight: bold;
}


#organisation-form {
    font-size: 0;
}

#organisation-btn-container {
    text-align: right;
}

.organisation-cover-image {
    background-color: #FFF;
    background-position: center;
    background-size: cover;
    height: 6rem;
    width: 100%;
}

.organisation-logo-image {
    background-color: #FFF;
    background-position: center;
    background-size: cover;
    height: 6rem;
    width: 6rem;
}

.organisation-image-btn {
    align-items: center;
    background-color: rgba(0,0,0,0.4);
    cursor: pointer;
    display: flex;
    justify-content: center;
    color: #FFF;
    font-size: 1rem;
    height: 100%;
    opacity: 0;
    transition: opacity 0.2s;
    width: 100%;
}

.organisation-image-btn:hover {
    opacity: 1;
}

.organisation-image-btn-text {
    text-align: center;
}

button[disabled] {
    cursor: default;
    opacity: 0.5 !important;
}

.row {
    display: inline-block;
    padding: 1rem;
    vertical-align: top;
}

.calendar {
    background: #f9f9f9;
    border: 1px solid #AAA;
    padding: 20px;
    width: 275px;
}

.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.calendar-body {
    justify-content: center;
    display: grid;
}

.calendar-weekdays {
    font-weight: bold;
}

.calendar-weekdays div, .calendar-week div {
    align-items: center;
    border: 1px solid transparent;
    box-sizing: border-box;
    display: inline-flex;
    height: 2.25rem;
    justify-content: center;
    text-align: center;
    vertical-align: middle;
    width: 2.25rem;
}

.calendar-dates div.date-cell {
    cursor: pointer;
}

.calendar-dates .working {
    background-color: #9CD99E;
}

.calendar-dates .not-working {
    background-color: transparent;
}

.calendar-dates .active {
    background-color: #6332c5;
    color: #fff;
}

.calendar-dates div.date-cell.disabled {
    background-color: #CCC;
    cursor: default;
}

.calendar-dates .selected {
    border: 1px solid #000 !important;
}

.week-calendar-container {
    display: inline-block;
    vertical-align: top;
    width: calc(100% - 360px);
}

.week-calendar, .week-calendar-headings {
    border-collapse: collapse;
    table-layout: fixed;
    vertical-align: top;
    width: 100%; 
}

.week-calendar thead, tbody {
}

.week-calendar-headings {
}

.week-calendar-heading {
    border: 1px solid #AAA;
    text-align: center; 
}

.week-calendar-day {
    font-size: 0.95rem;
    font-weight: normal;
}

.week-calendar-date {
    font-size: 0.95rem;
    font-weight: bold;
}

.week-calendar-slot {
    background-color: #FCFCFC;
    border: 1px solid #AAA;
    border-bottom: none;
    min-height: 1rem;
    height: 1rem;    
    padding: 0;
    position: relative;
}

.week-calendar-slot-item {
    border-bottom: 1px solid #AAA;
    font-size: 0.8rem;
    height: 1.5rem;    
    line-height: 1.5rem;
    text-align: center;
    vertical-align: middle;
}

.week-calendar-appointments {
    position: absolute;
    top: 0;
    width: 100%;
}

.week-calendar-appointment {
    background-color: #888;
    cursor: pointer;
    overflow: hidden;
    padding: 0.25rem;
    position: absolute;
    width: 100%;
}

.week-calendar-appointment.colour-0 {
    background-color: #d8e2fc;
    border-left: 2px solid #4169E1;
}

.week-calendar-appointment.colour-1 {
    background-color: #f5d8db;
    border-left: 2px solid #DC143C;
}

.week-calendar-appointment.colour-2 {
    background-color: #d8efd8;
    border-left: 2px solid #228B22;
}

.week-calendar-appointment.colour-3 {
    background-color: #f4f0c8;
    border-left: 2px solid #DAA520;
}

.week-calendar-appointment.colour-4 {
    background-color: #fef0d6;
    border-left: 2px solid #FF8C00;
}

.week-calendar-appointment.colour-5 {
    background-color: #e7def8;
    border-left: 2px solid #9370DB;
}

.week-calendar-appointment.colour-6 {
    background-color: #d4f7f6;
    border-left: 2px solid #40E0D0;
}

.week-calendar-appointment.colour-7 {
    background-color: #f9d7e0;
    border-left: 2px solid #FF1493;
}

.week-calendar-appointment.colour-8 {
    background-color: #ead9c6;
    border-left: 2px solid #8B4513;
}

.week-calendar-appointment.colour-9 {
    background-color: #d9dee4;
    border-left: 2px solid #708090;
}

.week-calendar-appointment:hover {
    box-shadow: 1px 2px 8px rgba(0,0,0,0.4);
    min-height: 5.5rem;
    min-width: 5.5rem;
    z-index: 3;
}

.week-calendar-appointment .week-calendar-appointment-heading {
    color: #000;
    font-size: 0.75rem;
    font-weight: bold;
}

.week-calendar-appointment .week-calendar-appointment-subheading {
    color: #000;
    font-size: 0.65rem;
    margin: 0.25rem 0;
}

.week-calendar-appointment .week-calendar-appointment-count {
    color: #000;
    font-size: 0.65rem;
}

.week-calendar-appointment .week-calendar-appointment-count svg {
    fill: #000;
    width: 0.5rem; 
}

.week-calendar-appointment .week-calendar-appointment-count span {
    margin: 0 0.35rem;
}

#month-year {
    font-weight: bold;
}

#calendar-staff-list {
    font-size: 1.05rem;
}

#bookings-table {
  max-height: 300px;      /* Set table body height */
  overflow-y: auto;       /* Enable vertical scrolling */
  border: 1px solid #ccc;
  width: 100%;            /* Optional: set container width */
}

#bookings-table table {
  width: 100%;
  border-collapse: collapse;
}

#bookings-table thead th {
  position: sticky;       /* Fix header */
  top: 0;
  background-color: #f1f1f1;
  z-index: 1;
}

#bookings-table th, td {
  padding: 10px;
  text-align: left;
  border: 1px solid #ddd;
}

#bookings-table td.red {
    background-color: #c69191;
}
#bookings-table td.amber {
    background-color: #c6ad91;
}
#bookings-table td.green {
    background-color: #91c6a3;
}

.default-hours-item {
    align-items: center;
    background-color: #EEE;
    border-top: none;
    display: flex;
    justify-content: flex-start;
    margin: 1rem 0;
    padding: 0.5rem;
}

.default-hours-item input[type=text] {
    width: 4rem;
}

.default-hours-heading {
    display: block;
    font-weight: bold;
    margin: 0 0 0.5rem;
}

.default-hours-text {
    font-size: 0.85rem;
    flex: 1;
}

.hours-from-input, .hours-to-input {
    width: 4rem !important;
}

.hours-row {
    margin: 0.5rem 0;
}

.hours-from-input, .hours-to-input {
    margin: 0 0.25rem;
}

.action-button {
    background-color: #111;
    color: #FFF;
    font-size: 0.75rem;
    font-weight: bold;
    padding: 0.35rem 0.75rem;
    margin: 0.5rem 0;
}

.radio-group {
    display: block;
    font-size: 0;
    margin: 0.5rem 0;
}

.radio-group .radio-option {
    background-color: #F3F3F3;
    font-size: 0.85rem;
    padding: 0.45rem 0.75rem;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.radio-group .radio-option.selected {
    background-color: #AAA !important;
}

/* Hide the default radio buttons */
.radio-group input[type="radio"] {
  display: none;
}

/* Style the label as a clickable box */
.radio-box {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: #FFF;
    cursor: pointer;
    transition: background 0.2s, border 0.2s, color 0.2s;
    font-family: inherit;
    font-size: 0.75rem;
}

/* When the radio is checked, highlight the box */
.radio-group input[type="radio"]:checked + .radio-box {
    background: #3b8956;
    color: #fff;
    font-weight: bold;
}

.form-inline {
    display: inline-block;
    margin: 0 1rem 0 0px;
}

.form-input-container {
    background-color: #FFF;
    display: block;
    text-align: center;
    padding: 0.5rem 0;
}

.form-input {
    align-items: center;
    background-color: #EEE;
    display: flex;
    margin: 0 1rem;
    text-align: left;
    padding: 0.5rem 0;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.form-input label {
    display: block;
    font-size: 0.8rem;
    font-weight: bold;
    margin: 0.5rem 0;
}

.form-input-btn {
    cursor: grab;
    padding: 0 1rem;
}

.form-input-btn svg {
    width: 0.75rem;
}

.form-delete-btn {
    cursor: pointer;
    padding: 1rem;
}

.form-delete-btn.disabled {
    cursor: default;
    opacity: 0.5;
}

.form-delete-btn svg {
    width: 1rem;
}

.form-add-btn {
    background-color: #FFF;
    border: none;
    box-shadow: 1px 2px 4px rgba(0,0,0,0.5);
    cursor: pointer;
    display: inline-block;
    font-size: 0.8rem;
    font-weight: bold;
    margin: 0 auto;
    padding: 0.5rem 2rem;
    transition: background-color 0.2s;
}

.form-add-btn:hover {
    background-color: #EEE;
}

.form-input-drop-area {
    background-color: transparent;
    left: 0;
    right: 0;
    top: -8px; /* or adjust as needed for spacing */
    height: 8px;
    transition: background-color 0.2s;
    z-index: 1;
    pointer-events: auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.form-input-drop-area.active {
    background-color: #0056b3;
}

.drop-area {
    background-color: transparent;
    left: 0;
    right: 0;
    top: -8px; /* or adjust as needed for spacing */
    height: 8px;
    transition: background-color 0.2s;
    z-index: 1;
    pointer-events: auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.drop-area.active {
    background-color: #0056b3;
}

#drag-label {
    background-color: #000;
    display: block;
    position: absolute;
    height: 3rem;
    width: 5rem;
    visibility: hidden;
    z-index: 4;
}

#drag-label.active {
    visibility: visible;
}

#service-container .service {
    align-items: center;
    background-color: #FAFAFA;
    border: 1px solid #AAA;
    border-radius: 1rem;
    display: flex;
    margin: 1rem 0;
    padding: 1rem;
}

#service-container .service .service-title {
    font-size: 1.65rem;
    margin: 0.5rem 0;
}

#service-container .service .service-subtitle {
    color: #444;
    font-size: 0.9rem;
    margin: 0.5rem 0;
}

#service-container .service .service-description {
    color: #444;
    font-size: 0.85rem;
    margin: 0.5rem 0;
}

#service-container .service .service-book-btn {
    background-color: #000;
    border: none;
    border-radius: 2rem;
    color: #FFF;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: bold;
    padding: 1rem 1.5rem;
    transition: background-color 0.2s;
}

#service-container .service .service-book-btn:hover {
    background-color: #444;
}

.staff {
    align-items: center;
    background-color: #FAFAFA;
    border: 1px solid #AAA;
    border-radius: 1rem;
    display: flex;
    margin: 1rem 0;
    padding: 1rem;
}

.staff-name {
    font-size: 1.5rem;
    flex: 1;
    margin: 0.5rem 0;
}

.staff-img {
    border-radius: 100rem;
    margin: 0 1.5rem 0 0 ;
    height: 5rem;
    width: 5rem;
}

.staff-book-btn {
    background-color: #000;
    border: none;
    border-radius: 2rem;
    color: #FFF;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: bold;
    padding: 1rem 1.5rem;
    transition: background-color 0.2s;
}

.staff-book-btn:hover {
    background-color: #444;
}

#slots-container .slot {
    background-color: #000;
    border: none;
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    display: inline-block;
    font-size: 0.85rem;
    font-weight: bold;
    margin: 0.5rem; 
    padding: 0.5rem 1rem;
    transition: background-color 0.2s;
}

#slots-container .slot.selected {
    background-color: #2e7ec4;
}

#reserve-booking-btn {
    background-color: #2e7ec4;
    border: none;
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    display: block;
    font-weight: bold;
    margin: 1rem 0.5rem;
    padding: 0.5rem 1rem;
    text-decoration: none;
    transition: background-color 0.2s;
}

#reserve-booking-btn:hover {
    background-color: #215b8e;
}

#reserve-booking-btn[disabled] {
    background-color: #2e7ec4 !important;
    cursor: default;
}

.login-btn {
    background-color: #EEE;
    border: 1px solid #AAA;
    border-radius: 2rem;
    cursor: pointer;
    display: block;
    margin: 1rem auto;
    padding: 0.75rem 2rem;
    transition: background-color 0.2s;
    width: 250px;
}

.login-btn:hover {
    background-color: #CCC;
}

.signup-btn {
    background-color: transparent;
    border: none;
    cursor: pointer;
    text-decoration: underline;
}

.guest-btn {
    background-color: #000;
    border: 1px solid #444;
    border-radius: 2rem;
    color: #FFF;
    cursor: pointer;
    display: block;
    margin: 1rem auto;
    padding: 0.75rem 2rem;
    transition: background-color 0.2s;
    width: 250px;
}

.guest-btn:hover {
    background-color: #444;
}

#login-area label {
    text-align: left;
}

#login-area div.hidden {
    display: none;
}

#login-area label {
    display: block;
    font-size: 0.8rem;
    font-weight: bold;
    margin: 0.5rem 0;
}

#login-area input {
    background-color: #FCFCFC;
    border: none;
    border-bottom: 2px solid #AAA;
    font-size: 0.85rem;
    height: 1.5rem;
    outline: none;
    max-width: 300px;
    width: 100%;
}

#login-area .submit-btn {
    background-color: #3b8956;
    border: none;
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    display: inline-block;
    font-weight: bold;
    margin: 1rem 0.5rem 0 0;
    padding: 0.5rem 1rem;
    text-decoration: none;
    transition: opacity 0.2s;
}

#login-area .submit-btn:hover {
    opacity: 0.8;
}

.gsi-material-button {
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  -webkit-appearance: none;
  background-color: #f2f2f2;
  background-image: none;
  border: none;
  -webkit-border-radius: 20px;
  border-radius: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #1f1f1f;
  cursor: pointer;
    display: block;
  font-family: 'Roboto', arial, sans-serif;
  font-size: 14px;
  height: 40px;
  letter-spacing: 0.25px;
    margin: 1rem auto;
  outline: none;
  overflow: hidden;
  padding: 0 12px;
  position: relative;
  text-align: center;
  -webkit-transition: background-color .218s, border-color .218s, box-shadow .218s;
  transition: background-color .218s, border-color .218s, box-shadow .218s;
  vertical-align: middle;
  white-space: nowrap;
  width: auto;
  max-width: 400px;
  min-width: min-content;
}

.gsi-material-button .gsi-material-button-icon {
  height: 20px;
  margin-right: 12px;
  min-width: 20px;
  width: 20px;
}

.gsi-material-button .gsi-material-button-content-wrapper {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  height: 100%;
  justify-content: space-between;
  position: relative;
  width: 100%;
}

.gsi-material-button .gsi-material-button-contents {
  -webkit-flex-grow: 1;
  flex-grow: 1;
  font-family: 'Roboto', arial, sans-serif;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: top;
}

.gsi-material-button .gsi-material-button-state {
  -webkit-transition: opacity .218s;
  transition: opacity .218s;
  bottom: 0;
  left: 0;
  opacity: 0;
  position: absolute;
  right: 0;
  top: 0;
}

.gsi-material-button:disabled {
  cursor: default;
  background-color: #ffffff61;
}

.gsi-material-button:disabled .gsi-material-button-state {
  background-color: #1f1f1f1f;
}

.gsi-material-button:disabled .gsi-material-button-contents {
  opacity: 38%;
}

.gsi-material-button:disabled .gsi-material-button-icon {
  opacity: 38%;
}

.gsi-material-button:not(:disabled):active .gsi-material-button-state, 
.gsi-material-button:not(:disabled):focus .gsi-material-button-state {
  background-color: #001d35;
  opacity: 12%;
}

.gsi-material-button:not(:disabled):hover {
  -webkit-box-shadow: 0 1px 2px 0 rgba(60, 64, 67, .30), 0 1px 3px 1px rgba(60, 64, 67, .15);
  box-shadow: 0 1px 2px 0 rgba(60, 64, 67, .30), 0 1px 3px 1px rgba(60, 64, 67, .15);
}

.gsi-material-button:not(:disabled):hover .gsi-material-button-state {
  background-color: #001d35;
  opacity: 8%;
}

#pay-card-btn {
    background-color: #EEE;
    border: 1px solid #AAA;
    border-radius: 2rem;
    cursor: pointer;
    display: block;
    margin: 1rem auto;
    padding: 0.75rem 2rem;
    transition: background-color 0.2s;
    width: 250px;
}

#pay-card-btn:hover {
    background-color: #CCC;
}

.main-organisation-text-content {
    display: inline-block;
    margin: 0 0 0 8rem;
}

.main-organisation-text-content > p {
    background-color: #FFF;
    display: block;
    margin: 0;
    font-size: 1rem;
    padding: 0.5rem; 
}

.main-organisation-name-container {
    align-items: center;
    background: #FFF;
    display: flex;
    height: 10rem;
    margin-top: -1rem;
    padding: 1rem;
    position: fixed;
    width: 58rem;
    z-index: 1;
}

#main-organisation-name {
    font-size: 2.5rem;
    font-weight: bold;
    margin: 0;
    padding: 0.5rem 1rem;
}

#main-organisation-location {
    font-size: 0.95rem;
    color: #444;
    margin: 0;
    padding: 0.5rem 1rem;
}

#main-organisation-location span {
    margin: 0 0.5rem 0 0;
}

#open-status.open {
    color: #228B22;
}

#open-status.closed {
    color: #DC143C;
}

.main-organisation-container {
    background-color: #EEE;
    border-radius: 1rem;
    display: flex;
    margin: 1rem 0 0;
    padding: 1rem;
}

.main-organisation-container#content-container {
    background-color: transparent;
}

.main-organisation-options {
    background: #e2ece5;
    box-shadow: 1px 1px 9px rgba(0,0,0,0.4);
    display: flex;
    height: 3.5rem;
    padding: 0;
    position: fixed;
    top: 0;
    justify-content: center;
    width: 100%;
    z-index: 2;
}

.main-organisation-btn {
    background-color: transparent;
    border: none;
    border-bottom: 4px solid transparent;
    color: #000;
    cursor: pointer;
    font-size: 0.95rem;
    padding: 0.5rem 1.5rem;
    transition: background-color 0.2s, border 0.2s;
    min-width: 7rem;
}

.main-organisation-btn.active {
    border-bottom: 6px solid #3b8956;
    font-weight: bold;
}

#content-container {
    display: block;
}

.content-item {
    background-color: #EEE;
    box-shadow: 0px 1px 7px rgba(0,0,0,0.3);
    border-radius: 1rem;
    color: #000;
    cursor: pointer;
    display: flex;
    margin: 1rem 0.5rem; 
    height: 7.5rem;
    transition: box-shadow 0.2s;
    overflow: hidden;
}

.content-item:hover {
    box-shadow: 0px 1px 20px rgba(0,0,0,0.3);
}

.content-item-title {
    font-size: 1.15rem;
    width: 46rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.content-item-subtitle {
    margin: 0.5rem 0;
}

.content-item-description {
    font-size: 0.75rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.content-item-img-container {
    display: inline-block;
    height: 7.5rem;
    position: relative;
}

.content-item-img {
    object-fit: cover;
    height: 7.5rem;
    width: 7.5rem; 
}

.content-item-img-overlay {
    background: rgba(0, 0, 0, 0.5);
    top: 0; left: 0; right: 0; bottom: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF;
    font-size: 1.35rem;
    font-weight: bold;
    opacity: 0;
    position: absolute;
    transition: opacity 0.2s;
}

.content-item:hover .content-item-img-overlay {
    opacity: 1;
}

.content-item-text-container {
    padding: 1rem;
}

.content-item-text-container > h2 {
    font-size: 1.15rem;
    margin: 0;
    width: 50rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.content-item-text-container > p {
    font-size: 0.85rem;
    margin: 0.5rem 0;
}

#main-organisation-book-btn {
    background-color: #3b8956;
    border: none;
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    font-size: 1.2rem;
    font-weight: bold;
    padding: 0.65rem 1.25rem;
    transition: background-color 0.2s;
}

#main-organisation-book-btn:hover {
  background-color: #EEE;
    color: #000;
}

#main-organisation-footer {
    background-color: #3b8956;
    color: #FFF;
    display: block;
    font-size: 1rem;
    padding: 1rem;
    position: relative;
}

#main-organisation-footer-logo {
    height: 2rem;
}

#pagination, #pagination-past {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 20px 0;
  font-family: Arial, sans-serif;
}

.pagination-button {
  background-color: #f0f0f0;
  border: 1px solid #ccc;
  color: #333;
  padding: 6px 12px;
  cursor: pointer;
  font-size: 14px;
  border-radius: 4px;
  transition: background-color 0.2s ease;
  user-select: none;
}

.pagination-button:hover:not(:disabled) {
  background-color: #ddd;
}

.pagination-button.active,
.pagination-button:disabled {
  background-color: #3b8956;
  color: white;
  cursor: default;
  border-color: #3b8956;
  font-weight: bold;
}

.pagination-ellipsis {
  padding: 6px 10px;
  color: #777;
  user-select: none;
  font-size: 14px;
  align-self: center;
}

.main-organisation-staff {
    border-radius: 1rem;
    display: inline-block;
    margin: 1rem;
    text-align: center;
}

.main-organisation-staff img {
    border-radius: 100rem;
    object-fit: cover;
    height: 7.5rem;
    width: 7.5rem;
}

#address-list .address {
    background-color: #F2F2F2;
    cursor: pointer;
    padding: 0.5rem;
    transition: background-color 0.2s;
}

#address-list .address:hover {
    background-color: #DDD;
}

#address-list .address .address-line1 {
    font-size: 0.75rem;
    font-weight: bold;
}

#address-list .address .address-line2 {
    font-size: 0.65rem;
}

#services-category-title {
    display: inline-block;
    font-size: 1rem;
}

.draggable {
    touch-action: none;
}

.category-title {
    background-color: #f2f2f2;
    font-size: 1rem;
    padding: 0.5rem;
}

.category {
    align-items: center;
    background-color: #f2f2f2;
    display: flex;
    margin-left: 1rem;
    padding: 0.5rem;
}

.category svg.drag-icon {
    height: 1rem;
    width: 0.5rem;
    padding: 0 1rem 0 0.25rem;
}

.category .category-text {
    display: inline-block;
    font-size: 0.85rem;
    flex: 1;
}

.category .category-container {
    align-items: center;
    display: flex;
    justify-content: center;
}

.category-btn {
    background-color: transparent;
    border: none;
    height: 1rem;
    width: 1.75rem;
}

.category-btn svg {
    fill: #000;
}

.add-category-btn {
    background-color: transparent;
    border: none;
    cursor: pointer;
    margin-left: 1rem;
    padding: 0.5rem;
    width: calc(100% - 1rem);
}

.category-title.active, .category.active {
    font-weight: bold;
}

#categories-container {
    box-sizing: border-box;
    padding: 1rem;
    -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  -webkit-appearance: none;
    width: 20rem;
}

#services-container {
    width: calc(100% - 20rem);
}

.service-option {
    display: block;
}

.service-option input, .service-option p {
    display: inline-block;
}

.category-service-container {
    max-height: 15rem;
    overflow: auto;
}

#loader-container {
  display: flex;
  justify-content: center;  /* horizontal centering */
  align-items: center;      /* vertical centering */
  height: 100vh;            /* viewport height */
}

/* The loader itself remains as before */
.loader {
  border: 8px solid #f3f3f3;
  border-top: 8px solid #228B22; 
  border-radius: 50%;
  width: 60px;
  height: 60px;
  animation: spin 1s linear infinite;
}

/* Spin animation */
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

#form-inputs-container {
    align-items: center;
    display: flex;
    flex-direction: column;
}

#log-out-btn {
    background-color: #FFF;
    border: 1px solid #3b8956;
    border-radius: 0.5rem;
    color: #3b8956;
    cursor: pointer;
    float: right;
    font-weight: bold;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

.form-primary-btn:hover, .form-secondary-btn:hover {
    opacity: 0.8;
}

.homepage-inline-container {
    font-size: 0;
}

.homepage-inline-container .homepage-inline-box {
    background-color: #F2F2F2;
    display: inline-block;
    font-size: initial;
    height: 22rem;
    margin: 1rem;
    padding: 1rem;
    text-align: center;
    vertical-align: top;
    width: 15rem;
}

.homepage-inline-container .homepage-inline-box.active {
    background-color: #3b8956;
    color: #FFF;
}

.homepage-inline-container .homepage-inline-box img {
    object-fit: cover;
    height: 10rem;
    width: 15rem;
}

.homepage-box {
    display: inline-block;
    margin: 1rem 0;
    width: 50rem;
}

.homepage-box h2 {
    background-color: #B1C9B4;
    margin: 0;
    padding: 1rem;
}

.homepage-box p {
    background-color: #FFF;
    font-size: 1.15rem;
    margin: 0;
    padding: 1rem;
}

.homepage-primary-action-btn {
    background-color: #3b8956;
    border: none;
    border-radius: 0.5rem;
    color: #FFF;
    cursor: pointer;
    display: inline-block;
    font-weight: bold;
    font-size: 0.9rem;
    margin: 0 0 0 1rem;
    padding: 0.75rem 1rem;
    text-decoration: none;
    transition: opacity 0.2s;
}

#plan-overview {
    background-color: #3b8956;
    margin: 1rem;
    padding: 1rem; 
}

#plan-overview p {
    color: #FFF;
    margin: 0;
}

#cancel-subscription {
    padding: 1rem;
}

#cancel-subscription h1 {
    margin: 0 !important;
}

#set-images-popup {
    max-width: 35rem;
    width: calc(100% - 6rem);
}

#organisation-images {
    border: 1px solid #000;
    align-items: center;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    max-height: 20rem;
    min-height: 5rem;
    overflow-y: auto;
    padding: 1rem;
}

.organisation-image-preview {
    background-color: #ccc;
    font-size: 0;
    margin: 5px;
    display: inline-block;
    position: relative;
    color: #666;
    text-align: center;
    font-weight: bold;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}   

.organisation-image-preview img {
    width: 150px;
    height: 100px;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
    user-drag: none;
    -webkit-user-drag: none;
    pointer-events: auto;
}   

.organisation-image-preview-text {
    cursor: pointer;
    font-size: 0.9rem;
    padding: 0.5rem;
}

.organisation-image-preview-text:hover {
    color: #000;
}

.image-drop-area {
    background-color: transparent;
    left: 0;
    right: 0;
    top: -8px; /* or adjust as needed for spacing */
    height: 150px;
    width: 8px;
    transition: background-color 0.2s;
    z-index: 1;
    pointer-events: auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.image-drop-area.active {
    background-color: #0056b3;
}

.carousel-container {
    height: 30rem;
  width: 100%; 
  overflow: hidden;
  position: relative;
  border-radius: 10px;
}

.carousel-track {
    display: flex;
  transition: transform 0.3s cubic-bezier(.23,.86,.39,.94);
  will-change: transform;
  cursor: grab;
}
.carousel-track.dragging {
  transition: none !important;
  cursor: grabbing;
}

.carousel-slide {
    height: 30rem;
  min-width: 100%;         /* Set your desired height */
  object-fit: cover;
  user-drag: none;
    -webkit-user-drag: none;
    pointer-events: auto;
}


/* Style buttons */
.carousel-button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.5);
  color: white;
  border: none;
  padding: 10px;
  cursor: pointer;
  border-radius: 50%;
}

.carousel-button#prevBtn {
  left: 10px;
}
.carousel-button#nextBtn {
  right: 10px;
}


.carousel-container .carousel-button#prevBtn svg, .carousel-container .carousel-button#nextBtn svg {
    height: 1.5rem;
    width: 1.5rem;
}

.carousel-container .carousel-button#prevBtn svg path, .carousel-container .carousel-button#nextBtn svg path {
    fill: #FFF;
}

#map-container {
    height: 20rem;
    width: 100%;
}

.address {
    margin-right: 0.75rem;
}

#opening-hours-table-container {
    margin: 2rem 0;
}

#opening-hours-table td, #opening-hours-table th {
    border: none !important;
    font-size: 0.9rem;
}

.category-toggle-btn {
    align-items: center;
    background-color: #F2F2F2;
    border: none;
    display: flex;
    font-family: "Nunito", sans-serif !important;
    font-size: 1rem;
    margin: 0.5rem 0;
    text-align: left;
    padding: 1rem;
    transition: background-color 0.2s;
    width: 100%;
}

.category-toggle-btn:hover {
    background-color: #DDD;
}

.category-toggle-btn span {
    color: #000;
    font-weight: bold;
    flex: 1;
}   

.category-toggle-btn svg {
    height: 1.5rem;
}