/* ============================================
   IBIDAN - Pre & Postnatal Massage Malaysia
   Reference: https://www.ibidan.com.my/
   ============================================ */

:root {
    --ibid-primary: #1a5f4a;
    --ibid-primary-dark: #0f3d30;
    --ibid-secondary: #d4842b;
    --ibid-secondary-dark: #b86e24;
    --ibid-accent: #c9a227;
    --ibid-cream: #faf8f5;
    --ibid-text: #2d2d2d;
    --ibid-text-muted: #5a5a5a;
    --ibid-white: #ffffff;
    --ibid-border: #e8e4df;
    --site-footer-bg: #f9f7f2;
    --home-shell-max: 1720px;
    --home-shell-pad-x: clamp(1rem, 3vw, 1.5rem);
    /* Fixed .site-header: promo strip + navbar (~6rem on large screens; avoid extra gap under bar) */
    --site-header-offset: 6rem;
}

@media (max-width: 991.98px) {
    :root {
        /* Stacked promo row needs a bit more than desktop */
        --site-header-offset: 7rem;
    }
}

/* AngularJS forms with was-validate: invalid fields (ng-invalid) */
form[was-validate] .form-control.ng-invalid,
form[was-validate] .form-select.ng-invalid,
form[was-validate] textarea.form-control.ng-invalid {
    border-color: #dc3545 !important;
}

form[was-validate] .form-control.ng-invalid:focus,
form[was-validate] .form-select.ng-invalid:focus,
form[was-validate] textarea.form-control.ng-invalid:focus {
    border-color: #b02a37 !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.22) !important;
}

form[was-validate] .form-control.ng-invalid:disabled,
form[was-validate] .form-select.ng-invalid:disabled,
form[was-validate] textarea.form-control.ng-invalid:disabled {
    border-color: var(--ibid-border) !important;
    box-shadow: none !important;
}

/*
 * Bootstrap 5 .form-control: appearance:none + ::-webkit-datetime-edit {display:block}
 * often hides the calendar icon. Restore native behaviour and reserve space
 * for ::-webkit-calendar-picker-indicator (with SVG fallback).
 */
input.form-control[type="date"],
input.form-control[type="datetime-local"],
input.form-control[type="month"],
input.form-control[type="week"],
input.form-control[type="time"] {
    -webkit-appearance: auto !important;
    appearance: auto !important;
}

input.form-control[type="date"]::-webkit-datetime-edit,
input.form-control[type="datetime-local"]::-webkit-datetime-edit,
input.form-control[type="month"]::-webkit-datetime-edit,
input.form-control[type="week"]::-webkit-datetime-edit {
    display: inline-block !important;
    max-width: calc(100% - 2rem) !important;
    padding: 0 !important;
    overflow: visible !important;
    vertical-align: middle;
}

input.form-control[type="date"]::-webkit-calendar-picker-indicator,
input.form-control[type="datetime-local"]::-webkit-calendar-picker-indicator,
input.form-control[type="month"]::-webkit-calendar-picker-indicator,
input.form-control[type="week"]::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: 1 !important;
    display: inline-block !important;
    width: 1.125rem;
    height: 1.125rem;
    padding: 0.125rem;
    margin: 0 0.15rem 0 0.35rem;
    flex-shrink: 0;
    background: transparent center / contain no-repeat;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236c757d' viewBox='0 0 16 16'%3E%3Cpath d='M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z'/%3E%3C/svg%3E");
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--ibid-text);
    line-height: 1.6;
    overflow-x: hidden;
    background: var(--ibid-white);
    padding-top: var(--site-header-offset);
    scroll-padding-top: calc(var(--site-header-offset) + 0.75rem);
}

img {
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
    color: inherit;
    transition: opacity 0.2s, color 0.2s;
}

a:hover {
    opacity: 0.85;
}

/* ========== Navigation ========== */
/* Same horizontal width as .home-hero (see home page hero) */
.home-shell {
    width: 100%;
    max-width: var(--home-shell-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--home-shell-pad-x);
    padding-right: var(--home-shell-pad-x);
    box-sizing: border-box;
}

.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1030;
    transition: box-shadow 0.2s ease;
}

.site-header.scrolled {
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.site-header__announce {
    background: #faf8f5;
    font-size: 0.8rem;
    color: var(--ibid-text-muted);
}

.site-header__socials {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.site-header__socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 50%;
    color: var(--ibid-secondary) !important;
    background: rgba(212, 132, 43, 0.1);
    font-size: 0.85rem;
    transition: background 0.2s, color 0.2s;
}

.site-header__socials a:hover {
    opacity: 1;
    background: rgba(212, 132, 43, 0.2);
    color: var(--ibid-secondary-dark) !important;
}

.site-header__promo-text {
    margin-right: 0.5rem;
}

.site-header__promo-btn {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ibid-secondary) !important;
    border-bottom: 1px solid transparent;
}

.site-header__promo-btn:hover {
    opacity: 1;
    border-bottom-color: var(--ibid-secondary);
}

.site-header__tools {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.75rem;
}

.site-header__tool {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--ibid-text);
    font-size: 1rem;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}

.site-header__tool:hover {
    opacity: 1;
    background: rgba(0, 0, 0, 0.05);
    color: var(--ibid-primary);
}

.site-header__tool--cart {
    position: relative;
}

.site-header__cart-badge {
    position: absolute;
    top: 0;
    right: 0;
    min-width: 1.1rem;
    height: 1.1rem;
    padding: 0 0.25rem;
    font-size: 0.65rem;
    font-weight: 700;
    line-height: 1.1rem;
    text-align: center;
    color: var(--ibid-white);
    background: var(--ibid-secondary);
    border-radius: 99px;
}

.site-header__divider {
    width: 1px;
    height: 1.5rem;
    background: rgba(0, 0, 0, 0.06);
    flex-shrink: 0;
}

.site-header__lang .dropdown-toggle,
.site-header__lang-btn,
.site-header__company .dropdown-toggle,
.site-header__company-btn {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--ibid-text) !important;
    text-decoration: none !important;
    border: none;
    background: transparent !important;
    padding: 0.25rem 0.5rem;
}

.site-header__lang .dropdown-toggle::after,
.site-header__lang-btn::after,
.site-header__company .dropdown-toggle::after,
.site-header__company-btn::after {
    margin-left: 0.35rem;
}

.site-header__company-flag {
    width: 20px;
    height: auto;
    vertical-align: middle;
    object-fit: cover;
    border-radius: 2px;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
    flex-shrink: 0;
}

.site-header__company-label {
    max-width: 10rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.site-header__company-menu .dropdown-item.active {
    font-weight: 600;
    background-color: rgba(26, 138, 157, 0.12);
    color: var(--ibid-text);
}

.ibid-nav.navbar-light .navbar-toggler {
    border: none;
    box-shadow: none;
}

.site-header__cta-phone {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none !important;
    color: inherit !important;
}

.site-header__cta-phone:hover {
    opacity: 1;
}

.site-header__cta-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--ibid-secondary);
    color: var(--ibid-white);
    font-size: 1rem;
    flex-shrink: 0;
}

.site-header__cta-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.2;
}

.site-header__cta-label {
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
}

.site-header__cta-num {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--ibid-text);
}

.ibid-nav {
    background: var(--ibid-white);
    padding: 0.5rem 0;
    position: relative;
}

.ibid-nav .navbar-brand {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--ibid-primary);
    padding-top: 0;
    padding-bottom: 0;
}

.ibid-nav .navbar-brand img {
    display: block;
    max-height: 44px;
    width: auto;
}

.ibid-nav .nav-link {
    color: var(--ibid-text);
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.5rem 0.65rem !important;
}

.ibid-nav .nav-link:hover {
    color: var(--ibid-primary);
}

.ibid-nav .nav-link.active {
    color: var(--ibid-primary);
    font-weight: 700;
    box-shadow: inset 0 -3px 0 var(--ibid-secondary);
}

.ibid-nav .btn-book {
    background: var(--ibid-secondary);
    color: var(--ibid-white) !important;
    padding: 0.5rem 1.25rem !important;
    border-radius: 6px;
    font-weight: 600;
}

.ibid-nav .btn-book:hover {
    background: var(--ibid-secondary-dark);
    color: var(--ibid-white) !important;
    opacity: 1;
}

.ibid-lang {
    font-size: 0.875rem;
    color: var(--ibid-text-muted);
}

.ibid-lang a {
    color: var(--ibid-text-muted);
}

.ibid-lang a.active,
.ibid-lang a:hover {
    color: var(--ibid-primary);
}

/* ========== Hero / Slider ========== */
.ibid-hero {
    min-height: 85vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    color: var(--ibid-white);
    text-align: center;
    padding: 4rem 1rem;
}

.ibid-hero h1 {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--ibid-white);
}

.ibid-hero .lead {
    font-size: clamp(1rem, 2.5vw, 1.35rem);
    opacity: 0.95;
    margin-bottom: 2rem;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.ibid-hero .btn-read {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--ibid-secondary);
    color: var(--ibid-white);
    padding: 0.75rem 1.5rem;
    border-radius: 6px;
    font-weight: 600;
    border: none;
}

.ibid-hero .btn-read:hover {
    background: var(--ibid-secondary-dark);
    color: var(--ibid-white);
    opacity: 1;
}

/* ========== Stats Bar ========== */
.ibid-stats {
    background: var(--ibid-cream);
    padding: 2rem 1rem;
    border-bottom: 1px solid var(--ibid-border);
}

.ibid-stats .stat-item {
    text-align: center;
}

.ibid-stats .stat-num {
    font-size: 2rem;
    font-weight: 700;
    color: var(--ibid-primary);
    line-height: 1.2;
}

.ibid-stats .row > *:nth-child(2) .stat-num {
    color: var(--ibid-secondary);
}

.ibid-stats .stat-label {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
}

/* ========== Section Common ========== */
.ibid-section {
    padding: 4rem 0;
}

.ibid-section--alt {
    background: var(--ibid-cream);
}

.ibid-section-title {
    text-align: center;
    margin-bottom: 2.5rem;
}

.ibid-section-title h2 {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--ibid-primary);
    margin-bottom: 0.5rem;
    position: relative;
    display: inline-block;
}

.ibid-section-title h2::after {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 50%;
    transform: translateX(-50%);
    width: 48px;
    height: 3px;
    background: var(--ibid-secondary);
    border-radius: 2px;
}

.ibid-section-title .sub {
    font-size: 1rem;
    color: var(--ibid-text-muted);
}

/* ========== About - Nurturing Women's Health ========== */
.ibid-about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}

.ibid-about-grid .text h2 {
    font-size: 1.75rem;
    color: var(--ibid-primary);
    margin-bottom: 0.5rem;
}

.ibid-about-grid .text .sub {
    font-size: 1.1rem;
    color: var(--ibid-text-muted);
    margin-bottom: 1rem;
}

.ibid-about-grid .text p {
    color: var(--ibid-text);
    margin-bottom: 1rem;
}

.ibid-about-grid .btn-read {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--ibid-secondary);
    font-weight: 600;
}

.ibid-about-grid .btn-read:hover {
    color: var(--ibid-secondary-dark);
}

.ibid-about-img {
    min-height: 320px;
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ibid-about-img i {
    font-size: 6rem;
    color: rgba(255,255,255,0.3);
}

/* ========== Traditional Malay Therapist ========== */
.ibid-therapist {
    background: var(--ibid-primary);
    color: var(--ibid-white);
    padding: 4rem 0;
}

.ibid-therapist h2 {
    color: var(--ibid-white);
    font-size: 1.5rem;
    margin-bottom: 0.25rem;
}

.ibid-therapist .sub {
    font-size: 1rem;
    opacity: 0.9;
    margin-bottom: 1rem;
}

.ibid-therapist p {
    opacity: 0.95;
    margin-bottom: 1rem;
}

.ibid-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
}

.ibid-pill {
    background: rgba(255,255,255,0.2);
    color: var(--ibid-white);
    padding: 0.35rem 1rem;
    border-radius: 50px;
    font-size: 0.9rem;
    font-weight: 500;
}

.ibid-pill:nth-child(2) {
    background: rgba(212, 132, 43, 0.5);
}

/* ========== Authentic Malay Massage CTA ========== */
.ibid-cta-strip {
    background: var(--ibid-cream);
    padding: 3rem 1rem;
    text-align: center;
}

.ibid-cta-strip h2 {
    font-size: 1.5rem;
    color: var(--ibid-primary);
    margin-bottom: 0.25rem;
}

.ibid-cta-strip .sub {
    color: var(--ibid-text-muted);
    margin-bottom: 1.5rem;
}

.ibid-cta-strip .btn-book {
    background: var(--ibid-secondary);
    color: var(--ibid-white);
    padding: 0.75rem 1.75rem;
    border-radius: 6px;
    font-weight: 600;
    border: none;
}

.ibid-cta-strip .btn-book:hover {
    background: var(--ibid-secondary-dark);
    color: var(--ibid-white);
    opacity: 1;
}

/* ========== Women's First Choice Stats ========== */
.ibid-choice-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-top: 2rem;
}

.ibid-choice-stat {
    text-align: center;
    padding: 1.5rem;
}

.ibid-choice-stat .num {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--ibid-primary);
}

.ibid-choice-stats .ibid-choice-stat:nth-child(2) .num {
    color: var(--ibid-secondary);
}

.ibid-choice-stat .label {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
}

/* ========== Our Packages ========== */
.ibid-packages {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.ibid-package-card {
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 12px;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.2s;
}

.ibid-package-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    transform: translateY(-2px);
}

.ibid-package-card .card-head {
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    color: var(--ibid-white);
    padding: 1.5rem;
    text-align: center;
    font-weight: 600;
}

.ibid-package-card .card-body {
    padding: 1.25rem;
}

.ibid-package-card .card-body p {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
    margin-bottom: 1rem;
}

.ibid-package-card .card-body .btn-link {
    color: var(--ibid-secondary);
    font-weight: 600;
    font-size: 0.9rem;
}

.ibid-package-card .card-body .btn-link:hover {
    color: var(--ibid-secondary-dark);
}

/* Section-level BOOK NOW / CTA buttons */
.ibid-section .btn-book,
.ibid-section--alt .btn-book {
    background: var(--ibid-secondary);
    color: var(--ibid-white);
    padding: 0.75rem 1.5rem;
    border-radius: 6px;
    font-weight: 600;
}

.ibid-section .btn-book:hover,
.ibid-section--alt .btn-book:hover {
    background: var(--ibid-secondary-dark);
    color: var(--ibid-white);
    opacity: 1;
}

/* ========== Why Choose Us ========== */
.ibid-why-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
}

.ibid-why-card {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.5rem;
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 12px;
}

.ibid-why-card .icon-wrap {
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    background: var(--ibid-cream);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ibid-primary);
    font-size: 1.5rem;
}

.ibid-why-card:nth-child(2) .icon-wrap,
.ibid-why-card:nth-child(4) .icon-wrap {
    background: rgba(212, 132, 43, 0.12);
    color: var(--ibid-secondary);
}

.ibid-why-card h3 {
    font-size: 1.1rem;
    color: var(--ibid-primary);
    margin-bottom: 0.25rem;
}

.ibid-why-card p {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
    margin: 0;
}

/* ========== Booking / Contact CTA ========== */
.ibid-booking-cta {
    background: var(--ibid-primary);
    color: var(--ibid-white);
    padding: 3rem 1rem;
    text-align: center;
}

.ibid-booking-cta h2 {
    color: var(--ibid-white);
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
}

.ibid-booking-cta p {
    opacity: 0.9;
    margin-bottom: 1.5rem;
}

.ibid-booking-cta .btn-book {
    background: var(--ibid-secondary);
    color: var(--ibid-white);
    padding: 0.75rem 1.75rem;
    border-radius: 6px;
    font-weight: 600;
    border: none;
}

.ibid-booking-cta .btn-book:hover {
    background: var(--ibid-secondary-dark);
    color: var(--ibid-white);
    opacity: 1;
}

/* ========== Contact Form ========== */
.ibid-contact .form-label {
    font-weight: 600;
    color: var(--ibid-text);
    margin-bottom: 0.35rem;
}

.ibid-contact .form-control {
    border: 1px solid var(--ibid-border);
    border-radius: 8px;
    padding: 0.6rem 0.75rem;
}

.ibid-contact .form-control:focus {
    border-color: var(--ibid-secondary);
    box-shadow: 0 0 0 3px rgba(212, 132, 43, 0.2);
}

.ibid-contact .btn-submit {
    background: var(--ibid-secondary);
    color: var(--ibid-white);
    padding: 0.75rem 1.5rem;
    border-radius: 8px;
    font-weight: 600;
    border: none;
}

.ibid-contact .btn-submit:hover {
    background: var(--ibid-secondary-dark);
    color: var(--ibid-white);
    opacity: 1;
}

/* ========== Footer ========== */
.ibid-footer {
    background: var(--ibid-primary-dark);
    color: var(--ibid-white);
    padding: 2.5rem 0 1.5rem;
}

.ibid-footer a {
    color: rgba(255,255,255,0.85);
}

.ibid-footer a:hover {
    color: var(--ibid-white);
    opacity: 1;
}

.ibid-footer .footer-brand {
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}

.ibid-footer .footer-desc {
    font-size: 0.9rem;
    opacity: 0.85;
    margin-bottom: 1rem;
}

.ibid-footer .footer-title {
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.75rem;
    opacity: 0.9;
}

.ibid-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ibid-footer ul li {
    margin-bottom: 0.35rem;
}

.ibid-footer .footer-addr {
    font-size: 0.9rem;
    opacity: 0.9;
    line-height: 1.6;
}

.ibid-footer .footer-bottom {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,0.15);
    font-size: 0.85rem;
    opacity: 0.8;
    text-align: center;
}

/* ========== Responsive ========== */
@media (max-width: 992px) {
    .ibid-about-grid {
        grid-template-columns: 1fr;
    }
    .ibid-about-img {
        min-height: 240px;
    }
    .ibid-packages {
        grid-template-columns: 1fr;
    }
    .ibid-why-grid {
        grid-template-columns: 1fr;
    }
    .ibid-choice-stats {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .ibid-hero {
        min-height: 70vh;
        padding: 3rem 1rem;
    }
    .ibid-section {
        padding: 3rem 0;
    }
}

/* ========== Home page hero (photo banner) ========== */
body.page-home {
    padding-top: var(--site-header-offset);
    scroll-padding-top: calc(var(--site-header-offset) + 1rem);
}

.home-hero {
    --home-hero-text: #333333;
    --home-hero-muted: #666666;
    padding: var(--home-shell-pad-x);
    max-width: var(--home-shell-max);
    margin-left: auto;
    margin-right: auto;
}

.home-hero__banner {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    min-height: clamp(500px, 80vh, 760px);
    background-color: #e8ecee;
    background-image: url('../img/home_page/hero.png');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right center;
    display: flex;
    align-items: stretch;
}

.home-hero__overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    /* Lighter veil on the left so the photo stays visible; stronger fade mid → right */
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.72) 0%,
        rgba(255, 255, 255, 0.45) 38%,
        rgba(255, 255, 255, 0.12) 62%,
        transparent 82%
    );
}

.home-hero__container {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1600px;
    margin-left: auto;
    margin-right: auto;
    flex: 1 1 auto;
    align-self: stretch;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-left: clamp(1.25rem, 3vw, 2.75rem);
    padding-right: clamp(1.25rem, 3vw, 2.75rem);
}

.home-hero__container .row {
    width: 100%;
    align-items: center;
}

.home-hero__copy {
    padding: clamp(1.5rem, 4vw, 2.75rem) 0;
    max-width: 40rem;
}

.home-hero__title {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: clamp(1.65rem, 3.8vw, 2.65rem);
    font-weight: 700;
    line-height: 1.15;
    color: var(--home-hero-text);
    margin-bottom: 1.25rem;
    letter-spacing: -0.02em;
}

.home-hero__lead {
    font-size: clamp(0.95rem, 1.35vw, 1.05rem);
    font-weight: 400;
    line-height: 1.65;
    color: var(--home-hero-muted);
    margin-bottom: 1.75rem;
}

.home-hero__badges {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.75rem 1rem;
}

.home-hero__badge {
    flex: 0 0 auto;
    line-height: 0;
}

.home-hero__badge-img {
    display: block;
    width: 96px;
    height: auto;
    max-width: 100%;
}

.home-hero__cta-wrap {
    margin: 1.5rem 0 0;
}

.home-hero__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.95rem 2.1rem;
    border-radius: 999px;
    border: none;
    background: linear-gradient(180deg, #e0a256 0%, #d69345 42%, #c47f38 100%);
    color: var(--ibid-white) !important;
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.035em;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.22),
        0 5px 18px rgba(180, 100, 45, 0.32),
        0 2px 5px rgba(0, 0, 0, 0.07);
    transition: background 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.home-hero__cta:hover {
    background: linear-gradient(180deg, #d6994f 0%, #c8823a 45%, #b8742f 100%);
    color: var(--ibid-white) !important;
    opacity: 1;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.18),
        0 7px 22px rgba(160, 88, 38, 0.36),
        0 2px 6px rgba(0, 0, 0, 0.08);
}

.home-hero__cta:focus-visible {
    outline: 2px solid #b8652a;
    outline-offset: 3px;
}

@media (max-width: 991.98px) {
    .home-hero__banner {
        background-position: 72% center;
        min-height: min(600px, 90vh);
    }

    .home-hero__overlay {
        background: linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.82) 0%,
            rgba(255, 255, 255, 0.55) 38%,
            rgba(255, 255, 255, 0.2) 58%,
            rgba(248, 250, 251, 0.08) 100%
        );
    }

    .home-hero__copy {
        max-width: 100%;
        padding: clamp(2rem, 6vw, 3rem) 0;
    }

    .home-hero__badges {
        justify-content: center;
    }

    .home-hero__cta-wrap {
        text-align: center;
    }
}

@media (max-width: 575.98px) {
    .home-hero {
        padding: 0.75rem;
    }

    .home-hero__banner {
        border-radius: 16px;
    }

    .home-hero__badge-img {
        width: 80px;
    }
}

/* ========== Home page — About ========== */
.home-about {
    --home-about-gold: #c68e3e;
    --home-about-beige: #f5efe6;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background: var(--ibid-white);
}

.home-about__media {
    position: relative;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
}

.home-about__media-deco {
    position: absolute;
    z-index: 0;
    inset: auto 0 0 auto;
    width: 92%;
    height: 92%;
    background: var(--home-about-beige);
    border-radius: 3rem 0 3rem 0;
    transform: translate(1.25rem, 1.25rem);
}

.home-about__img {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 3rem 0 3rem 0;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.home-about__eyebrow {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
    margin-bottom: 0.75rem;
}

.home-about__title {
    font-size: clamp(1.45rem, 2.8vw, 2.05rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin-bottom: 1rem;
}

.home-about__title-accent {
    color: var(--home-about-gold);
}

.home-about__lead {
    font-size: clamp(0.95rem, 1.2vw, 1.05rem);
    line-height: 1.65;
    color: var(--ibid-text-muted);
    margin-bottom: 1.75rem;
    max-width: 36rem;
}

.home-about__features-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 1.5rem 2rem;
    margin-bottom: 1.75rem;
}

.home-about__features {
    flex: 1 1 220px;
    min-width: 0;
}

.home-about__feature {
    display: flex;
    gap: 0.875rem;
    align-items: flex-start;
}

.home-about__feature + .home-about__feature {
    margin-top: 1.25rem;
}

.home-about__feature-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.home-about__feature-icon img {
    display: block;
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.home-about__feature-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--ibid-text);
    margin: 0 0 0.25rem;
    line-height: 1.3;
}

.home-about__feature-text {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
    margin: 0;
    line-height: 1.55;
}

.home-about__stat {
    flex: 0 0 auto;
    align-self: stretch;
    min-width: 140px;
    padding: 1.1rem 1.25rem;
    background: var(--home-about-beige);
    border: 1px dashed rgba(198, 142, 62, 0.45);
    border-radius: 0 1.25rem 0 1.25rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.35rem;
}

.home-about__stat-num {
    font-size: clamp(2rem, 4vw, 2.5rem);
    font-weight: 700;
    line-height: 1;
    color: var(--home-about-gold);
}

.home-about__stat-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ibid-text);
    line-height: 1.35;
    max-width: 9rem;
    margin-left: auto;
    margin-right: auto;
}

.home-about__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    border-radius: 999px;
    background: var(--home-about-gold);
    color: var(--ibid-white) !important;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: background 0.2s, transform 0.2s;
}

.home-about__btn:hover {
    background: #b07d32;
    color: var(--ibid-white) !important;
    opacity: 1;
}

.home-about__btn-arrow {
    font-size: 1rem;
    line-height: 1;
}

@media (max-width: 991.98px) {
    .home-about__media {
        max-width: 480px;
        margin-bottom: 0.5rem;
    }

    .home-about__stat {
        width: 100%;
        max-width: 280px;
        margin-left: auto;
        margin-right: auto;
    }

    .home-about__features-wrap {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ========== Home page — Postpartum challenges ========== */
.home-challenge {
    --home-challenge-gold: #d69345;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background: var(--ibid-cream);
}

.home-challenge__header {
    max-width: 44rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2.5rem;
}

.home-challenge__title {
    font-size: clamp(1.35rem, 2.6vw, 1.85rem);
    font-weight: 700;
    line-height: 1.25;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin-bottom: 0.75rem;
}

.home-challenge__title-accent {
    display: inline-block;
    margin-top: 0.2em;
    color: var(--home-challenge-gold);
    font-weight: 700;
}

.home-challenge__sub {
    font-size: clamp(0.95rem, 1.15vw, 1.05rem);
    line-height: 1.6;
    color: var(--ibid-text-muted);
    margin: 0;
}

.home-challenge__grid {
    --bs-gutter-x: 1.25rem;
    --bs-gutter-y: 1.25rem;
}

.home-challenge__card {
    background: var(--ibid-white);
    border-radius: 16px;
    padding: 1.75rem 1.25rem 1.5rem;
    width: 100%;
    height: 100%;
    text-align: center;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.04);
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Icon → title → rule; title min-height aligns short vs wrapped titles without a tall empty block */
.home-challenge__card-upper {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    flex: 0 0 auto;
    margin-bottom: 0.85rem;
}

.home-challenge__card-icon {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex: 0 0 auto;
    margin-bottom: 0.75rem;
}

.home-challenge__card-icon img {
    display: block;
    width: 80px;
    height: 80px;
    object-fit: contain;
}

.home-challenge__card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--ibid-text);
    margin: 0;
    line-height: 1.3;
    min-height: calc(1.3em * 2);
    text-align: center;
    width: 100%;
    max-width: 16rem;
    margin-left: auto;
    margin-right: auto;
}

.home-challenge__card-rule {
    display: block;
    width: 2.5rem;
    height: 3px;
    border-radius: 2px;
    background: var(--home-challenge-gold);
    flex-shrink: 0;
    margin-top: 0.5rem;
    margin-bottom: 0;
}

.home-challenge__card-lower {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    flex: 1 1 auto;
    min-height: 0;
}

.home-challenge__card-text {
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--ibid-text-muted);
    margin: 0;
    flex-grow: 1;
    max-width: 16rem;
    margin-left: auto;
    margin-right: auto;
}

.home-challenge__cta-wrap {
    margin-top: 2.5rem;
}

.home-challenge__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    border-radius: 999px;
    background: var(--home-challenge-gold);
    color: var(--ibid-white) !important;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: background 0.2s;
}

.home-challenge__btn:hover {
    background: #c47f38;
    color: var(--ibid-white) !important;
    opacity: 1;
}

.home-challenge__btn-arrow {
    font-size: 1rem;
    line-height: 1;
}

/* ========== Home page — Services (checkerboard grid) ========== */
.home-service {
    --home-service-teal: #0d9488;
    --home-service-teal-dark: #0f766e;
    --home-service-teal-soft: #d7ebec;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background: #eaf5f7;
}

.home-service__header {
    max-width: 65rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2rem;
}

.home-service__eyebrow {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--home-service-teal);
    margin-bottom: 0.65rem;
}

.home-service__title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.15rem;
    font-size: clamp(1.25rem, 2.4vw, 1.65rem);
    font-weight: 700;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    line-height: 1.25;
    margin: 0 0 1.5rem;
}

.home-service__title-line {
    display: block;
}

.home-service__title-accent {
    display: block;
    font-size: clamp(1.35rem, 2.8vw, 1.95rem);
    font-weight: 700;
    color: var(--home-service-teal);
}

.home-service__tabs {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 0.32rem;
    padding: 0.2rem 0.32rem;
    max-width: 100%;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    background: rgba(13, 148, 136, 0.08);
    border-radius: 999px;
}

.home-service__tab {
    flex: 1 1 14rem;
    min-width: min(100%, 14rem);
    border: none;
    border-radius: 999px;
    padding: 0.36rem 1.1rem;
    font-size: clamp(0.66rem, 1.42vw, 0.8rem);
    font-weight: 600;
    line-height: 1.22;
    color: var(--home-service-teal);
    background: transparent;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}

.home-service__tab:hover {
    background: rgba(255, 255, 255, 0.7);
}

.home-service__tab.is-active,
.home-service__tab[aria-selected='true'] {
    background: var(--home-service-teal);
    color: var(--ibid-white);
}

.home-service__checkerboard {
    margin-top: 2rem;
}

.home-service__row2 {
    margin-top: 0.75rem;
}

@media (min-width: 992px) {
    .home-service__row2 {
        margin-top: 1rem;
    }
}

.home-service__media-cell {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 15px;
    background: var(--ibid-cream);
    height: 100%;
}

.home-service__media-cell img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-service__text-cell {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    text-align: left;
    height: 100%;
    min-height: 0;
    aspect-ratio: 1;
    padding: clamp(1rem, 3vw, 1.5rem);
    border-radius: 15px;
    background: var(--home-service-teal-soft);
    border: 1px solid rgba(13, 148, 136, 0.12);
}

.home-service__icon-wrap {
    margin-bottom: 1.1rem;
    line-height: 0;
}

.home-service__icon-wrap img {
    display: block;
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.home-service__card-title {
    font-size: clamp(0.95rem, 1.8vw, 1.1rem);
    font-weight: 700;
    color: var(--ibid-text);
    margin: 0 0 1rem;
    line-height: 1.3;
}

.home-service__card-text {
    font-size: clamp(0.8rem, 1.35vw, 0.9rem);
    line-height: 1.5;
    color: var(--ibid-text-muted);
    margin: 0 0 0.85rem;
}

/* Short intro under category tabs (not the same role as in-card body copy) */
.home-service__panel-lead {
    text-align: center;
    font-size: clamp(0.9rem, 1.55vw, 1.05rem);
    font-weight: 500;
    line-height: 1.55;
    letter-spacing: -0.01em;
    color: var(--ibid-text-muted);
    margin: 0 auto clamp(1rem, 2.2vw, 1.5rem);
    max-width: 40rem;
}

@media (max-width: 575.98px) {
    .home-service__tabs {
        flex-direction: column;
        border-radius: 16px;
    }

    .home-service__tab {
        width: 100%;
        min-width: 0;
    }
}

.home-service__panel {
    display: none;
}

.home-service__panel.is-active {
    display: block;
}

/* ========== Home page — Active BioEnergy ========== */
.home-abe {
    --home-abe-teal: #239dad;
    --home-abe-teal-dark: #1d8796;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background: #eaf5f7;
}

.home-abe__visual {
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

.home-abe__slides {
    position: relative;
    width: 100%;
    aspect-ratio: 560 / 720;
    border-radius: 16px;
    overflow: hidden;
    background: var(--ibid-white);
    isolation: isolate;
    contain: layout style;
}

.home-abe__slides-track {
    position: absolute;
    inset: 0;
    border-radius: inherit;
}

.home-abe__slides-corner {
    position: absolute;
    top: clamp(0.5rem, 2vw, 0.85rem);
    left: clamp(0.5rem, 2vw, 0.85rem);
    z-index: 2;
    line-height: 0;
    pointer-events: none;
}

.home-abe__slides-corner-img {
    display: block;
    width: clamp(64px, 14vw, 96px);
    height: auto;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.12));
}

/* One visible frame via data-active (single reflow; avoids flash between class toggles) */
.home-abe__slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    opacity: 0;
    z-index: 0;
    transition: none;
    pointer-events: none;
    transform: translateZ(0);
    backface-visibility: hidden;
}

.home-abe__slides[data-active='0'] .home-abe__slides-track .home-abe__slide:nth-child(1),
.home-abe__slides[data-active='1'] .home-abe__slides-track .home-abe__slide:nth-child(2),
.home-abe__slides[data-active='2'] .home-abe__slides-track .home-abe__slide:nth-child(3) {
    opacity: 1;
    z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
    .home-abe__slide {
        opacity: 0;
        z-index: 0;
    }

    .home-abe__slides .home-abe__slides-track .home-abe__slide:first-child {
        opacity: 1;
        z-index: 1;
    }
}

.home-abe__badge {
    display: inline-block;
    margin-bottom: 1rem;
    padding: 0.4rem 1rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ibid-white);
    background: var(--home-abe-teal);
}

.home-abe__title {
    font-size: clamp(1.35rem, 2.6vw, 1.85rem);
    font-weight: 700;
    line-height: 1.25;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin: 0 0 1rem;
}

.home-abe__accent {
    color: var(--home-abe-teal);
}

.home-abe__lead {
    font-size: clamp(0.95rem, 1.15vw, 1.05rem);
    line-height: 1.65;
    color: var(--ibid-text-muted);
    margin: 0 0 1.25rem;
}

.home-abe__list {
    margin: 0;
    padding: 0;
}

.home-abe__item {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    font-size: 0.95rem;
    line-height: 1.5;
    color: var(--ibid-text);
    margin-bottom: 0.75rem;
}

.home-abe__item:last-child {
    margin-bottom: 0;
}

.home-abe__check {
    flex-shrink: 0;
    margin-top: 0.1rem;
    color: var(--home-abe-teal);
    line-height: 0;
}

.home-abe__cta-wrap {
    margin: 1.75rem 0 0;
}

.home-abe__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.95rem 2.25rem;
    border-radius: 999px;
    border: none;
    background: linear-gradient(90deg, #e8833a 0%, #f0a04a 52%, #f7a950 100%);
    color: var(--ibid-white) !important;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    text-align: center;
    box-shadow: 0 4px 14px rgba(200, 110, 50, 0.28), 0 2px 4px rgba(0, 0, 0, 0.06);
    transition: background 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.home-abe__cta:hover {
    background: linear-gradient(90deg, #d97530 0%, #e89445 52%, #ed9d45 100%);
    color: var(--ibid-white) !important;
    opacity: 1;
    box-shadow: 0 5px 18px rgba(180, 95, 40, 0.32), 0 2px 5px rgba(0, 0, 0, 0.07);
}

.home-abe__cta:focus-visible {
    outline: 2px solid #c45f28;
    outline-offset: 3px;
}

@media (max-width: 991.98px) {
    .home-abe__visual {
        margin-bottom: 0.5rem;
    }

    .home-abe__cta-wrap {
        text-align: center;
    }
}

/* ========== Home page — Why Choose Us ========== */
.home-chooseus {
    --home-chooseus-ochre: #c68e3e;
    --home-chooseus-teal: #239dad;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background-color: var(--ibid-white);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: min(92vw, 880px) auto;
}

.home-chooseus__header {
    max-width: 44rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.home-chooseus__eyebrow {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
    margin-bottom: 0.65rem;
}

.home-chooseus__title {
    font-size: clamp(1.35rem, 2.6vw, 1.95rem);
    font-weight: 700;
    line-height: 1.25;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin: 0;
}

.home-chooseus__title-accent {
    color: var(--home-chooseus-ochre);
}

.home-chooseus__grid {
    display: flex;
    flex-direction: column;
    gap: clamp(2rem, 4.5vw, 3.5rem);
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.home-chooseus__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: start;
}

.home-chooseus__row--top {
    column-gap: clamp(2rem, 14vw, 12rem);
}

.home-chooseus__row--bottom {
    column-gap: clamp(4rem, 26vw, 24rem);
}

.home-chooseus__point--1,
.home-chooseus__point--2 {
    justify-self: end;
    max-width: 22rem;
    width: 100%;
}

.home-chooseus__point--3,
.home-chooseus__point--4 {
    justify-self: start;
    max-width: 22rem;
    width: 100%;
}

.home-chooseus__point {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.home-chooseus__point--left {
    flex-direction: row;
    text-align: right;
}

.home-chooseus__point--left .home-chooseus__point-text {
    flex: 1;
    min-width: 0;
}

.home-chooseus__point--right {
    flex-direction: row;
    text-align: left;
}

.home-chooseus__point--right .home-chooseus__point-text {
    flex: 1;
    min-width: 0;
}

.home-chooseus__point-icon {
    flex-shrink: 0;
    line-height: 0;
}

.home-chooseus__point-icon img {
    display: block;
    width: 80px;
    height: 80px;
    object-fit: contain;
}

.home-chooseus__point-title {
    font-size: 1rem;
    font-weight: 700;
    color: #6b4a2e;
    margin: 0 0 0.4rem;
    line-height: 1.3;
}

.home-chooseus__point-desc {
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--ibid-text-muted);
    margin: 0;
}

.home-chooseus__stats {
    margin-top: clamp(6.5rem, 18vw, 14rem);
    background: var(--home-chooseus-ochre);
    color: var(--ibid-white);
    border-radius: 16px;
    padding: clamp(1.5rem, 3vw, 2.25rem) clamp(1.25rem, 3vw, 2rem);
}

.home-chooseus__stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    text-align: center;
}

@media (min-width: 992px) {
    .home-chooseus__stat {
        flex-direction: row;
        align-items: center;
        text-align: left;
        gap: 1rem;
    }
}

.home-chooseus__stat-icon {
    width: 56px;
    height: 56px;
    object-fit: contain;
    filter: brightness(0) invert(1);
    opacity: 0.95;
    flex-shrink: 0;
}

.home-chooseus__stat-body {
    flex: 1;
    min-width: 0;
}

.home-chooseus__stat-num {
    display: block;
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 0.25rem;
}

.home-chooseus__stat-label {
    font-size: 0.9rem;
    line-height: 1.45;
    margin: 0;
    opacity: 0.95;
}

@media (max-width: 991.98px) {
    .home-chooseus {
        background-size: min(100%, 520px) auto;
        background-position: center top;
    }

    .home-chooseus__grid {
        gap: clamp(1.75rem, 4vw, 2.75rem);
    }

    .home-chooseus__row {
        display: contents;
    }

    .home-chooseus__point--1,
    .home-chooseus__point--2,
    .home-chooseus__point--3,
    .home-chooseus__point--4 {
        justify-self: stretch;
        max-width: none;
    }

    .home-chooseus__point--left,
    .home-chooseus__point--right {
        flex-direction: row;
        text-align: left;
    }

    .home-chooseus__point--1 {
        order: 1;
    }

    .home-chooseus__point--2 {
        order: 2;
    }

    .home-chooseus__point--3 {
        order: 3;
    }

    .home-chooseus__point--4 {
        order: 4;
    }
}

/* ========== Home page — Master Bidans carousel ========== */
.home-mbidan {
    --home-mbidan-cream: #f9f7f2;
    --home-mbidan-copper: #d69345;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background: var(--home-mbidan-cream);
}

.home-mbidan__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
    margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
}

.home-mbidan__intro {
    flex: 1 1 18rem;
    min-width: 0;
}

.home-mbidan__eyebrow {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #8b7355;
    margin-bottom: 0.5rem;
}

.home-mbidan__title {
    font-size: clamp(1.35rem, 2.6vw, 1.9rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin: 0;
}

.home-mbidan__title-accent {
    color: var(--home-mbidan-copper);
}

.home-mbidan__sub {
    font-size: clamp(0.8rem, 1.05vw, 0.9rem);
    font-weight: 400;
    line-height: 1.55;
    color: var(--ibid-text-muted);
    margin: 0.65rem 0 0;
    max-width: 36rem;
}

.home-mbidan__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 1.4rem;
    border-radius: 999px;
    background: var(--home-mbidan-copper);
    color: var(--ibid-white) !important;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    flex-shrink: 0;
    transition: background 0.2s, opacity 0.2s;
}

.home-mbidan__cta:hover {
    background: #c48338;
    color: var(--ibid-white) !important;
    opacity: 1;
}

.home-mbidan__carousel {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.home-mbidan__nav {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--ibid-white);
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.08);
    color: #9ca3af;
    font-size: 1.85rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s, box-shadow 0.2s;
}

.home-mbidan__nav:hover {
    color: var(--home-mbidan-copper);
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.1);
}

.home-mbidan__nav:focus-visible {
    outline: 2px solid var(--home-mbidan-copper);
    outline-offset: 2px;
}

.home-mbidan__scroller {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    gap: 1.25rem;
    overflow-x: auto;
    margin: 0;
    padding: 0.25rem 0.75rem 0.75rem;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.home-mbidan__scroller::-webkit-scrollbar {
    display: none;
}

.home-mbidan__card {
    flex: 0 0 auto;
    width: min(100%, 260px);
    min-width: 240px;
    scroll-snap-align: start;
    background: var(--ibid-white);
    border-radius: 16px;
    padding: 1.5rem 1.25rem 1.25rem;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.04);
}

@media (min-width: 992px) {
    .home-mbidan__card {
        width: calc((100% - 3.75rem) / 4);
        min-width: 0;
        max-width: 280px;
    }
}

.home-mbidan__photo-wrap {
    width: 160px;
    height: 160px;
    margin: 0 auto 1rem;
    border-radius: 50%;
    overflow: hidden;
    background: #ececec;
}

.home-mbidan__photo {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-mbidan__lower {
    margin-top: 0.75rem;
}

.home-mbidan__rule {
    height: 0;
    margin: 0 0 0.75rem;
    border: 0;
    border-top: 1px solid #e3e3e3;
}

.home-mbidan__footer {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
}

.home-mbidan__meta {
    flex: 1;
    min-width: 0;
    text-align: left;
}

.home-mbidan__name {
    font-size: 1.05rem;
    font-weight: 700;
    color: #4a3728;
    text-align: left;
    margin: 0 0 0.2rem;
    line-height: 1.25;
}

.home-mbidan__role {
    font-size: 0.85rem;
    color: var(--ibid-text-muted);
    text-align: left;
    margin: 0;
    line-height: 1.35;
}

.home-mbidan__card-link {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #f0f0f0;
    color: #555;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: 1;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}

.home-mbidan__card-link:hover {
    background: #e8e8e8;
    color: var(--home-mbidan-copper);
}

@media (max-width: 575.98px) {
    .home-mbidan__nav {
        width: 38px;
        height: 38px;
        font-size: 1.5rem;
    }
}

/* ========== Home page — Package pricing ========== */
.home-package-pricing {
    --home-pp-gold: #d68d34;
    --home-pp-gold-dark: #c27f2c;
    --home-pp-check: #2a9d8f;
    --home-pp-card-width: 20rem;
    --home-pp-cards-gap: 0.65rem;
    --home-pp-inner-max: calc(3 * var(--home-pp-card-width) + 2 * var(--home-pp-cards-gap));
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 1.5rem);
    background: var(--ibid-white);
}

.home-package-pricing__inner {
    width: 100%;
    max-width: min(100%, var(--home-pp-inner-max));
    margin-inline: auto;
}

.home-package-pricing__header {
    margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
    text-align: left;
}

.home-package-pricing__section-title {
    font-size: clamp(1.25rem, 2.2vw, 1.5rem);
    font-weight: 700;
    color: var(--ibid-text);
    margin: 0;
    letter-spacing: -0.02em;
}

.home-package-pricing__cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), var(--home-pp-card-width)));
    justify-content: start;
    align-items: stretch;
    gap: var(--home-pp-cards-gap);
}

.home-package-pricing__card {
    min-height: 0;
    width: 100%;
    max-width: var(--home-pp-card-width);
    justify-self: start;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 16px;
    padding: 1.75rem 1.55rem 1.55rem;
    box-shadow: 0 4px 22px rgba(0, 0, 0, 0.07);
    transition: box-shadow 0.2s, transform 0.2s;
}

.home-package-pricing__card:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

.home-package-pricing__card-top {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.home-package-pricing__card-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--home-pp-gold);
    margin: 0;
    line-height: 1.25;
    flex: 1;
    min-width: 0;
}

.home-package-pricing__icon-wrap {
    flex-shrink: 0;
    line-height: 0;
}

.home-package-pricing__icon-wrap img {
    display: block;
    width: 64px;
    height: 64px;
    object-fit: contain;
}

.home-package-pricing__features {
    margin: 0 0 1.15rem;
    padding: 0;
    flex: 0 0 auto;
}

.home-package-pricing__features li {
    position: relative;
    padding-left: 1.35rem;
    margin-bottom: 0.45rem;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--ibid-text);
}

.home-package-pricing__features li:last-child {
    margin-bottom: 0;
}

.home-package-pricing__features li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 0.05em;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--home-pp-check);
}

.home-package-pricing__price-row {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    gap: 0.65rem;
    margin-top: auto;
    margin-bottom: 1.25rem;
}

.home-package-pricing__start-from {
    display: flex;
    flex-direction: column;
    font-size: 0.65rem;
    font-weight: 600;
    line-height: 1.15;
    color: var(--ibid-text-muted);
    text-transform: capitalize;
}

.home-package-pricing__amount {
    font-size: clamp(1.55rem, 2.6vw, 1.85rem);
    font-weight: 700;
    color: var(--ibid-text);
    margin: 0;
    line-height: 1;
}

.home-package-pricing__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.7rem 1rem;
    border-radius: 10px;
    background: var(--home-pp-gold);
    color: var(--ibid-white) !important;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-top: 0;
    transition: background 0.2s;
}

.home-package-pricing__btn:hover {
    background: var(--home-pp-gold-dark);
    color: var(--ibid-white) !important;
    opacity: 1;
}

.home-package-pricing__btn-arrow {
    margin-left: 0.35rem;
    font-size: 0.85rem;
}

/* ========== Packages & booking — professional layout (/packages, /make-booking) ========== */
body.page-package-detail,
body.page-packages,
body.page-package-categories,
body.page-package-category-detail {
    background: #f6f7f6;
}

body.page-make-booking {
    background: linear-gradient(180deg, var(--ibid-cream) 0%, #f2f4f3 45%, #e9edeb 100%);
}

/* ========== Make booking flow (/make-booking) ========== */
.booking-flow__intro {
    margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
    max-width: 40rem;
}

.booking-flow__label {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ibid-primary);
    margin-bottom: 0.5rem;
}

.booking-flow__title {
    font-size: clamp(1.75rem, 3.2vw, 2.25rem);
    font-weight: 600;
    letter-spacing: -0.03em;
    line-height: 1.2;
    color: var(--ibid-text);
    margin: 0 0 0.65rem;
}

.booking-flow__lead {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--ibid-text-muted);
    margin: 0;
}

.booking-card {
    border: 1px solid var(--ibid-border);
    border-radius: 14px;
    background: var(--ibid-white);
    box-shadow: 0 4px 28px rgba(26, 95, 74, 0.07);
    overflow: hidden;
    margin-bottom: 1.25rem;
}

.booking-card__header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.1rem 1.35rem;
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    color: var(--ibid-white);
}

.booking-card__step {
    flex-shrink: 0;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.28);
}

.booking-card__title {
    margin: 0 0 0.2rem;
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.25;
}

.booking-card__subtitle {
    margin: 0;
    font-size: 0.8125rem;
    opacity: 0.88;
    line-height: 1.4;
}

.booking-card__body {
    padding: 1.35rem 1.35rem 1.5rem;
}

body.page-make-booking .booking-flow .form-label {
    font-weight: 500;
    font-size: 0.875rem;
    color: var(--ibid-text);
    margin-bottom: 0.35rem;
}

body.page-make-booking .booking-input.form-control {
    border-radius: 10px;
    border-color: var(--ibid-border);
    padding: 0.55rem 0.85rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.page-make-booking .booking-input.form-control:focus {
    border-color: var(--ibid-primary);
    box-shadow: 0 0 0 0.2rem rgba(26, 95, 74, 0.12);
}

body.page-make-booking .booking-input.form-control:disabled {
    background: var(--ibid-cream);
    opacity: 0.85;
}

body.page-make-booking .booking-btn.booking-btn--primary.btn-primary,
body.page-make-booking .booking-flow .btn-primary.booking-btn--primary {
    --bs-btn-color: var(--ibid-white);
    --bs-btn-bg: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-color: var(--ibid-white);
    --bs-btn-hover-bg: var(--ibid-primary-dark);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
    --bs-btn-active-color: var(--ibid-white);
    --bs-btn-active-bg: var(--ibid-primary-dark);
    --bs-btn-active-border-color: var(--ibid-primary-dark);
    --bs-btn-disabled-color: var(--ibid-white);
    --bs-btn-disabled-bg: var(--ibid-primary);
    --bs-btn-disabled-border-color: var(--ibid-primary);
    font-weight: 600;
    padding: 0.55rem 1.35rem;
    border-radius: 10px;
    box-shadow: 0 2px 12px rgba(26, 95, 74, 0.18);
    background-color: var(--ibid-primary) !important;
    border-color: var(--ibid-primary) !important;
    color: var(--ibid-white) !important;
}

body.page-make-booking .booking-btn.booking-btn--primary.btn-primary:hover:not(:disabled),
body.page-make-booking .booking-flow .btn-primary.booking-btn--primary:hover:not(:disabled) {
    box-shadow: 0 4px 16px rgba(26, 95, 74, 0.24);
    background-color: var(--ibid-primary-dark) !important;
    border-color: var(--ibid-primary-dark) !important;
    color: var(--ibid-white) !important;
}

body.page-make-booking .booking-btn.booking-btn--primary.btn-primary:active:not(:disabled),
body.page-make-booking .booking-flow .btn-primary.booking-btn--primary:active:not(:disabled) {
    background-color: var(--ibid-primary-dark) !important;
    border-color: var(--ibid-primary-dark) !important;
}

body.page-make-booking .booking-btn.booking-btn--primary.btn-primary:disabled,
body.page-make-booking .booking-flow .btn-primary.booking-btn--primary:disabled {
    background-color: var(--ibid-primary) !important;
    border-color: var(--ibid-primary) !important;
    color: var(--ibid-white) !important;
    opacity: 0.55;
}

body.page-make-booking .booking-btn.booking-btn--outline {
    --bs-btn-color: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-bg: rgba(26, 95, 74, 0.08);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
    --bs-btn-hover-color: var(--ibid-primary-dark);
    font-weight: 600;
    border-radius: 10px;
    padding: 0.5rem 1.15rem;
}

.booking-action-btn {
    font-weight: 600;
    border-radius: 8px;
    padding: 0.35rem 0.75rem;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.booking-action-btn--primary {
    background: var(--ibid-primary) !important;
    border-color: var(--ibid-primary) !important;
    color: var(--ibid-white) !important;
}

.booking-action-btn--primary:hover:not(:disabled) {
    background: var(--ibid-primary-dark) !important;
    border-color: var(--ibid-primary-dark) !important;
    color: var(--ibid-white) !important;
}

.booking-action-btn--secondary {
    background: var(--ibid-white) !important;
    border: 1px solid rgba(212, 132, 43, 0.55) !important;
    color: var(--ibid-secondary-dark) !important;
}

.booking-action-btn--secondary:hover:not(:disabled) {
    background: rgba(212, 132, 43, 0.1) !important;
    border-color: var(--ibid-secondary) !important;
    color: var(--ibid-secondary-dark) !important;
}

body.page-make-booking .booking-btn-remove.btn-danger {
    --bs-btn-color: #b45309;
    --bs-btn-border-color: rgba(212, 132, 43, 0.45);
    --bs-btn-bg: transparent;
    --bs-btn-hover-bg: rgba(212, 132, 43, 0.1);
    --bs-btn-hover-border-color: var(--ibid-secondary);
    --bs-btn-hover-color: #9a3412;
    --bs-btn-active-bg: rgba(212, 132, 43, 0.15);
    border-radius: 8px;
}

/* Step 2 — guest cards (replaces table; mobile-first) */
.booking-guest-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.booking-guest-card {
    border: 1px solid var(--ibid-border);
    border-radius: 14px;
    background: var(--ibid-white);
    box-shadow: 0 2px 14px rgba(26, 95, 74, 0.06);
    overflow: hidden;
}

.booking-guest-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background: linear-gradient(180deg, rgba(26, 95, 74, 0.07) 0%, rgba(250, 248, 245, 0.5) 100%);
    border-bottom: 1px solid var(--ibid-border);
}

.booking-guest-card__badge {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.8125rem;
    letter-spacing: 0.02em;
    color: var(--ibid-primary-dark);
    background: rgba(26, 95, 74, 0.12);
    border: 1px solid rgba(26, 95, 74, 0.18);
}

.booking-guest-card__remove {
    flex-shrink: 0;
}

.booking-guest-card__body {
    padding: 1rem 1rem 1.15rem;
}

.booking-guest-card__field {
    margin-bottom: 1rem;
}

.booking-guest-card__label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-text);
    margin-bottom: 0.35rem;
}

.booking-guest-card__package-heading {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
    margin: 0 0 0.5rem;
}

.booking-guest-card__package-box {
    padding: 0.85rem;
    border-radius: 12px;
    border: 1px solid var(--ibid-border);
    background: rgba(250, 248, 245, 0.65);
    margin-bottom: 0.85rem;
}

.booking-guest-card__package-empty {
    padding: 0.85rem 1rem;
    border-radius: 12px;
    border: 1px dashed rgba(26, 95, 74, 0.22);
    background: rgba(26, 95, 74, 0.03);
    margin-bottom: 0.85rem;
}

/* Same visual language as form[was-validate] .form-control.ng-invalid — package is required */
.booking-guest-card__package-empty.booking-guest-card__package-empty--invalid {
    border-color: #dc3545 !important;
    border-style: dashed;
    background: rgba(220, 53, 69, 0.06);
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.12);
}

.booking-guest-card__empty-text {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--ibid-text-muted);
}

.booking-guest-card__price {
    margin-top: 0.35rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}

.booking-guest-card__actions {
    margin-top: 0.25rem;
}

.booking-action-btn--block {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.75rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    font-size: 0.875rem;
}

.booking-guest-list__add {
    width: 100%;
}

@media (min-width: 768px) {
    .booking-guest-list__add {
        width: auto;
    }
}

.booking-row-pkg__title {
    color: var(--ibid-text);
}

.booking-row-pkg__meta {
    color: var(--ibid-text-muted);
}

.booking-row-pkg__price {
    color: var(--ibid-primary);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

body.page-make-booking .booking-row-pkg__media {
    border-color: var(--ibid-border);
    background: rgba(26, 95, 74, 0.04);
}

body.page-make-booking .booking-row-pkg__placeholder {
    color: var(--ibid-primary);
    opacity: 0.35;
}

.booking-checkout-card {
    border: 1px solid var(--ibid-border);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 6px 32px rgba(26, 95, 74, 0.1);
}

@media (min-width: 992px) {
    .booking-checkout-card {
        position: sticky;
        top: calc(var(--site-header-offset) + 1rem);
    }
}

.booking-checkout-card__head.card-header {
    background: linear-gradient(135deg, var(--ibid-secondary) 0%, var(--ibid-secondary-dark) 100%);
    color: var(--ibid-white);
    border: none;
    padding: 1.05rem 1.2rem 1.15rem;
}

.booking-checkout-card__title {
    font-size: 1.0625rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: inherit;
    margin: 0 0 0.4rem;
}

.booking-checkout-card__subtitle {
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.88);
    margin: 0;
}

.booking-checkout-card__body.card-body {
    background: var(--ibid-white);
    padding: 1.15rem 1.2rem 1.25rem;
    font-size: 0.9rem;
}

.booking-checkout-card__empty {
    color: var(--ibid-text-muted);
    line-height: 1.5;
}

.booking-checkout-card__guest-line {
    color: var(--ibid-text-muted);
}

.booking-checkout-card__pkg-title {
    color: var(--ibid-text);
}

.booking-checkout-card__muted {
    color: #8a918e;
}

.booking-checkout-card__price {
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
}

.booking-checkout-summary__total {
    border-top: 2px solid rgba(26, 95, 74, 0.12) !important;
}

.booking-checkout-summary__total-label {
    color: var(--ibid-text);
    font-size: 0.9375rem;
}

.booking-checkout-summary__total-value {
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}

.booking-checkout-card__cta {
    margin-top: 1.15rem;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(26, 95, 74, 0.12);
}

.booking-checkout-card__payment-note {
    font-size: 0.75rem;
    line-height: 1.5;
    color: var(--ibid-text-muted);
    margin: 0 0 0.85rem;
}

.booking-checkout-card__payment-note strong {
    font-weight: 700;
    color: var(--ibid-text);
}

.booking-checkout-card__submit {
    font-weight: 700;
}

/* Make booking — package picker modal (wider than default lg/xl) */
@media (min-width: 576px) {
    .booking-package-modal .booking-package-modal__dialog.modal-dialog {
        max-width: min(96vw, 1240px);
    }
}

.booking-package-modal__shell.modal-content {
    border: none;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 1.25rem 3rem rgba(15, 61, 48, 0.22);
}

.booking-package-modal__header.modal-header {
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    color: var(--ibid-white);
    border-bottom: none;
    padding: 1rem 1.25rem;
}

.booking-package-modal__title.modal-title {
    font-weight: 600;
    font-size: 1.125rem;
    letter-spacing: -0.02em;
}

.booking-package-modal__body.modal-body {
    background: linear-gradient(180deg, rgba(250, 248, 245, 0.9) 0%, var(--ibid-white) 100%);
    padding: 1.25rem 1.35rem 1.5rem;
}

.booking-pkg-card--modal:hover {
    border-color: rgba(26, 95, 74, 0.3) !important;
    box-shadow: 0 8px 24px rgba(26, 95, 74, 0.12) !important;
}

body.page-make-booking .booking-modal-choose.btn-primary {
    --bs-btn-bg: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-bg: var(--ibid-primary-dark);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
    font-weight: 600;
    border-radius: 8px;
    padding-inline: 1rem;
}

.booking-package-modal .booking-package-modal__category + .booking-package-modal__category {
    margin-top: 2.75rem;
    padding-top: 2.25rem;
    border-top: 1px solid var(--ibid-border);
}

.booking-package-modal .booking-package-modal__cat-title {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 1rem;
    margin-top: 0.15rem;
    color: var(--ibid-primary-dark);
    letter-spacing: -0.01em;
}

/* Modal package cards: equal height, footer (price + Choose) aligned */
.booking-package-modal .booking-pkg-card--modal.card {
    min-height: 13.5rem;
    height: 100%;
}

.booking-package-modal .booking-pkg-card--modal > .row.g-0 {
    min-height: 13.5rem;
    align-items: stretch;
}

.booking-package-modal .booking-pkg-card--modal .booking-pkg-card__media {
    display: flex;
    align-self: stretch;
    min-height: 13.5rem;
    background: rgba(26, 95, 74, 0.06);
}

.booking-package-modal .booking-pkg-card--modal .booking-pkg-card__img {
    display: block;
    width: 100%;
    flex: 1;
    min-height: 13.5rem;
    height: 100%;
    object-fit: cover;
    border-radius: 0.375rem 0 0 0.375rem;
}

.booking-package-modal .booking-pkg-card--modal .booking-pkg-card__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-height: 13.5rem;
    width: 100%;
    color: var(--ibid-primary);
    opacity: 0.35;
    font-size: 1.75rem;
}

.booking-package-modal .booking-pkg-card--modal .card-body {
    min-height: 13.5rem;
}

.booking-pkg-card__media {
    background: rgba(26, 95, 74, 0.06);
    min-height: 6.5rem;
}

.booking-pkg-card__img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 6.5rem;
    object-fit: cover;
    border-radius: 0.375rem 0 0 0.375rem;
}

.booking-pkg-card__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 6.5rem;
    color: var(--ibid-primary);
    opacity: 0.35;
    font-size: 1.75rem;
}

.booking-pkg-card__summary {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Reserve description lines so short/empty blurbs match card height in modal */
.booking-package-modal .booking-pkg-card--modal .booking-pkg-card__summary {
    min-height: 4.125rem;
    line-height: 1.375;
}

/* Make booking — package thumbnail (table row / guest card / summary) */
.booking-row-pkg__media {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    overflow: hidden;
    background: #eef0ef;
    border: 1px solid #e5e7e6;
}

.booking-row-pkg__media.booking-row-pkg__media--guest-card {
    width: 72px;
    height: 72px;
    border-radius: 10px;
}

.booking-row-pkg__media.booking-row-pkg__media--guest-card .booking-row-pkg__img {
    border-radius: 10px;
}

.booking-row-pkg__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.booking-row-pkg__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: #9ca3a0;
    font-size: 1.25rem;
}

.booking-row-pkg__placeholder--sm {
    font-size: 1rem;
}

.booking-checkout-summary {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.booking-checkout-summary .booking-row-pkg__media {
    width: 48px;
    height: 48px;
}

.booking-checkout-summary__item--muted .booking-row-pkg__media {
    opacity: 0.85;
}

/* —— Package detail (/packages/:slug) —— */
body.page-package-detail .pkg-detail {
    padding-bottom: clamp(2.5rem, 5vw, 4rem);
}

body.page-package-detail .pkg-detail__breadcrumb {
    padding-top: clamp(0.75rem, 2vw, 1.25rem);
}

body.page-package-detail .pkg-detail__grid {
    display: grid;
    gap: clamp(1.75rem, 4vw, 2.75rem);
    align-items: start;
    margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
}

@media (min-width: 992px) {
    body.page-package-detail .pkg-detail__grid:not(.pkg-detail__grid--single) {
        grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
        gap: clamp(2rem, 4vw, 3rem);
    }

    body.page-package-detail .pkg-detail__aside {
        position: sticky;
        top: 1.25rem;
    }

    body.page-package-detail .pkg-detail__main {
        padding-left: clamp(1.25rem, 3vw, 2rem);
        border-left: 1px solid #e5e7e6;
    }
}

body.page-package-detail .pkg-detail__aside {
    min-width: 0;
}

body.page-package-detail .pkg-detail__photo {
    margin: 0 0 1.25rem;
    width: 100%;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e5e7e6;
    background: #eef0ef;
    aspect-ratio: 4 / 3;
}

body.page-package-detail .pkg-detail__photo-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.page-package-detail .pkg-detail__header {
    margin-bottom: 1.25rem;
}

body.page-package-detail .pkg-detail__title {
    font-size: clamp(1.375rem, 2.8vw, 1.75rem);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: #1a1d1c;
    margin: 0 0 0.65rem;
}

body.page-package-detail .pkg-detail__category-wrap {
    margin: 0;
}

body.page-package-detail .pkg-detail__category-icon {
    font-size: 0.85em;
    opacity: 0.9;
}

body.page-package-detail .pkg-detail__category {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.35rem 0.85rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-primary);
    background: rgba(26, 95, 74, 0.08);
    border: 1px solid rgba(26, 95, 74, 0.2);
    border-radius: 999px;
    text-decoration: none !important;
    transition: background 0.2s ease, border-color 0.2s ease;
}

body.page-package-detail .pkg-detail__category:hover {
    background: rgba(26, 95, 74, 0.12);
    border-color: rgba(26, 95, 74, 0.35);
    color: var(--ibid-primary-dark);
}

body.page-package-detail .pkg-detail__aside-block {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid #e5e7e6;
}

body.page-package-detail .pkg-detail__aside-block:first-of-type {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

body.page-package-detail .pkg-detail__aside-label {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9ca3a0;
    margin: 0 0 0.65rem;
}

body.page-package-detail .pkg-detail__lead {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: #4b5563;
    margin: 0;
}

body.page-package-detail .pkg-detail__main {
    min-width: 0;
}

body.page-package-detail .pkg-detail__main-title {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9ca3a0;
    margin: 0 0 1rem;
}

body.page-package-detail .pkg-detail__content {
    margin: 0;
}

body.page-package-detail .pkg-detail__main-section + .pkg-detail__main-section {
    margin-top: clamp(1.35rem, 2.5vw, 1.75rem);
    padding-top: clamp(1.35rem, 2.5vw, 1.75rem);
    border-top: 1px solid #e5e7e6;
}

body.page-package-detail .pkg-detail__tags {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

body.page-package-detail .pkg-detail__tags--aside {
    gap: 0.4rem;
}

body.page-package-detail .pkg-detail__tag {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: #4b5563;
    background: var(--ibid-white);
    border: 1px solid #dde1df;
    border-radius: 8px;
}

body.page-package-detail .pkg-detail__tag-icon {
    font-size: 0.72rem;
    color: var(--ibid-primary);
    opacity: 0.8;
}

body.page-package-detail .pkg-detail__benefits {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

body.page-package-detail .pkg-detail__benefit {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: #37403e;
}

body.page-package-detail .pkg-detail__benefit-icon {
    flex-shrink: 0;
    margin-top: 0.15rem;
    color: var(--ibid-primary);
    font-size: 0.95rem;
}

body.page-package-detail .pkg-detail__benefit-text {
    min-width: 0;
}

body.page-package-detail .pkg-detail__footer {
    margin-top: clamp(1.75rem, 3.5vw, 2.5rem);
    padding-top: 0;
    border-top: none;
}

body.page-package-detail .pkg-detail__footer-inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1.125rem;
    padding: clamp(1.125rem, 2.8vw, 1.5rem) clamp(1.25rem, 3vw, 1.75rem);
    background: linear-gradient(165deg, rgba(26, 95, 74, 0.09) 0%, rgba(26, 95, 74, 0.04) 48%, #f4f7f6 100%);
    border: 1px solid rgba(26, 95, 74, 0.18);
    border-radius: 12px;
    box-shadow: 0 6px 28px rgba(26, 42, 35, 0.08);
}

body.page-package-detail .pkg-detail__footer .pp-card__pricing {
    gap: 0.25rem;
}

body.page-package-detail .pkg-detail__footer .pp-card__pricing-label {
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    color: #5a6562;
}

body.page-package-detail .pkg-detail__footer .pp-card__pricing-value {
    font-size: clamp(1.5rem, 4.2vw, 2.125rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.03em;
}

body.page-package-detail .pkg-detail__book-btn {
    width: 100%;
    min-height: 3.125rem;
    padding: 0.875rem 1.5rem;
    font-size: 0.9375rem;
    font-weight: 700;
    border-radius: 10px;
    box-shadow: 0 4px 16px rgba(26, 95, 74, 0.28);
    transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}

body.page-package-detail .pkg-detail__book-btn:hover {
    box-shadow: 0 6px 22px rgba(26, 95, 74, 0.35);
    transform: translateY(-1px);
}

@media (min-width: 576px) {
    body.page-package-detail .pkg-detail__footer-inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
    }

    body.page-package-detail .pkg-detail__book-btn {
        width: auto;
        min-width: 12.5rem;
        flex-shrink: 0;
    }
}

/* Package categories: teal (--ibid-primary) + orange (--ibid-secondary) together */
body.page-package-categories .pp-hero--categories-landing .pp-hero__label {
    color: var(--ibid-secondary);
}

body.page-package-categories .pp-hero__solo {
    position: relative;
}

body.page-package-categories .pp-hero__solo::after {
    content: '';
    display: block;
    width: min(5.5rem, 40vw);
    height: 3px;
    margin-top: 1.125rem;
    border-radius: 2px;
    background: linear-gradient(90deg, var(--ibid-primary) 0%, var(--ibid-primary) 38%, var(--ibid-secondary) 38%, var(--ibid-secondary) 100%);
}

body.page-package-categories .pp-crumb__list a {
    color: var(--ibid-secondary);
}

body.page-package-categories .pp-crumb__list a:hover {
    color: var(--ibid-secondary-dark);
}

body.page-package-categories .pcat-category-card .pp-card__pricing-label {
    font-size: 0.6875rem;
}

body.page-package-categories .pcat-category-card .pp-card__pricing-value {
    color: var(--ibid-primary);
    font-size: clamp(1.5rem, 2.8vw, 1.75rem);
    line-height: 1.15;
}

body.page-package-categories .pcat-category-card .pp-card__bullets li::before {
    background: var(--ibid-primary);
    opacity: 0.85;
}

body.page-package-categories .pcat-category-card__cta {
    background: var(--ibid-secondary);
}

body.page-package-categories .pcat-category-card:hover .pcat-category-card__cta {
    background: var(--ibid-secondary-dark);
    box-shadow: 0 2px 14px rgba(212, 132, 43, 0.38);
}

body.page-package-categories .pcat-category-card__mark {
    border-color: rgba(26, 95, 74, 0.22);
    background: rgba(246, 250, 248, 0.98);
}

body.page-package-categories .pcat-category-card__mark-icon {
    color: var(--ibid-primary);
}

body.page-package-categories .pp-empty__btn {
    color: var(--ibid-white) !important;
    background: var(--ibid-primary);
    border: 2px solid var(--ibid-secondary);
}

body.page-package-categories .pp-empty__btn:hover {
    background: var(--ibid-primary-dark);
    border-color: var(--ibid-secondary-dark);
    color: var(--ibid-white) !important;
}

/* —— Package categories landing (/package-categories): 3 cards per row —— */
.pcat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
    align-items: stretch;
    list-style: none;
    margin: 0;
    padding: 0;
}

.pcat-grid > li {
    display: flex;
    min-width: 0;
}

@media (max-width: 991.98px) {
    .pcat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .pcat-grid {
        grid-template-columns: 1fr;
    }
}

.pcat-card {
    display: flex;
    flex: 1;
    width: 100%;
    min-width: 0;
    text-decoration: none;
    color: inherit;
    border-radius: 12px;
    border: 1px solid #e5e7e6;
    background: var(--ibid-white);
    box-shadow: 0 1px 2px rgba(26, 29, 28, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.pcat-card:hover {
    border-color: #cfd4d1;
    box-shadow: 0 8px 24px rgba(26, 29, 28, 0.08);
    transform: translateY(-2px);
    color: inherit;
}

.pcat-card:focus-visible {
    outline: 2px solid var(--ibid-primary);
    outline-offset: 3px;
}

.pcat-card__inner {
    padding: 1.25rem 1.35rem 1.35rem;
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 100%;
}

.pcat-card__top {
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    margin-bottom: 1rem;
}

.pcat-card__icon {
    flex-shrink: 0;
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: 1px solid #e5e7e6;
    background: #fafbfb;
    color: var(--ibid-primary);
    font-size: 1.25rem;
}

.pcat-card__icon--fallback {
    color: var(--ibid-primary);
}

.pcat-card__icon-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
}

.pcat-card__headline {
    min-width: 0;
    flex: 1;
}

.pcat-card__title {
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: #1a1d1c;
    margin: 0 0 0.5rem;
}

.pcat-card__from {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.5rem;
    font-size: 0.8125rem;
}

.pcat-card__from-label {
    color: #6b7280;
    font-weight: 500;
}

.pcat-card__from-value {
    font-weight: 600;
    color: var(--ibid-primary);
}

.pcat-card__details {
    list-style: none;
    margin: 0 0 1.25rem;
    padding: 0;
    flex: 1;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: #4b5563;
}

.pcat-card__details li {
    position: relative;
    padding-left: 1.1rem;
    margin-bottom: 0.4rem;
}

.pcat-card__details li:last-child {
    margin-bottom: 0;
}

.pcat-card__details li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--ibid-primary);
    opacity: 0.75;
}

.pcat-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: auto;
    padding-top: 0.25rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-primary);
}

.pcat-card__cta-arrow {
    transition: transform 0.2s ease;
}

.pcat-card:hover .pcat-card__cta-arrow {
    transform: translateX(3px);
}

/* Package categories index: photo strip on top, body below (thumbnail or icon fallback) */
.pp-section--categories-index.pp-section {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

ul.pp-section__grid {
    list-style: none;
    margin: 0;
    padding: 0;
}

.pcat-category-card__li {
    display: flex;
    min-width: 0;
}

.pcat-category-card {
    position: relative;
    display: flex;
    flex-direction: column;
    flex: 1;
    width: 100%;
    min-width: 0;
    min-height: 0;
    padding: 0;
    overflow: hidden;
    background: var(--ibid-white);
    text-decoration: none !important;
    color: inherit !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.pcat-category-card:hover {
    color: inherit !important;
    transform: translateY(-2px);
}

.pcat-category-card:focus-visible {
    outline: 2px solid var(--ibid-primary);
    outline-offset: 3px;
}

.pcat-category-card__photo {
    position: relative;
    flex-shrink: 0;
    aspect-ratio: 13 / 10;
    background: linear-gradient(145deg, #e8eeeb 0%, #f4f6f5 48%, #e2e8e5 100%);
    border-bottom: 1px solid #e5e7e6;
    overflow: hidden;
    border-radius: 10px 10px 0 0;
}

.pcat-category-card__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.45s ease;
}

.pcat-category-card:hover .pcat-category-card__img {
    transform: scale(1.045);
}

.pcat-category-card__photo-fallback {
    width: 100%;
    height: 100%;
    min-height: 100%;
}

.pcat-category-card__photo-fallback--empty {
    background: linear-gradient(160deg, #e4ebe7 0%, #f0f4f2 45%, #dde5e1 100%);
}

.pcat-category-card__photo-price {
    position: absolute;
    right: 0.65rem;
    bottom: 0.65rem;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.1rem;
    padding: 0.4rem 0.55rem 0.45rem;
    max-width: calc(100% - 1.3rem);
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(26, 95, 74, 0.12);
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(26, 42, 35, 0.12);
}

.pcat-category-card__photo-price-label {
    font-size: 0.5625rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #7a8682;
    line-height: 1;
}

.pcat-category-card__photo-price-value {
    font-size: clamp(0.9375rem, 2.2vw, 1.0625rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.15;
}

.pcat-category-card__inner {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    padding: 1.25rem 1.25rem 1.2rem;
}

.pcat-category-card .pp-card__top {
    margin-bottom: 0.65rem;
}

.pcat-category-card__pricing-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
}

.pcat-category-card__pricing-row .pp-card__pricing {
    min-width: 0;
}

.pcat-category-card__mark {
    flex-shrink: 0;
    width: 3.5rem;
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    border: 1px solid #e5e7e6;
    background: #fafbfb;
    overflow: hidden;
}

.pcat-category-card__mark-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pcat-category-card__mark-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ibid-primary);
    font-size: 1.55rem;
    line-height: 1;
}

.pcat-category-card__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: 100%;
    min-height: 2.75rem;
    padding: 0 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-white) !important;
    background: var(--ibid-primary);
    border-radius: 8px;
    border: 1px solid transparent;
    box-sizing: border-box;
    transition: background 0.2s ease, box-shadow 0.2s ease;
}

.pcat-category-card:hover .pcat-category-card__cta {
    background: var(--ibid-primary-dark);
    box-shadow: 0 2px 12px rgba(26, 95, 74, 0.22);
}

.pcat-category-card__cta-arrow {
    transition: transform 0.2s ease;
}

.pcat-category-card:hover .pcat-category-card__cta-arrow {
    transform: translateX(3px);
}

/* Shared breadcrumb */
.pp-crumb {
    margin-bottom: 1.75rem;
}

.pp-crumb__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem 0;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 0.8125rem;
    color: #6b7280;
}

.pp-crumb__list li {
    display: inline-flex;
    align-items: center;
}

.pp-crumb__list li:not(:last-child)::after {
    content: '/';
    margin: 0 0.5rem;
    color: #c5c9c7;
    font-weight: 400;
}

.pp-crumb__list a {
    color: var(--ibid-primary);
    font-weight: 500;
    text-decoration: none;
}

.pp-crumb__list a:hover {
    text-decoration: underline;
    opacity: 1;
}

.pp-crumb__list li[aria-current='page'] {
    color: #4b5563;
    font-weight: 500;
}

/* —— Packages hero —— */
.pp-hero {
    padding: clamp(1rem, 2.5vw, 1.5rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--ibid-white);
    border-bottom: 1px solid #e5e7e6;
}

/* /package-categories: one column, no side “checklist” panel */
.pp-hero--categories-landing {
    padding-bottom: clamp(1.35rem, 2.8vw, 2rem);
}

.pp-crumb--tight {
    margin-bottom: 1.125rem;
}

.pp-hero__solo {
    margin: 0;
    padding: 0;
    max-width: 38rem;
}

.pp-hero__title--categories {
    max-width: none;
    letter-spacing: -0.035em;
    margin-bottom: 0.65rem;
}

.pp-hero__lead--categories {
    max-width: 36rem;
    font-size: 0.9375rem;
    line-height: 1.62;
    color: #5f6662;
}

.pp-hero__grid {
    display: grid;
    gap: clamp(1.75rem, 4vw, 2.75rem);
}

@media (min-width: 992px) {
    .pp-hero__grid {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
        align-items: start;
    }
}

.pp-hero__label {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ibid-primary);
    margin-bottom: 0.5rem;
}

.pp-hero__intro-head {
    display: flex;
    align-items: flex-start;
    gap: clamp(0.875rem, 2vw, 1.25rem);
    margin-bottom: 1rem;
}

.pp-hero__intro-head .pp-hero__title {
    margin-bottom: 0;
}

.pp-hero__icon {
    flex-shrink: 0;
    width: 3.5rem;
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    border: 1px solid #e5e7e6;
    background: #fafbfb;
    color: var(--ibid-primary);
    font-size: 1.35rem;
}

.pp-hero__icon-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
}

.pp-hero__intro-main {
    min-width: 0;
    flex: 1;
}

.pp-hero__title {
    font-size: clamp(1.875rem, 3.5vw, 2.375rem);
    font-weight: 600;
    letter-spacing: -0.03em;
    line-height: 1.2;
    color: #1a1d1c;
    margin: 0 0 1rem;
    max-width: 20ch;
}

.pp-hero__lead {
    font-size: 1rem;
    line-height: 1.65;
    color: #5c6360;
    margin: 0;
    max-width: 38rem;
}

.pp-hero__lead--preline {
    white-space: pre-line;
}

.pp-hero__from {
    margin-top: clamp(1rem, 2.5vw, 1.5rem);
}

.pp-hero__highlights {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid #e5e7e6;
    border-radius: 10px;
    background: #fafbfb;
    overflow: hidden;
}

.pp-hero__highlight {
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    padding: 1rem 1.125rem;
    border-bottom: 1px solid #e5e7e6;
    font-size: 0.875rem;
    line-height: 1.5;
    color: #37403c;
    font-weight: 500;
}

.pp-hero__highlight:last-child {
    border-bottom: none;
}

.pp-hero__highlight-icon {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: var(--ibid-white);
    border: 1px solid #e5e7e6;
    color: var(--ibid-primary);
    font-size: 0.8125rem;
}

.pp-hero__highlight-text {
    padding-top: 0.125rem;
}

/* Package category detail (/package-categories/{slug}) — cover hero */
.pp-hero--category-detail .pp-hero__title {
    max-width: none;
}

/* No usable hero image: full-width soft gradient so the block is not “empty right” */
.pp-hero--category-detail:not(.pp-hero--category-detail-has-cover).pp-hero {
    background: linear-gradient(105deg, #ffffff 0%, #fafcfb 35%, #eef4f1 68%, #e3ebe7 100%);
    border-bottom: 1px solid #e5e7e6;
}

.pp-hero--category-detail:not(.pp-hero--category-detail-has-cover) .pcat-detail__intro {
    max-width: min(42rem, 100%);
}

.pp-hero--category-detail:not(.pp-hero--category-detail-has-cover) .pcat-detail__hero-shell {
    padding-bottom: clamp(2rem, 4vw, 2.85rem);
}

.pp-hero--category-detail-has-cover.pp-hero {
    position: relative;
    overflow: hidden;
    background: #dfe7e3;
    padding: 0;
    border-bottom: 1px solid #e5e7e6;
    min-height: min(48vh, 28rem);
    max-height: 550px;
}

.pp-hero--category-detail-has-cover.pp-hero:has(.pcat-detail__hero-grid--has-aside) {
    min-height: min(50vh, 30rem);
}

.pcat-detail__hero-visual {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.pcat-detail__hero-bg {
    position: absolute;
    inset: 0;
    background-color: #dfe7e3;
    background-size:cover;
    background-position: center;
    background-repeat: no-repeat;
}

.pcat-detail__hero-scrim {
    position: absolute;
    inset: 0;
    /* Softer left veil: not fully opaque — slight see-through + light blur for 朦胧感 */
    background: linear-gradient(
        100deg,
        rgba(255, 255, 255, 0.68) 0%,
        rgba(255, 255, 255, 0.42) 22%,
        rgba(255, 255, 255, 0.16) 48%,
        rgba(255, 255, 255, 0) 72%
    );
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
}

.pcat-detail__hero-shell {
    position: relative;
    z-index: 1;
    padding: clamp(1rem, 2.5vw, 1.5rem) 0 clamp(1.75rem, 4vw, 2.75rem);
}

.pcat-detail__hero-grid {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: start;
}

@media (min-width: 768px) {
    .pcat-detail__hero-grid--has-aside {
        grid-template-columns: minmax(0, 1fr) minmax(15.5rem, 21rem);
        align-items: center;
    }
}

.pcat-detail__hero-grid--has-aside .pcat-detail__intro {
    max-width: none;
}

.pcat-detail__hero-aside {
    margin: 0;
    padding: 1rem 1.125rem 1.1rem;
    border-radius: 12px;
    border: 1px solid rgba(26, 95, 74, 0.12);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.94) 0%, rgba(246, 250, 248, 0.96) 100%);
    box-shadow: 0 4px 22px rgba(26, 29, 28, 0.07);
}

.pp-hero--category-detail-has-cover .pcat-detail__hero-aside {
    background: rgba(255, 255, 255, 0.9);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-color: rgba(255, 255, 255, 0.72);
    box-shadow: 0 6px 28px rgba(26, 29, 28, 0.1);
}

.pcat-detail__hero-aside-kicker {
    margin: 0 0 0.55rem;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ibid-secondary);
}

.pcat-detail__hero-aside-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    max-height: min(46vh, 17.5rem);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.pcat-detail__hero-aside-list .pcat-detail__inclusion--hero-aside {
    padding: 0.42rem 0.5rem;
    font-size: 0.8125rem;
}

.pcat-detail__hero-aside-list .pcat-detail__inclusion-icon {
    width: 1.45rem;
    height: 1.45rem;
    font-size: 0.65rem;
}

.pp-hero--category-detail-has-cover .pcat-detail__intro {
    max-width: min(38rem, 100%);
}

.pp-hero--category-detail-has-cover .pcat-detail__hero-grid--has-aside .pcat-detail__intro {
    max-width: none;
}

.pp-hero--category-detail-has-cover .pcat-detail__intro .pp-hero__title {
    color: #141816;
    text-shadow:
        0 0 1.25rem rgba(255, 255, 255, 0.95),
        0 0 0.5rem rgba(255, 255, 255, 0.85);
}

.pp-hero--category-detail-has-cover .pcat-detail__intro .pp-hero__lead {
    color: #2a302d;
    text-shadow: 0 0 1rem rgba(255, 255, 255, 0.92);
}

.pp-hero--category-detail-has-cover .pp-crumb__list,
.pp-hero--category-detail-has-cover .pp-crumb__list li[aria-current='page'] {
    text-shadow: 0 0 0.75rem rgba(255, 255, 255, 0.95);
}

.pp-hero--category-detail-has-cover .pcat-detail__price {
    background: rgba(255, 255, 255, 0.78);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-color: rgba(255, 255, 255, 0.65);
    box-shadow: 0 2px 16px rgba(26, 29, 28, 0.06);
}

.pcat-detail__intro .pp-hero__lead {
    max-width: 42rem;
}

.pcat-detail__price {
    margin-top: clamp(1.25rem, 2.5vw, 1.75rem);
    padding: 1rem 1.125rem;
    border-radius: 10px;
    border: 1px solid rgba(26, 95, 74, 0.15);
    background: linear-gradient(135deg, rgba(246, 250, 248, 0.95) 0%, rgba(255, 252, 247, 0.98) 100%);
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    max-width: 20rem;
}

.pcat-detail__price-label {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ibid-secondary);
}

.pcat-detail__price-value {
    font-size: clamp(1.5rem, 2.8vw, 2rem);
    font-weight: 600;
    letter-spacing: -0.03em;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.15;
}

.pcat-detail__inclusions {
    margin-top: 0;
    padding: 0.65rem 0 0.9rem;
    background: var(--ibid-cream);
    border-top: 1px solid var(--ibid-border);
}

.pcat-detail__inclusions-kicker {
    margin: 0 0 0.4rem;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ibid-secondary);
}

.pcat-detail__inclusions-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.35rem 0.5rem;
}

@media (min-width: 520px) {
    .pcat-detail__inclusions-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 900px) {
    .pcat-detail__inclusions-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.pcat-detail__inclusion {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin: 0;
    padding: 0.45rem 0.55rem;
    background: var(--ibid-white);
    border: 1px solid #e5e7e6;
    border-radius: 8px;
    border-left: 2px solid var(--ibid-secondary);
    font-size: 0.8125rem;
    line-height: 1.3;
    font-weight: 500;
    color: #37403c;
    transition: border-color 0.2s ease;
}

.pcat-detail__inclusion:hover {
    border-color: rgba(26, 95, 74, 0.28);
    border-left-color: var(--ibid-primary);
    box-shadow: none;
}

.pcat-detail__inclusion-icon {
    flex-shrink: 0;
    width: 1.65rem;
    height: 1.65rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    background: var(--ibid-primary);
    color: var(--ibid-white);
    font-size: 0.7rem;
}

.pcat-detail__inclusion-text {
    padding: 0;
    min-width: 0;
}

body.page-package-category-detail .pp-crumb__list a {
    color: var(--ibid-secondary);
}

body.page-package-category-detail .pp-crumb__list a:hover {
    color: var(--ibid-secondary-dark);
}

body.page-package-category-detail .pcat-detail__intro .pp-hero__title::after {
    content: '';
    display: block;
    width: min(5.5rem, 40vw);
    height: 3px;
    margin-top: 0.85rem;
    border-radius: 2px;
    background: linear-gradient(90deg, var(--ibid-primary) 0%, var(--ibid-primary) 38%, var(--ibid-secondary) 38%, var(--ibid-secondary) 100%);
    box-shadow: 0 0 12px rgba(255, 255, 255, 0.9);
}

/* Category detail: package cards — photo on top, then title, description, CTA */
body.page-package-category-detail .pp-card.pp-card--media {
    padding: 0;
    overflow: hidden;
}

body.page-package-category-detail .pp-card--media .pp-card__media {
    position: relative;
    aspect-ratio: 16 / 10;
    background: linear-gradient(145deg, #eef2f0 0%, #e5eae7 100%);
    border-bottom: 1px solid #e5e7e6;
}

body.page-package-category-detail .pp-card--media .pp-card__media-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.page-package-category-detail .pp-card--media .pp-card__media-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 8rem;
    color: var(--ibid-primary);
    font-size: clamp(2rem, 8vw, 2.75rem);
    opacity: 0.35;
}

body.page-package-category-detail .pp-card--media .pp-card__media-price-badge {
    position: absolute;
    right: 0.55rem;
    bottom: 0.55rem;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.08rem;
    padding: 0.35rem 0.5rem 0.4rem;
    max-width: calc(100% - 1.1rem);
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(26, 95, 74, 0.12);
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(26, 42, 35, 0.12);
}

body.page-package-category-detail .pp-card--media .pp-card__media-price-badge-label {
    font-size: 0.5625rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #7a8682;
    line-height: 1;
}

body.page-package-category-detail .pp-card--media .pp-card__media-price-badge-value {
    font-size: clamp(0.8125rem, 2.5vw, 0.9375rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.15;
}

body.page-package-category-detail .pp-card--media .pp-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    padding: 1.125rem 1.25rem 1.25rem;
    flex: 1;
}

body.page-package-category-detail .pp-card--media .pp-card__name {
    font-size: 1.0625rem;
}

body.page-package-category-detail .pp-card--media .pp-card__summary {
    margin: 0;
}

body.page-package-category-detail .pp-card--media .pp-card__action--media-detail {
    flex-shrink: 0;
    margin-top: auto;
    padding: 0.75rem 1.125rem;
    min-height: 2.875rem;
    line-height: 1.2;
}

@media (min-width: 1200px) {
    body.page-package-category-detail .pp-grid:not(.pp-grid--single) {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

/* —— Packages catalogue —— */
.pp-catalog {
    padding: clamp(2rem, 4vw, 3rem) 0 clamp(3rem, 6vw, 4.5rem);
}

.pp-catalog__head {
    margin-bottom: clamp(1.5rem, 3vw, 2rem);
    padding-bottom: 1.25rem;
    border-bottom: 1px solid #e5e7e6;
}

.pp-catalog__title {
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #1a1d1c;
    margin: 0 0 0.5rem;
}

.pp-catalog__desc {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.55;
    color: #6b7280;
    max-width: 40rem;
}

/* Category sections (package_category + detail + packages) */
.pp-section {
    margin-bottom: clamp(2.5rem, 5vw, 3.75rem);
    padding-bottom: clamp(2rem, 4vw, 2.75rem);
    border-bottom: 1px solid #e5e7e6;
}

.pp-section:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: clamp(1rem, 2vw, 1.5rem);
}

.pp-section__head {
    margin-bottom: 1.5rem;
}

.pp-section__head-row {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.pp-section__icon {
    flex-shrink: 0;
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: 1px solid #e5e7e6;
    background: #fafbfb;
    color: var(--ibid-primary);
    font-size: 1.25rem;
}

.pp-section__icon-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
}

.pp-section__head-text {
    min-width: 0;
    flex: 1;
}

.pp-section__title {
    font-size: clamp(1.2rem, 2.2vw, 1.45rem);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: #1a1d1c;
    margin: 0 0 0.5rem;
}

.pp-section__from {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.65rem;
}

.pp-section__from-label {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #9ca3a0;
}

.pp-section__from-value {
    font-size: 1rem;
    font-weight: 600;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
}

.pp-section__details {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0.75rem 0 0;
    border-top: 1px solid #eef0ef;
}

.pp-section__details li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: 0.45rem;
    font-size: 0.875rem;
    line-height: 1.55;
    color: #4b5563;
}

.pp-section__details li:last-child {
    margin-bottom: 0;
}

.pp-section__details li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--ibid-primary);
    opacity: 0.55;
}

.pp-section__subhead {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #9ca3a0;
    margin: 0 0 0.5rem;
}

.pp-section__cat-benefits {
    list-style: none;
    margin: 0 0 0.5rem;
    padding: 0;
}

.pp-section__cat-benefits li {
    font-size: 0.8125rem;
    line-height: 1.5;
    color: #5c6360;
    padding: 0.2rem 0;
    padding-left: 1rem;
    border-left: 2px solid rgba(26, 95, 74, 0.2);
    margin-bottom: 0.35rem;
}

.pp-section__cat-benefits li:last-child {
    margin-bottom: 0;
}

.pp-section__grid {
    margin-top: 0.25rem;
}

.pp-section__empty-packages {
    font-size: 0.875rem;
    color: #9ca3a0;
    margin: 0;
    padding: 1rem 1.125rem;
    background: #fafbfb;
    border: 1px dashed #d5d8d6;
    border-radius: 8px;
}

.pp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 17.5rem), 1fr));
    gap: 1.25rem;
    align-items: stretch;
}

@media (min-width: 1200px) {
    .pp-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.pp-grid--single {
    grid-template-columns: minmax(0, 22rem);
    justify-content: start;
}

.pp-card {
    display: flex;
    flex-direction: column;
    background: var(--ibid-white);
    border: 1px solid #e5e7e6;
    border-radius: 10px;
    padding: 1.375rem 1.25rem 1.25rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.pp-card:hover {
    border-color: #c5d4cf;
    box-shadow: 0 4px 20px rgba(26, 95, 74, 0.06);
}

/* Care category cards: no grey haze — skip default pp-card shadow / grey border */
.pcat-category-card.pp-card:hover {
    border-color: rgba(26, 95, 74, 0.4);
    box-shadow: none;
}

.pp-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 0.875rem;
}

.pp-card__copy {
    min-width: 0;
}

.pp-card__category {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #6b7280;
    margin: 0 0 0.35rem;
}

.pp-card__name {
    font-size: 1.0625rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.3;
    color: #1a1d1c;
    margin: 0;
}

.pp-card__mark {
    flex-shrink: 0;
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 8px;
    background: #f3f4f3;
    border: 1px solid #e5e7e6;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.pp-card__mark-img {
    width: 2.5rem;
    height: 2.5rem;
    object-fit: contain;
}

.pp-card__mark-img--photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
}

.pp-card__mark-fallback {
    font-size: 1.35rem;
    color: var(--ibid-primary);
    opacity: 0.85;
}

.pp-card__summary {
    font-size: 0.8125rem;
    line-height: 1.55;
    color: #6b7280;
    margin: 0 0 1rem;
}

.pp-card__bullets {
    list-style: none;
    margin: 0 0 1.25rem;
    padding: 0.75rem 0 0;
    border-top: 1px solid #eef0ef;
    flex: 1;
}

.pp-card__bullets li {
    position: relative;
    padding-left: 0.875rem;
    margin-bottom: 0.4rem;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: #4b5563;
}

.pp-card__bullets li:last-child {
    margin-bottom: 0;
}

.pp-card__bullets li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--ibid-primary);
    opacity: 0.65;
}

.pp-card__empty-note {
    font-size: 0.8125rem;
    color: #9ca3a0;
    margin: 0 0 1.25rem;
    flex: 1;
    padding-top: 0.5rem;
    border-top: 1px solid #eef0ef;
}

.pp-card__bottom {
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid #eef0ef;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
}

.pp-card__pricing {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.pp-card__pricing-label {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #9ca3a0;
}

.pp-card__pricing-value {
    font-size: 1.375rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
}

.pp-card__pricing-value--muted {
    font-size: 1rem;
    font-weight: 600;
    color: #7a8682;
    font-variant-numeric: normal;
}

.pp-card__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.75rem;
    padding: 0 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-white) !important;
    background: var(--ibid-primary);
    border-radius: 8px;
    border: 1px solid transparent;
    text-decoration: none !important;
    transition: background 0.2s ease, box-shadow 0.2s ease;
}

.pp-card__action:hover {
    background: var(--ibid-primary-dark);
    color: var(--ibid-white) !important;
    opacity: 1;
    box-shadow: 0 2px 12px rgba(26, 95, 74, 0.22);
}

/* —— Packages empty —— */
.pp-empty {
    display: flex;
    justify-content: center;
    padding: 2rem 0 1rem;
}

.pp-empty__panel {
    text-align: center;
    max-width: 26rem;
    padding: 2.25rem 1.75rem;
    background: var(--ibid-white);
    border: 1px solid #e5e7e6;
    border-radius: 10px;
}

.pp-empty__label {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9ca3a0;
    margin: 0 0 0.5rem;
}

.pp-empty__title {
    font-size: 1.125rem;
    font-weight: 600;
    color: #1a1d1c;
    margin: 0 0 0.5rem;
    letter-spacing: -0.02em;
}

.pp-empty__text {
    font-size: 0.875rem;
    line-height: 1.55;
    color: #6b7280;
    margin: 0 0 1.25rem;
}

.pp-empty__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0 1.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-primary) !important;
    background: var(--ibid-white);
    border: 1px solid #c5d4cf;
    border-radius: 8px;
    text-decoration: none !important;
    transition: border-color 0.2s, background 0.2s;
}

.pp-empty__btn:hover {
    border-color: var(--ibid-primary);
    background: #f6faf8;
    opacity: 1;
    color: var(--ibid-primary-dark) !important;
}

/* —— Make booking —— */
.bk-hero {
    padding: clamp(1rem, 2.5vw, 1.5rem) 0 clamp(1.5rem, 3vw, 2.25rem);
    background: var(--ibid-white);
    border-bottom: 1px solid #e5e7e6;
}

.bk-hero__label {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ibid-primary);
    margin-bottom: 0.5rem;
}

.bk-hero__title {
    font-size: clamp(1.75rem, 3.2vw, 2.125rem);
    font-weight: 600;
    letter-spacing: -0.03em;
    line-height: 1.2;
    color: #1a1d1c;
    margin: 0 0 0.75rem;
}

.bk-hero__lead {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: #5c6360;
    margin: 0;
    max-width: 36rem;
}

.bk-main {
    padding: clamp(1.75rem, 4vw, 2.5rem) 0 clamp(3rem, 6vw, 4.5rem);
}

.bk-layout {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 992px) {
    .bk-layout {
        grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
        align-items: start;
        gap: 2rem;
    }
}

.bk-aside {
    min-width: 0;
}

.bk-summary {
    background: var(--ibid-white);
    border: 1px solid #e5e7e6;
    border-radius: 10px;
    padding: 1.25rem 1.125rem;
    position: sticky;
    top: 5.5rem;
}

.bk-summary--muted {
    text-align: left;
}

.bk-summary__heading {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9ca3a0;
    margin: 0 0 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid #eef0ef;
}

.bk-summary__media {
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 1rem;
    background: #f3f4f3;
    border: 1px solid #e5e7e6;
}

.bk-summary__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.bk-summary__category {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ibid-primary);
    margin: 0 0 0.35rem;
}

.bk-summary__title {
    font-size: 1.0625rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.3;
    color: #1a1d1c;
    margin: 0 0 1rem;
}

.bk-summary__price-block {
    padding: 0.75rem 0;
    border-top: 1px solid #eef0ef;
    border-bottom: 1px solid #eef0ef;
    margin-bottom: 1rem;
}

.bk-summary__price-label {
    display: block;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #9ca3a0;
    margin-bottom: 0.25rem;
}

.bk-summary__price-value {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--ibid-primary);
    font-variant-numeric: tabular-nums;
}

.bk-summary__link {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--ibid-primary);
    text-decoration: none;
}

.bk-summary__link:hover {
    text-decoration: underline;
    opacity: 1;
}

.bk-summary__note {
    font-size: 0.8125rem;
    line-height: 1.55;
    color: #6b7280;
    margin: 0 0 1rem;
}

.bk-summary__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-white) !important;
    background: var(--ibid-primary);
    border-radius: 8px;
    text-decoration: none !important;
    transition: background 0.2s ease;
}

.bk-summary__btn:hover {
    background: var(--ibid-primary-dark);
    color: var(--ibid-white) !important;
    opacity: 1;
}

.bk-content {
    min-width: 0;
}

.bk-panel {
    background: var(--ibid-white);
    border: 1px solid #e5e7e6;
    border-radius: 10px;
    padding: 1.5rem 1.25rem 1.25rem;
}

.bk-panel__title {
    font-size: 1.0625rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #1a1d1c;
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid #eef0ef;
}

.bk-timeline {
    list-style: none;
    margin: 0;
    padding: 0;
}

.bk-timeline__row {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem 1.125rem;
    padding-bottom: 1.25rem;
    margin-bottom: 1.25rem;
    border-bottom: 1px solid #eef0ef;
}

.bk-timeline__row:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.bk-timeline__step {
    width: 1.75rem;
    height: 1.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--ibid-primary);
    background: #eef5f2;
    border: 1px solid #d4e3dc;
    border-radius: 6px;
    font-variant-numeric: tabular-nums;
}

.bk-timeline__step--muted {
    color: #9ca3a0;
    background: #f3f4f3;
    border-color: #e5e7e6;
    font-weight: 600;
}

.bk-timeline__name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: #1a1d1c;
    margin: 0 0 0.35rem;
    line-height: 1.3;
}

.bk-timeline__detail {
    font-size: 0.8125rem;
    line-height: 1.55;
    color: #6b7280;
    margin: 0;
}

.bk-panel__foot {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid #eef0ef;
}

.bk-panel__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.75rem;
    margin-bottom: 0.875rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ibid-white) !important;
    background: var(--ibid-primary);
    border-radius: 8px;
    text-decoration: none !important;
    transition: background 0.2s ease, box-shadow 0.2s ease;
}

.bk-panel__cta:hover {
    background: var(--ibid-primary-dark);
    color: var(--ibid-white) !important;
    opacity: 1;
    box-shadow: 0 2px 12px rgba(26, 95, 74, 0.22);
}

.bk-panel__fineprint {
    font-size: 0.75rem;
    line-height: 1.5;
    color: #9ca3a0;
    margin: 0;
}

.bk-panel__fineprint a {
    color: var(--ibid-primary);
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
}

.bk-panel__fineprint a:hover {
    text-decoration: underline;
    opacity: 1;
}

@media (max-width: 991.98px) {
    .bk-summary {
        position: static;
    }
}

/* ========== Home page — Testimonial ========== */
.home-testimonial {
    position: relative;
    padding: clamp(3rem, 7vw, 5.5rem) 0 clamp(4rem, 9vw, 6rem);
    color: var(--ibid-white);
    overflow: hidden;
}

.home-testimonial__bg {
    position: absolute;
    inset: 0;
    background-image: url('../img/home_page/testimonial-bg-photo.png');
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    z-index: 0;
}

.home-testimonial__bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(13, 116, 110, 0.35) 0%,
        rgba(13, 116, 110, 0.15) 45%,
        rgba(255, 255, 255, 0.92) 100%
    );
    pointer-events: none;
}

.home-testimonial__container {
    position: relative;
    z-index: 1;
}

.home-testimonial__eyebrow {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.95);
    margin: 0 0 0.65rem;
}

.home-testimonial__title {
    font-size: clamp(1.35rem, 3vw, 2rem);
    font-weight: 600;
    line-height: 1.3;
    color: var(--ibid-white);
    margin: 0 auto 1.75rem;
    max-width: 36rem;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.12);
}

.home-testimonial__title-strong {
    font-weight: 800;
}

.home-testimonial__badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1rem 1.5rem;
    margin-bottom: 2.5rem;
}

.home-testimonial__badge {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    text-align: left;
}

.home-testimonial__badge-logo {
    flex-shrink: 0;
    display: block;
}

.home-testimonial__badge-text {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.home-testimonial__badge-score {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ibid-white);
    line-height: 1.2;
}

.home-testimonial__badge-label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.85);
}

.home-testimonial__badge-divider {
    display: inline-block;
    width: 1px;
    height: 2rem;
    background: rgba(255, 255, 255, 0.45);
}

.home-testimonial__carousel-wrap {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.home-testimonial__nav {
    flex: 0 0 auto;
    width: 2.25rem;
    height: 2.25rem;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    color: var(--ibid-white);
    font-size: 1.35rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s;
}

.home-testimonial__nav:hover {
    background: rgba(255, 255, 255, 0.35);
}

@media (max-width: 575.98px) {
    .home-testimonial__nav {
        display: none;
    }
}

.home-testimonial__scroller {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    padding: 2.25rem 0.25rem 1rem;
    margin: 0;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.home-testimonial__scroller::-webkit-scrollbar {
    display: none;
}

.home-testimonial__card {
    flex: 0 0 auto;
    width: min(100%, 300px);
    min-width: 260px;
    scroll-snap-align: start;
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .home-testimonial__card {
        width: calc((100% - 1 * 1rem) / 2);
        min-width: 0;
        max-width: none;
    }
}

@media (min-width: 992px) {
    .home-testimonial__card {
        width: calc((100% - 3 * 1rem) / 4);
        min-width: 0;
        max-width: none;
    }
}

.home-testimonial__card-inner {
    position: relative;
    background: rgba(255, 255, 255, 0.94);
    border-radius: 16px;
    padding: 2.25rem 1.25rem 1.35rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
    color: var(--ibid-text);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-height: 100%;
}

.home-testimonial__quote {
    position: absolute;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 3.5rem;
    line-height: 1;
    color: rgba(13, 148, 136, 0.15);
    pointer-events: none;
}

.home-testimonial__quote--tl {
    top: 0.5rem;
    left: 0.65rem;
}

.home-testimonial__quote--tr {
    top: 0.5rem;
    right: 0.65rem;
}

.home-testimonial__avatar-wrap {
    margin-top: -3.25rem;
    margin-bottom: 0.75rem;
    border-radius: 50%;
    overflow: hidden;
    width: 88px;
    height: 88px;
    border: 4px solid var(--ibid-white);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    flex-shrink: 0;
}

.home-testimonial__avatar {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-testimonial__name {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0 0 0.25rem;
    color: var(--ibid-text);
}

.home-testimonial__category {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
    margin: 0 0 0.75rem;
}

.home-testimonial__body-block {
    width: 100%;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.home-testimonial__body {
    font-size: 0.85rem;
    line-height: 1.55;
    color: var(--ibid-text-muted);
    margin: 0 0 0.35rem;
    flex: 0 1 auto;
    width: 100%;
    max-height: calc(1.55em * 7);
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 7;
    line-clamp: 7;
    overflow-wrap: break-word;
}

button.home-testimonial__more {
    appearance: none;
    -webkit-appearance: none;
    background: none;
    border: none;
    padding: 0;
    margin: 0 0 0.85rem;
    cursor: pointer;
    font: inherit;
    font-size: 0.8rem;
    font-weight: 600;
    color: #0d9488 !important;
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.home-testimonial__more:hover {
    opacity: 0.85;
}

.home-testimonial__text-modal-dialog {
    max-width: min(100% - 1.5rem, 440px);
}

@media (min-width: 576px) {
    .home-testimonial__text-modal-dialog {
        max-width: 480px;
    }
}

.home-testimonial__text-modal-content {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    box-shadow:
        0 25px 50px -12px rgba(15, 23, 42, 0.2),
        0 0 0 1px rgba(13, 148, 136, 0.08);
}

.home-testimonial__text-modal-accent {
    height: 4px;
    background: linear-gradient(90deg, #0f766e 0%, #0d9488 40%, #2dd4bf 100%);
}

.home-testimonial__text-modal-close {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    z-index: 4;
    padding: 0.5rem;
    opacity: 0.55;
    transition: opacity 0.2s ease;
}

.home-testimonial__text-modal-close:hover {
    opacity: 1;
}

.home-testimonial__text-modal-inner {
    background: #fff;
}

.home-testimonial__text-modal-head {
    padding: 1.65rem 1.45rem 1.25rem;
    padding-right: 3.25rem;
    background: linear-gradient(165deg, rgba(13, 148, 136, 0.14) 0%, rgba(240, 253, 250, 0.65) 45%, #fff 100%);
}

.home-testimonial__text-modal-profile {
    display: flex;
    align-items: center;
    gap: 1rem;
    text-align: left;
}

.home-testimonial__text-modal-avatar-wrap {
    flex-shrink: 0;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid #fff;
    box-shadow:
        0 8px 24px rgba(13, 148, 136, 0.22),
        0 2px 8px rgba(0, 0, 0, 0.06);
}

.home-testimonial__text-modal-avatar {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-testimonial__text-modal-meta {
    min-width: 0;
    flex: 1;
}

.home-testimonial__text-modal-name {
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--ibid-text);
    line-height: 1.3;
}

.home-testimonial__text-modal-package {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
    margin-top: 0.4rem;
}

.home-testimonial__text-modal-stars {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.12rem;
    margin-top: 0.55rem;
}

.home-testimonial__text-modal-star {
    font-size: 1.1rem;
    line-height: 1;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.6);
}

.home-testimonial__text-modal-star--empty {
    opacity: 0.42;
}

.home-testimonial__text-modal-message {
    position: relative;
    padding: 1.4rem 1.45rem 1.65rem;
    background: linear-gradient(180deg, #f8fafc 0%, #f0fdfa 100%);
    border-top: 1px solid rgba(13, 148, 136, 0.12);
}

.home-testimonial__text-modal-quote-mark {
    position: absolute;
    top: 0.5rem;
    left: 0.85rem;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 2.75rem;
    line-height: 1;
    color: rgba(13, 148, 136, 0.14);
    pointer-events: none;
    user-select: none;
}

.home-testimonial__text-modal-body {
    position: relative;
    z-index: 1;
    padding-top: 0.35rem;
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--ibid-text-muted);
    white-space: pre-wrap;
    overflow-wrap: break-word;
}

.home-testimonial__stars {
    display: flex;
    justify-content: center;
    gap: 0.15rem;
    margin-top: auto;
}

.home-testimonial__star {
    color: #e8b44c;
    font-size: 1.05rem;
    line-height: 1;
}

.home-testimonial__videos-block {
    margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.home-testimonial__subheading {
    font-size: clamp(1.15rem, 2.2vw, 1.45rem);
    font-weight: 700;
    color: var(--ibid-white);
    margin: 0 0 1.5rem;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.12);
}

.home-testimonial__video-row {
    max-width: 960px;
    margin-inline: auto;
}

.home-testimonial__video-tiers {
    display: flex;
    flex-direction: column;
    gap: clamp(0.85rem, 2.2vw, 1.35rem);
}

.home-testimonial__video {
    position: relative;
    display: block;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.15);
}

button.home-testimonial__video {
    appearance: none;
    -webkit-appearance: none;
    font: inherit;
    color: inherit;
    text-align: left;
    cursor: pointer;
    width: 100%;
    padding: 0;
    margin: 0;
    border: none;
    background: transparent;
}

.home-testimonial__video-modal-content {
    border-radius: 12px;
    overflow: hidden;
}

.home-testimonial__video-modal-frame iframe {
    border: 0;
}

.home-testimonial__video-thumb img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.home-testimonial__play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.15);
    transition: background 0.2s;
}

.home-testimonial__video:hover .home-testimonial__play {
    background: rgba(0, 0, 0, 0.25);
}

.home-testimonial__play::before {
    content: '';
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 50%;
    background: #e8913a;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
}

.home-testimonial__play-tri {
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.45rem 0 0.45rem 0.75rem;
    border-color: transparent transparent transparent var(--ibid-white);
    margin-left: 0.2rem;
}

.home-testimonial__results {
    position: relative;
    z-index: 1;
}

.home-testimonial__results .home-testimonial__subheading {
    color: var(--ibid-white);
    text-shadow: 0 1px 14px rgba(0, 0, 0, 0.18);
}

.home-testimonial__results-lead {
    font-size: clamp(1rem, 1.8vw, 1.15rem);
    color: rgba(255, 255, 255, 0.95);
    margin: 0 0 1.5rem;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.15);
}

.home-testimonial__results-pct {
    font-size: clamp(1.75rem, 3.5vw, 2.35rem);
    font-weight: 800;
    font-style: italic;
    color: var(--ibid-white);
    text-shadow: 0 1px 14px rgba(0, 0, 0, 0.18);
}

.home-testimonial__compare {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    max-width: 720px;
    margin: 0 auto 1rem;
}

.home-testimonial__compare-nav {
    flex: 0 0 auto;
    width: 2.5rem;
    height: 2.5rem;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.95);
    color: #0d9488;
    font-size: 1.5rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
    transition: background 0.2s, transform 0.15s;
}

.home-testimonial__compare-nav:hover {
    background: var(--ibid-white);
    transform: scale(1.05);
}

.home-testimonial__compare-viewport {
    flex: 1 1 auto;
    min-width: 0;
    max-width: 560px;
}

.home-testimonial__compare-stage {
    --compare-pct: 50;
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.home-testimonial__compare-base {
    display: block;
    width: 100%;
    height: auto;
}

.home-testimonial__compare-clip {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: calc(var(--compare-pct) * 1%);
    max-width: 100%;
    overflow: hidden;
}

.home-testimonial__compare-topimg {
    display: block;
    width: calc(100% / (var(--compare-pct) * 0.01));
    max-width: none;
    height: auto;
}

.home-testimonial__compare-handle {
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(var(--compare-pct) * 1%);
    width: 4px;
    margin-left: -2px;
    background: var(--ibid-white);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
    pointer-events: none;
    z-index: 2;
}

.home-testimonial__compare-handle::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    background: var(--ibid-white);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.home-testimonial__compare-range {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    opacity: 0;
    cursor: ew-resize;
    z-index: 3;
}

.home-testimonial__dots {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    padding-top: 0.25rem;
}

.home-testimonial__dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(45, 45, 45, 0.25);
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
}

.home-testimonial__dot.is-active {
    background: #0d9488;
    transform: scale(1.15);
}

/* ========== Brand recognition ========== */
.brand-recognition-section {
    padding: clamp(2.25rem, 4vw, 3.5rem) 0;
    background: var(--ibid-white);
    border-top: 1px solid var(--ibid-border);
}

.brand-recognition-section__title {
    font-size: clamp(1.2rem, 2.2vw, 1.45rem);
    font-weight: 700;
    color: var(--ibid-text);
    margin: 0 auto clamp(1.5rem, 3vw, 2.25rem);
    letter-spacing: -0.02em;
    max-width: 40rem;
}

.brand-recognition-section__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 3.5rem;
    padding: 0.35rem 0.5rem;
}

.brand-recognition-section__img {
    max-height: 52px;
    width: auto;
    max-width: 100%;
    object-fit: contain;
}

.brand-recognition-section__marquee {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    max-width: 100%;
    margin: 0 auto;
}

.brand-recognition-section__nav {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: #f3f4f6;
    color: #0d9488;
    font-size: 1.5rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    transition: background 0.2s, color 0.2s, transform 0.15s;
}

.brand-recognition-section__nav:hover {
    background: #e7e5e4;
    color: #0f766e;
    transform: scale(1.05);
}

.brand-recognition-section__nav:focus-visible {
    outline: 2px solid #0d9488;
    outline-offset: 2px;
}

.brand-recognition-section__marquee-viewport {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}

.brand-recognition-section__marquee-track {
    display: flex;
    width: max-content;
    transform: translateX(0);
    will-change: transform;
}

.brand-recognition-section__marquee-group {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: clamp(1.75rem, 5vw, 3rem);
    padding: 0.25rem clamp(1rem, 3vw, 1.75rem);
    flex-shrink: 0;
}

.brand-recognition-section__marquee-item {
    flex: 0 0 auto;
}

@media (prefers-reduced-motion: reduce) {
    .brand-recognition-section__marquee-viewport {
        mask-image: none;
        -webkit-mask-image: none;
    }
}

/* ========== Site footer ========== */
.site-footer {
    --site-footer-accent: #a67c2e;
    position: relative;
    background-color: var(--site-footer-bg);
}

.site-footer__banner-wrap {
    padding: 0 0 clamp(1.5rem, 3vw, 2.25rem);
    background: transparent;
}

.site-footer__cta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 1.5rem;
    padding: clamp(1.25rem, 3vw, 1.75rem) clamp(1.25rem, 3vw, 2rem);
    border-radius: 16px;
    background: linear-gradient(135deg, #d68c39 0%, #c47a2e 100%);
    color: var(--ibid-white) !important;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
    text-decoration: none !important;
    transition: transform 0.15s, box-shadow 0.15s;
}

.site-footer__cta:hover {
    color: var(--ibid-white) !important;
    opacity: 1;
    transform: translateY(-1px);
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.14);
}

.site-footer__cta-eyebrow {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin: 0 0 0.35rem;
    opacity: 0.95;
}

.site-footer__cta-title {
    font-size: clamp(1.15rem, 2.5vw, 1.5rem);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin: 0;
    line-height: 1.2;
}

.site-footer__cta-contact {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.site-footer__cta-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    background: var(--ibid-white);
    color: #d68c39;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.site-footer__cta-phone {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
}

.site-footer__cta-wa {
    font-size: 0.7rem;
    font-weight: 600;
    opacity: 0.95;
}

.site-footer__cta-num {
    font-size: clamp(1.1rem, 2.2vw, 1.35rem);
    font-weight: 800;
    letter-spacing: 0.02em;
}

@media (max-width: 575.98px) {
    .site-footer__cta {
        flex-direction: column;
        text-align: center;
    }

    .site-footer__cta-copy {
        text-align: center;
    }

    .site-footer__cta-contact {
        justify-content: center;
    }

    .site-footer__cta-phone {
        align-items: center;
    }
}

.site-footer__main {
    padding: clamp(2.5rem, 5vw, 3.75rem) 0 clamp(2.5rem, 5vw, 3.5rem);
    background: var(--site-footer-bg);
}

.site-footer__brand {
    display: inline-block;
    margin-bottom: 1rem;
}

.site-footer__brand:hover {
    opacity: 0.9;
}

.site-footer__logo {
    display: block;
    max-width: 200px;
    height: auto;
}

.site-footer__about {
    font-size: 0.9rem;
    line-height: 1.65;
    color: var(--ibid-text-muted);
    margin: 0 0 1.25rem;
    max-width: 22rem;
}

.site-footer__socials {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.site-footer__social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 50%;
    background: rgba(212, 132, 43, 0.12);
    color: var(--site-footer-accent) !important;
    font-size: 1rem;
    transition: background 0.2s, color 0.2s, transform 0.15s;
}

.site-footer__social:hover {
    background: rgba(212, 132, 43, 0.22);
    color: var(--ibid-secondary-dark) !important;
    opacity: 1;
    transform: translateY(-1px);
}

.site-footer__col-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ibid-text);
    margin: 0 0 1rem;
}

.site-footer__list li {
    margin-bottom: 0.45rem;
}

.site-footer__list a {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
}

.site-footer__list a:hover {
    color: var(--ibid-secondary);
    opacity: 1;
}

.site-footer__bg {
    padding: clamp(1.5rem, 3vw, 2rem) 0 0;
    background: var(--site-footer-bg);
}

.site-footer__bg-inner {
    line-height: 0;
    border-radius: 12px 12px 0 0;
    overflow: hidden;
}

.site-footer__bg-img {
    display: block;
    width: 100%;
    height: auto;
}

.site-footer-copyright {
    padding: 1rem 0 1.35rem;
    background: var(--site-footer-bg);
}

.site-footer-copyright__text {
    font-size: 0.75rem;
    color: #7a7a7a;
    line-height: 1.5;
}

.site-footer-copyright__company {
    color: var(--ibid-primary);
}

/* AngularJS: hide uncompiled bindings (contact form alerts) */
[ng\:cloak], [ng-cloak], [data-ng-cloak], .ng-cloak {
    display: none !important;
}

/* ========== Contact page & Government collaboration page ========== */
body.page-contact,
body.page-gov-collab,
body.page-bidan,
body.page-events,
body.page-blog {
    padding-top: var(--site-header-offset);
    scroll-padding-top: calc(var(--site-header-offset) + 1rem);
    background-color: var(--ibid-cream);
    /* Photo at low visual weight: strong cream/white overlay on top of cover image */
    background-image:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.88) 0%,
            rgba(250, 248, 245, 0.84) 38%,
            rgba(250, 248, 245, 0.86) 72%,
            rgba(249, 247, 242, 0.9) 100%
        ),
        url('../img/home_page/about-main-photo.png');
    background-size: auto, cover;
    background-position: center, center 28%;
    background-repeat: no-repeat, no-repeat;
    background-attachment: scroll, scroll;
}

@media (max-width: 991.98px) {
    body.page-contact,
    body.page-gov-collab,
    body.page-bidan,
    body.page-events,
    body.page-blog {
        background-position: center, center 22%;
    }
}

/* Blog / event / bidan detail: solid white page for readable long-form content */
body.page-blog-detail,
body.page-event-detail,
body.page-bidan-detail {
    padding-top: var(--site-header-offset);
    scroll-padding-top: calc(var(--site-header-offset) + 1rem);
    background-color: var(--ibid-white);
    background-image: none;
}

.contact-hero {
    padding: clamp(2rem, 5vw, 3rem) 0 clamp(1.5rem, 4vw, 2.25rem);
    background: transparent;
}

.contact-hero__title {
    font-size: clamp(1.65rem, 3.2vw, 2.35rem);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: var(--ibid-text);
    margin-bottom: 0.75rem;
}

.contact-hero__lead {
    font-size: clamp(0.95rem, 1.25vw, 1.05rem);
    color: var(--ibid-text-muted);
    max-width: 40rem;
    margin-bottom: 0;
    line-height: 1.65;
}

/* Legal — Terms & Privacy */
body.page-legal {
    padding-top: var(--site-header-offset);
    scroll-padding-top: calc(var(--site-header-offset) + 1rem);
    background-color: #f8fafc;
    background-image: none;
}

.legal-hero {
    padding: clamp(2rem, 5vw, 3rem) 0 clamp(1.35rem, 3.5vw, 2rem);
    position: relative;
    background: linear-gradient(180deg, #fff 0%, rgba(240, 253, 250, 0.45) 100%);
}

.legal-hero::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(13, 148, 136, 0.22), transparent);
}

.legal-hero__icon-wrap {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(13, 148, 136, 0.16) 0%, rgba(45, 212, 191, 0.1) 100%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #0d9488;
    font-size: 1.4rem;
    margin-bottom: 1rem;
    box-shadow: 0 4px 16px rgba(13, 148, 136, 0.12);
}

.legal-hero__meta {
    max-width: 42rem;
}

.legal-main {
    padding: clamp(1.5rem, 4vw, 2.5rem) 0 clamp(3rem, 7vw, 5rem);
}

.legal-card {
    background: #fff;
    border-radius: 20px;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow:
        0 20px 50px -20px rgba(15, 23, 42, 0.12),
        0 0 0 1px rgba(13, 148, 136, 0.04);
    overflow: hidden;
}

.legal-card__inner {
    padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1.25rem, 4vw, 2.75rem);
}

.legal-section {
    padding-bottom: clamp(1.35rem, 3vw, 2rem);
    margin-bottom: clamp(1.35rem, 3vw, 2rem);
    border-bottom: 1px solid var(--ibid-border);
}

.legal-section--last {
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: none;
}

.legal-section__title {
    font-size: clamp(1.05rem, 2vw, 1.2rem);
    font-weight: 700;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin-bottom: 0.85rem;
    scroll-margin-top: calc(var(--site-header-offset) + 1rem);
}

.legal-section__text {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--ibid-text-muted);
    margin-bottom: 1rem;
    max-width: 52rem;
}

.legal-section__text:last-child {
    margin-bottom: 0;
}

.legal-section__text a {
    color: #0d9488;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.legal-section__text a:hover {
    color: #0f766e;
}

.legal-list {
    margin: 0 0 1rem;
    padding-left: 1.25rem;
    color: var(--ibid-text-muted);
    font-size: 0.9375rem;
    line-height: 1.7;
    max-width: 52rem;
}

.legal-list:last-child {
    margin-bottom: 0;
}

.legal-list li {
    margin-bottom: 0.5rem;
}

.legal-list li:last-child {
    margin-bottom: 0;
}

.legal-section__note {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px dashed rgba(13, 148, 136, 0.2);
}

.legal-cross-link {
    display: inline-flex;
    align-items: center;
    font-size: 0.9rem;
    font-weight: 600;
    color: #0d9488;
    text-decoration: none;
    transition: color 0.2s ease;
}

.legal-cross-link:hover {
    color: #0f766e;
}

.contact-main {
    padding: clamp(2rem, 4vw, 3.5rem) 0 clamp(3rem, 6vw, 4.5rem);
}

.contact-card {
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 1.25rem;
    padding: clamp(1.25rem, 3vw, 1.75rem);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
}

/* Inquiry column only: do not combine with .contact-card (that rule sets padding on all sides). */
.contact-form-card {
    height: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
    box-sizing: border-box;
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 1.25rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
}

.contact-form-card__inner {
    padding: clamp(1.25rem, 3vw, 1.75rem);
}

.contact-form-card__media {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    overflow: hidden;
    aspect-ratio: 21 / 9;
    max-height: 220px;
    background-color: var(--ibid-border);
    background-size: cover;
    background-position: right center;
    background-repeat: no-repeat;
}

@media (min-width: 992px) {
    .contact-form-card__media {
        max-height: 280px;
    }
}

.contact-card__title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--ibid-text);
    margin-bottom: 0.5rem;
}

.contact-card__intro {
    font-size: 0.9rem;
    margin-bottom: 1.25rem;
}

.contact-info-list__item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1rem 0;
    border-bottom: 1px solid var(--ibid-border);
}

.contact-info-list__item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.contact-info-list__icon {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(26, 95, 74, 0.1);
    color: var(--ibid-primary);
    font-size: 1rem;
}

.contact-info-list__label {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
    margin-bottom: 0.25rem;
}

.contact-info-list__text {
    font-size: 0.95rem;
    color: var(--ibid-text);
    line-height: 1.55;
}

.contact-info-list__text a {
    color: var(--ibid-primary);
    font-weight: 600;
}

.contact-info-list__text a:hover {
    color: var(--ibid-primary-dark);
    opacity: 1;
}

.contact-map-wrap {
    margin-top: 1.75rem;
}

.contact-map-wrap__title {
    font-size: 1.05rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    color: var(--ibid-text);
}

.contact-map {
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--ibid-border);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.06);
}

.contact-map iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
}

.contact-map-wrap__note {
    margin-top: 0.65rem;
    font-size: 0.8rem;
}

.contact-form__input,
.contact-form__textarea {
    border-radius: 0.65rem;
    border-color: var(--ibid-border);
}

.contact-form__input:focus,
.contact-form__textarea:focus {
    border-color: var(--ibid-primary);
    box-shadow: 0 0 0 0.2rem rgba(26, 95, 74, 0.15);
}

.contact-form__submit {
    padding: 0.85rem 2rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.8rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    background: var(--ibid-primary);
    color: var(--ibid-white) !important;
    border: none;
    transition: background 0.2s, transform 0.2s;
}

.contact-form__submit:hover {
    background: var(--ibid-primary-dark);
    color: var(--ibid-white) !important;
    opacity: 1;
}

.contact-alert {
    border-radius: 0.75rem;
    margin-bottom: 1.25rem;
}

.contact-faq {
    padding: clamp(3rem, 6vw, 4.5rem) 0 clamp(4rem, 8vw, 5.5rem);
    background: var(--ibid-cream);
}

.contact-faq__header {
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2.25rem;
}

.contact-faq__title {
    font-size: clamp(1.35rem, 2.6vw, 1.85rem);
    font-weight: 700;
    line-height: 1.25;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin-bottom: 0.65rem;
}

.contact-faq__sub {
    font-size: 0.95rem;
    margin-bottom: 0;
}

.contact-faq__accordion {
    max-width: 48rem;
    margin-left: auto;
    margin-right: auto;
}

.contact-faq__item {
    border: 1px solid var(--ibid-border);
    border-radius: 0.75rem !important;
    overflow: hidden;
    margin-bottom: 0.65rem;
    background: var(--ibid-white);
}

.contact-faq__item .accordion-button {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--ibid-text);
    background: var(--ibid-white);
    box-shadow: none;
}

.contact-faq__item .accordion-button:not(.collapsed) {
    color: var(--ibid-primary);
    background: rgba(26, 95, 74, 0.06);
}

.contact-faq__item .accordion-body {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
    line-height: 1.65;
    padding-top: 0;
}

/* ========== Government collaboration page ========== */
.gov-collab-main {
    padding: 0 0 clamp(2.5rem, 5vw, 3.5rem);
}

.gov-collab-block {
    padding: clamp(2rem, 4vw, 3rem) 0;
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.gov-collab-block:last-child {
    border-bottom: none;
}

.gov-collab-block--alt {
    background: rgba(255, 255, 255, 0.45);
    margin-left: calc(-0.5 * var(--bs-gutter-x, 1.5rem));
    margin-right: calc(-0.5 * var(--bs-gutter-x, 1.5rem));
    padding-left: calc(0.5 * var(--bs-gutter-x, 1.5rem));
    padding-right: calc(0.5 * var(--bs-gutter-x, 1.5rem));
    border-radius: 1.25rem;
    border-bottom: none;
    margin-bottom: 0.5rem;
}

.gov-collab-block--empty {
    border-bottom: none;
    padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1.25rem, 4vw, 2rem);
}

.gov-collab-block__media {
    position: relative;
    border-radius: 1.25rem;
    overflow: hidden;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
    background: linear-gradient(160deg, #faf7f2 0%, #f2ebe1 55%, #efe8dd 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 12rem;
}

.gov-collab-block__media-deco {
    position: absolute;
    left: -6%;
    bottom: -8%;
    width: 55%;
    height: 45%;
    max-height: 220px;
    background: rgba(232, 196, 160, 0.35);
    border-radius: 40% 60% 45% 55% / 55% 45% 55% 45%;
    z-index: 0;
    pointer-events: none;
}

.gov-collab-block__img {
    position: relative;
    z-index: 1;
    display: block;
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: min(85vh, 880px);
    margin-left: auto;
    margin-right: auto;
    object-fit: contain;
    object-position: center center;
    border-radius: 0.35rem;
}

.gov-collab-rich-text {
    font-size: clamp(0.95rem, 1.1vw, 1.02rem);
    line-height: 1.65;
    color: var(--ibid-text-muted);
}

.gov-collab-rich-text > :first-child {
    margin-top: 0;
}

.gov-collab-rich-text > :last-child {
    margin-bottom: 0;
}

.gov-collab-rich-text h1,
.gov-collab-rich-text h2,
.gov-collab-rich-text h3 {
    font-weight: 700;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    line-height: 1.25;
    margin-top: 1.25rem;
    margin-bottom: 0.65rem;
}

.gov-collab-rich-text h1:first-child,
.gov-collab-rich-text h2:first-child,
.gov-collab-rich-text h3:first-child {
    margin-top: 0;
}

.gov-collab-rich-text h2 {
    font-size: clamp(1.2rem, 2.2vw, 1.45rem);
}

.gov-collab-rich-text h3 {
    font-size: 1.1rem;
}

.gov-collab-rich-text p {
    margin-bottom: 0.85rem;
}

.gov-collab-rich-text a {
    color: var(--ibid-primary);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.gov-collab-rich-text a:hover {
    color: var(--ibid-primary-dark);
}

.gov-collab-rich-text ul,
.gov-collab-rich-text ol {
    margin-bottom: 0.85rem;
    padding-left: 1.25rem;
}

.gov-collab-rich-text li {
    margin-bottom: 0.35rem;
}

.gov-collab-rich-text b,
.gov-collab-rich-text strong {
    color: var(--ibid-text);
    font-weight: 700;
}

.gov-collab-check__item {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.65rem 0;
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--ibid-text);
    border-bottom: 1px solid var(--ibid-border);
}

.gov-collab-check__item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.gov-collab-check__icon {
    flex-shrink: 0;
    color: var(--ibid-primary);
    margin-top: 0.15rem;
}

.gov-collab-card {
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 1.25rem;
    padding: clamp(1.15rem, 3vw, 1.5rem);
    height: 100%;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.gov-collab-card:hover {
    border-color: rgba(26, 95, 74, 0.25);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
}

.gov-collab-card__icon {
    width: 2.75rem;
    height: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.75rem;
    background: rgba(26, 95, 74, 0.1);
    color: var(--ibid-primary);
    font-size: 1.15rem;
    margin-bottom: 0.85rem;
}

.gov-collab-card__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--ibid-text);
    margin-bottom: 0.45rem;
}

.gov-collab-card__text {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
    line-height: 1.6;
}

.gov-collab-models {
    padding: clamp(2rem, 5vw, 3rem) 0 clamp(2.5rem, 5vw, 3.5rem);
    background: rgba(255, 255, 255, 0.55);
}

.gov-collab-models__header {
    max-width: 40rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2.25rem;
}

.gov-collab-models__title {
    font-size: clamp(1.35rem, 2.6vw, 1.85rem);
    font-weight: 700;
    color: var(--ibid-text);
    letter-spacing: -0.02em;
    margin-bottom: 0.65rem;
}

.gov-collab-models__sub {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
    margin-bottom: 0;
    line-height: 1.6;
}

.gov-collab-panel {
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 1.25rem;
    padding: clamp(1.35rem, 3vw, 1.75rem);
    height: 100%;
    position: relative;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.04);
}

.gov-collab-panel__step {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ibid-primary);
    margin-bottom: 0.5rem;
}

.gov-collab-panel__title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--ibid-text);
    margin-bottom: 0.5rem;
}

.gov-collab-panel__text {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
    line-height: 1.6;
}

.gov-collab-impact {
    padding: 0 0 clamp(2.5rem, 5vw, 3.5rem);
}

.gov-collab-impact__inner {
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 1.25rem;
    padding: clamp(1.75rem, 4vw, 2.5rem);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
}

.gov-collab-impact__num {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--ibid-primary);
    margin-bottom: 0.25rem;
    letter-spacing: -0.02em;
}

.gov-collab-impact__label {
    font-size: 0.85rem;
    color: var(--ibid-text-muted);
}

.gov-collab-cta {
    padding: 0 0 clamp(3rem, 6vw, 4.5rem);
}

.gov-collab-cta__card {
    background: linear-gradient(135deg, rgba(26, 95, 74, 0.08) 0%, rgba(26, 95, 74, 0.02) 100%);
    border: 1px solid rgba(26, 95, 74, 0.2);
    border-radius: 1.25rem;
    padding: clamp(1.5rem, 4vw, 2.25rem);
}

.gov-collab-cta__title {
    font-size: clamp(1.2rem, 2.4vw, 1.55rem);
    font-weight: 700;
    color: var(--ibid-text);
    margin-bottom: 0.65rem;
    letter-spacing: -0.02em;
}

.gov-collab-cta__text {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
    line-height: 1.65;
}

.gov-collab-cta__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.85rem 1.75rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.8rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-decoration: none;
    background: var(--ibid-primary);
    color: var(--ibid-white) !important;
    border: none;
    transition: background 0.2s, transform 0.2s;
}

.gov-collab-cta__btn:hover {
    background: var(--ibid-primary-dark);
    color: var(--ibid-white) !important;
}

/* ========== Events list & detail ========== */
.events-list-section,
.blog-list-section {
    padding: 0 0 clamp(2.5rem, 5vw, 3.5rem);
}

.blog-list__layout {
    --blog-cat-active-bg: rgba(26, 95, 74, 0.12);
    --blog-cat-active-border: var(--ibid-primary, #1a5f4a);
}

/* Blog, shop & events — pagination from Setting_model::get_paging (ul.pagination, li.pagination-btn) */
body.page-blog .blog-pagination,
body.page-products .products-pagination,
body.page-events .events-pagination {
    padding: 0 0 clamp(2rem, 4vw, 2.75rem);
}

body.page-blog .blog-pagination .pagination,
body.page-products .products-pagination .pagination,
body.page-events .events-pagination .pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

body.page-blog .blog-pagination .pagination .pagination-btn,
body.page-products .products-pagination .pagination .pagination-btn,
body.page-events .events-pagination .pagination .pagination-btn {
    margin: 0;
    padding: 0;
    list-style: none;
}

body.page-blog .blog-pagination .pagination .pagination-btn > a,
body.page-products .products-pagination .pagination .pagination-btn > a,
body.page-events .events-pagination .pagination .pagination-btn > a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    min-height: 2.5rem;
    padding: 0.4rem 0.7rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none;
    color: var(--ibid-text);
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}

body.page-blog .blog-pagination .pagination .pagination-btn > a:hover,
body.page-products .products-pagination .pagination .pagination-btn > a:hover,
body.page-events .events-pagination .pagination .pagination-btn > a:hover {
    color: var(--ibid-primary);
    border-color: rgba(26, 95, 74, 0.35);
    box-shadow: 0 4px 12px rgba(26, 95, 74, 0.1);
    opacity: 1;
}

body.page-blog .blog-pagination .pagination .pagination-btn.active > a,
body.page-blog .blog-pagination .pagination li.active.pagination-btn > a,
body.page-products .products-pagination .pagination .pagination-btn.active > a,
body.page-products .products-pagination .pagination li.active.pagination-btn > a,
body.page-events .events-pagination .pagination .pagination-btn.active > a,
body.page-events .events-pagination .pagination li.active.pagination-btn > a {
    color: var(--ibid-white) !important;
    background: var(--ibid-primary);
    border-color: var(--ibid-primary);
    box-shadow: 0 4px 14px rgba(26, 95, 74, 0.25);
    cursor: default;
    pointer-events: none;
}

body.page-blog .blog-pagination .pagination .pagination-btn.active > a:hover,
body.page-products .products-pagination .pagination .pagination-btn.active > a:hover,
body.page-events .events-pagination .pagination .pagination-btn.active > a:hover {
    color: var(--ibid-white) !important;
    opacity: 1;
}

.blog-cat-nav__title.letter-spacing {
    letter-spacing: 0.12em;
}

.blog-cat-nav__list {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.blog-cat-nav__link {
    display: block;
    padding: 0.55rem 0.85rem 0.55rem 0.95rem;
    border-radius: 0.5rem;
    text-decoration: none;
    color: var(--ibid-text, #1a1a1a);
    font-weight: 500;
    font-size: 0.95rem;
    line-height: 1.35;
    border-left: 3px solid transparent;
    transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.blog-cat-nav__link:hover {
    background: rgba(0, 0, 0, 0.04);
    color: var(--ibid-primary, #1a5f4a);
}

.blog-cat-nav__link:focus-visible {
    outline: 2px solid var(--ibid-primary, #1a5f4a);
    outline-offset: 2px;
}

.blog-cat-nav__link--active {
    background: var(--blog-cat-active-bg);
    color: var(--ibid-primary, #1a5f4a);
    border-left-color: var(--blog-cat-active-border);
    font-weight: 600;
}

@media (min-width: 992px) {
    .blog-cat-nav {
        position: sticky;
        top: 1.25rem;
    }
}

.events-card {
    background: var(--ibid-white);
    border: 1px solid var(--ibid-border);
    border-radius: 1.25rem;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.events-card:hover {
    border-color: rgba(26, 95, 74, 0.22);
    box-shadow: 0 14px 44px rgba(0, 0, 0, 0.07);
}

.events-card__media-link {
    display: block;
    text-decoration: none;
}

.events-card__media {
    background: var(--ibid-border);
}

.events-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.events-card__body {
    padding: clamp(1.1rem, 3vw, 1.35rem);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.events-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    margin-bottom: 0.65rem;
}

.events-card__date {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--ibid-text-muted);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.events-card__badge {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: rgba(26, 95, 74, 0.12);
    color: var(--ibid-primary);
}

.events-card__badge--muted {
    background: rgba(0, 0, 0, 0.06);
    color: var(--ibid-text-muted);
}

.events-card__title {
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.35;
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
}

.events-card__title a {
    color: var(--ibid-text);
    text-decoration: none;
}

.events-card__title a:hover {
    color: var(--ibid-primary);
}

.events-card__excerpt {
    font-size: 0.9rem;
    color: var(--ibid-text-muted);
    line-height: 1.55;
    margin-bottom: 1rem;
    flex: 1;
}

.events-card__more {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ibid-primary);
    text-decoration: none;
    margin-top: auto;
}

.events-card__more:hover {
    color: var(--ibid-primary-dark);
}

/* ========== Shop / product catalog (ecommerce list) ========== */
body.page-products .blog-list-section.shop-catalog {
    padding-top: clamp(0.5rem, 2vw, 1rem);
}

.shop-hero .contact-hero__lead {
    max-width: 40rem;
}

.shop-hero__trust-item {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--ibid-text-muted);
    line-height: 1.45;
}

.shop-hero__trust-item i {
    flex-shrink: 0;
    margin-top: 0.15rem;
    color: var(--ibid-secondary);
    font-size: 1rem;
}

/* Grid: avoids a single product stuck in a half-width Bootstrap column */
.shop-product-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 3vw, 1.75rem);
}

@media (min-width: 992px) {
    .shop-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .shop-product-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.shop-product-grid--single {
    grid-template-columns: minmax(0, 380px);
    justify-content: center;
}

/* ========== Product detail (shop) ========== */
body.page-product-detail {
    background: var(--ibid-white);
}

.shop-product-detail-hero {
    padding: clamp(1rem, 3vw, 1.5rem) 0 0;
    background: transparent;
}

.shop-product-detail-main {
    padding: 0 0 clamp(2.5rem, 5vw, 4rem);
}

.shop-product-detail__media {
    position: relative;
    min-width: 0;
}

.shop-product-detail__frame {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
    border-radius: 1.35rem;
    overflow: hidden;
    background: linear-gradient(165deg, #f3f0eb 0%, var(--ibid-border) 100%);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.08);
}

.shop-product-detail__img {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
}

.shop-product-detail__thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
}

@media (max-width: 575.98px) {
    .shop-product-detail__thumbs {
        flex-wrap: nowrap;
        justify-content: flex-start;
        overflow-x: auto;
        overflow-y: hidden;
        padding-bottom: 0.35rem;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }
}

.shop-product-detail__thumb {
    flex: 0 0 auto;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: 0.65rem;
    opacity: 0.72;
    transition: opacity 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.shop-product-detail__thumb:hover,
.shop-product-detail__thumb:focus-visible {
    opacity: 1;
    outline: none;
}

.shop-product-detail__thumb:focus-visible {
    box-shadow: 0 0 0 3px rgba(26, 95, 74, 0.45);
}

.shop-product-detail__thumb.is-active {
    opacity: 1;
    transform: translateY(-1px);
}

.shop-product-detail__thumb-frame {
    display: block;
    width: 4.25rem;
    height: 4.25rem;
    border-radius: 0.65rem;
    overflow: hidden;
    border: 2px solid var(--ibid-border);
    background: linear-gradient(165deg, #f3f0eb 0%, var(--ibid-border) 100%);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.shop-product-detail__thumb.is-active .shop-product-detail__thumb-frame {
    border-color: var(--ibid-primary);
    box-shadow: 0 6px 18px rgba(26, 95, 74, 0.2);
}

.shop-product-detail__thumb-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.shop-product-detail__summary {
    padding-top: 0.25rem;
}

/* Sticky only when Details live in a separate row — never stick over long content in the same column */
@media (min-width: 992px) {
    .shop-product-detail__summary {
        position: sticky;
        top: 5.5rem;
        z-index: 2;
        align-self: flex-start;
        background: var(--ibid-white);
        padding-bottom: 0.5rem;
    }
}

.shop-product-detail__title {
    font-size: clamp(1.5rem, 3.5vw, 2.15rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.2;
    color: var(--ibid-text);
    margin-bottom: 1rem;
}

.shop-product-detail__meta-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.65rem;
    margin-bottom: 1rem;
}

.shop-product-detail__sku-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.38rem 0.9rem 0.38rem 0.75rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.045);
    border: 1px solid var(--ibid-border);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
}

.shop-product-detail__sku-label {
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ibid-text-muted);
}

.shop-product-detail__sku-value {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.035em;
    color: var(--ibid-text);
}

.shop-product-detail__price-row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 1rem;
    margin-bottom: 1rem;
}

.shop-product-detail__price-regular,
.shop-product-detail__price-sale {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--ibid-primary);
}

.shop-product-detail__price-was {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--ibid-text-muted);
    text-decoration: line-through;
}

.shop-product-detail__lead {
    font-size: 1.02rem;
    line-height: 1.65;
}

.shop-product-detail__actions {
    margin-top: 0.5rem;
}

.shop-product-detail__cta-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.85rem 1.5rem;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--ibid-white) !important;
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    border-radius: 999px;
    border: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    opacity: 1;
}

.shop-product-detail__cta-primary:hover {
    color: var(--ibid-white) !important;
    opacity: 1;
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(26, 95, 74, 0.35);
}

.shop-product-detail__cta-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.85rem 1.25rem;
    font-size: 0.88rem;
    font-weight: 700;
    text-decoration: none;
    color: var(--ibid-primary);
    border: 2px solid rgba(26, 95, 74, 0.35);
    border-radius: 999px;
    background: transparent;
    transition: background 0.2s, border-color 0.2s;
}

.shop-product-detail__cta-secondary:hover {
    opacity: 1;
    background: rgba(26, 95, 74, 0.06);
    border-color: var(--ibid-primary);
    color: var(--ibid-primary-dark);
}

.shop-product-detail__note {
    max-width: 28rem;
    line-height: 1.5;
}

.shop-product-detail__content-heading {
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--ibid-text);
}

.shop-product-detail__content {
    position: relative;
    z-index: 0;
    padding-top: clamp(1.25rem, 3vw, 2rem);
    border-top: 1px solid var(--ibid-border);
    clear: both;
    overflow-wrap: break-word;
}

.shop-product-detail__content::after {
    content: '';
    display: table;
    clear: both;
}

.shop-product-detail-main .col-lg-6.col-xl-5 {
    min-width: 0;
}

.shop-contact-product-hint {
    border-color: rgba(26, 95, 74, 0.2) !important;
    background: rgba(26, 95, 74, 0.04) !important;
    border-radius: 0.75rem;
}

.events-card.events-card--product {
    border-radius: 1.35rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.06);
    transition: transform 0.25s ease, border-color 0.2s, box-shadow 0.25s ease;
}

.events-card.events-card--product:hover {
    transform: translateY(-4px);
    border-color: rgba(26, 95, 74, 0.28);
    box-shadow: 0 20px 48px rgba(26, 95, 74, 0.12);
}

/* Do not use Bootstrap .ratio here: global img { height: auto } breaks ratio children and causes broken / “white disc” crops */
.shop-product-media__frame {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: linear-gradient(180deg, #f3f0eb 0%, var(--ibid-border) 100%);
}

.shop-catalog .shop-product-media__img {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.events-card.events-card--product:hover .shop-product-media__img {
    transform: scale(1.06);
}

.shop-product-badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    z-index: 3;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    line-height: 1.2;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
}

.shop-product-badge--sale {
    background: linear-gradient(135deg, var(--ibid-secondary) 0%, var(--ibid-secondary-dark) 100%);
    color: var(--ibid-white);
}

.shop-product-badge--featured {
    background: var(--ibid-white);
    color: var(--ibid-primary);
    border: 1px solid rgba(26, 95, 74, 0.2);
}

.shop-product-price {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.65rem;
    margin-bottom: 0.85rem;
}

.shop-product-price__current {
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--ibid-primary);
    line-height: 1.2;
}

.shop-product-price__current--solo {
    color: var(--ibid-text);
}

.shop-product-price__was {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--ibid-text-muted);
    text-decoration: line-through;
}

.shop-product-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-top: auto;
    padding: 0.65rem 1rem;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--ibid-white) !important;
    background: linear-gradient(135deg, var(--ibid-primary) 0%, var(--ibid-primary-dark) 100%);
    border-radius: 999px;
    border: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s;
    opacity: 1;
}

.shop-product-cta:hover {
    opacity: 1;
    color: var(--ibid-white) !important;
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(26, 95, 74, 0.35);
}

.shop-product-cta:focus-visible {
    outline: 2px solid var(--ibid-secondary);
    outline-offset: 2px;
}

.events-card--product .events-card__title {
    font-size: clamp(1rem, 2.5vw, 1.12rem);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

@media (max-width: 575.98px) {
    .shop-product-price__current {
        font-size: 1.15rem;
    }

    .events-card--product .events-card__title {
        font-size: 0.95rem;
    }

    .shop-product-cta {
        padding: 0.55rem 0.75rem;
        font-size: 0.7rem;
    }
}

.events-empty__icon {
    font-size: 2.5rem;
    color: var(--ibid-text-muted);
}

.events-empty__title {
    color: var(--ibid-text);
}

.events-list-cta,
.blog-list-cta {
    padding: 0 0 clamp(3rem, 6vw, 4.5rem);
}

.events-list-cta__inner {
    background: linear-gradient(135deg, rgba(26, 95, 74, 0.06) 0%, rgba(26, 95, 74, 0.02) 100%);
    border: 1px solid rgba(26, 95, 74, 0.15);
    border-radius: 1.25rem;
    padding: clamp(1.5rem, 4vw, 2rem);
}

.events-list-cta__title {
    font-size: clamp(1.15rem, 2.2vw, 1.45rem);
    font-weight: 700;
    color: var(--ibid-text);
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
}

.events-list-cta__text {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
    line-height: 1.65;
}

.events-detail-hero {
    padding: clamp(1.5rem, 4vw, 2rem) 0 clamp(1rem, 3vw, 1.5rem);
    background: transparent;
}

.events-detail-breadcrumb__list {
    list-style: none;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.5rem;
    align-items: center;
    font-size: 0.85rem;
    color: var(--ibid-text-muted);
}

.events-detail-breadcrumb__list li {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.events-detail-breadcrumb__list li:not(:last-child)::after {
    content: "/";
    margin-left: 0.35rem;
    opacity: 0.5;
}

.events-detail-breadcrumb__list a {
    color: var(--ibid-primary);
    text-decoration: none;
    font-weight: 600;
}

.events-detail-breadcrumb__list a:hover {
    text-decoration: underline;
}

.events-detail-hero__when {
    font-size: 0.95rem;
    color: var(--ibid-text-muted);
    margin-bottom: 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.events-detail-main {
    padding-bottom: 0;
}

.events-detail-cover {
    border-radius: 1.25rem;
    overflow: hidden;
    border: 1px solid var(--ibid-border);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.06);
}

.events-detail-cover__img {
    display: block;
    width: 100%;
    height: auto;
}

.events-detail-seo__h {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--ibid-text);
}

.events-detail-seo__p {
    font-size: 0.95rem;
    line-height: 1.65;
}

.events-detail-description {
    font-size: 1rem;
    line-height: 1.7;
}

.events-detail-content {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--ibid-text);
}

.events-detail-content h2,
.events-detail-content h3,
.events-detail-content h4 {
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
    font-weight: 700;
    color: var(--ibid-text);
}

.events-detail-content p {
    margin-bottom: 1rem;
}

.events-detail-content ul,
.events-detail-content ol {
    margin-bottom: 1rem;
    padding-left: 1.25rem;
}

.events-detail-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0.75rem;
}

.events-detail-back {
    font-weight: 600;
    color: var(--ibid-primary);
    text-decoration: none;
}

.events-detail-back:hover {
    text-decoration: underline;
}

/* Blog detail: category pill */
.blog-detail-category-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.blog-detail-category {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    padding: 0.4rem 0.95rem;
    border-radius: 999px;
    line-height: 1.2;
    background: rgba(26, 95, 74, 0.1);
    color: var(--ibid-primary);
    border: 1px solid rgba(26, 95, 74, 0.28);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset;
}

.blog-detail-category i {
    font-size: 0.7rem;
    opacity: 0.92;
}

.blog-detail-category--muted {
    background: rgba(0, 0, 0, 0.04);
    color: var(--ibid-text-muted);
    border-color: var(--ibid-border);
    font-weight: 600;
    letter-spacing: 0.1em;
    box-shadow: none;
}

/* Blog list cards: same pill as detail, slightly tighter in meta row */
.events-card__meta .blog-detail-category {
    font-size: 0.68rem;
    padding: 0.32rem 0.8rem;
}

.events-card__meta .blog-detail-category i {
    font-size: 0.62rem;
}

/* Bidan directory cards */
.bidan-profile-card .bidan-profile-card__media {
    border-radius: 1.25rem 1.25rem 0 0;
    overflow: hidden;
    background: var(--ibid-border);
}

.bidan-profile-card__legal {
    line-height: 1.35;
}

.bidan-profile-card__meta {
    font-size: 0.88rem;
    color: var(--ibid-text-muted);
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    line-height: 1.4;
}

.bidan-profile-card__meta i {
    margin-top: 0.15rem;
    flex-shrink: 0;
}

.bidan-profile-card__pillars {
    font-size: 0.8rem;
    line-height: 1.45;
}

.bidan-profile-card__pillars li {
    margin-bottom: 0.2rem;
}

.bidan-profile-card__pillar-label {
    font-weight: 600;
    color: var(--ibid-text);
}

.bidan-page__filter .letter-spacing {
    letter-spacing: 0.12em;
}

/* Bidan list: modest gap under hero (fixed rem ≈ px at default 16px root) */
body.page-bidan .contact-hero {
    padding-bottom: 1.5rem; /* 24px */
}

/* Two classes beat .blog-list-section { padding: 0 0 ... } */
.bidan-page__directory.blog-list-section {
    --home-mbidan-cream: #f9f7f2;
    background: var(--home-mbidan-cream);
    padding-top: 2rem; /* 16px — space before “Filter directory” */
    padding-bottom: 2rem; /* 32px — space after card grid */
    padding-left: 0;
    padding-right: 0;
}

/* Filter row above grid */
.bidan-page__directory .bidan-page__filter {
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

/* Match directory card CTAs (.bidan-page__profile-btn): same orange */
.bidan-page__filter-actions .btn.bidan-page__filter-btn {
    font-weight: 600;
}

.bidan-page__filter-actions .btn.bidan-page__filter-btn--primary {
    color: var(--ibid-white);
    background-color: #d69345;
    border: 1px solid #d69345;
}

.bidan-page__filter-actions .btn.bidan-page__filter-btn--primary:hover {
    color: var(--ibid-white);
    background-color: #c48338;
    border-color: #c48338;
}

.bidan-page__filter-actions .btn.bidan-page__filter-btn--primary:focus-visible {
    color: var(--ibid-white);
    background-color: #c48338;
    border-color: #c48338;
    box-shadow: 0 0 0 0.2rem rgba(214, 147, 69, 0.35);
}

.bidan-page__filter-actions .btn.bidan-page__filter-btn--outline {
    color: #d69345;
    background-color: transparent;
    border: 1px solid #d69345;
}

.bidan-page__filter-actions .btn.bidan-page__filter-btn--outline:hover {
    color: var(--ibid-white);
    background-color: #d69345;
    border-color: #d69345;
}

.bidan-page__filter-actions .btn.bidan-page__filter-btn--outline:focus-visible {
    color: var(--ibid-white);
    background-color: #d69345;
    border-color: #d69345;
    box-shadow: 0 0 0 0.2rem rgba(214, 147, 69, 0.35);
}

/* Bidan directory page — grid of cards (no carousel) */
.bidan-page__directory {
    --home-mbidan-cream: #f9f7f2;
    background: var(--home-mbidan-cream);
}

.bidan-page__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.5rem;
    justify-items: center;
}

.bidan-page__grid .home-mbidan__card {
    width: 100%;
    max-width: 320px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.bidan-page__grid .home-mbidan__card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.09);
}

.bidan-page__meta {
    text-align: center;
    margin-bottom: 1rem;
}

.bidan-page__meta .home-mbidan__name,
.bidan-page__meta .home-mbidan__role {
    text-align: center;
}

.bidan-page__profile-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 0.55rem 1rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--ibid-white);
    text-decoration: none;
    border-radius: 999px;
    background: #d69345;
    border: none;
    transition: background 0.2s, transform 0.15s;
}

.bidan-page__profile-btn:hover {
    background: #c48338;
    color: var(--ibid-white);
    transform: translateY(-1px);
}

/* Bidan profile detail — 3-column layout (matches marketing profile) */
.bidan-profile {
    --bidan-profile-orange: #f39200;
    --bidan-profile-orange-dark: #d69345;
    --bidan-profile-text: #1a1a1a;
    --bidan-profile-muted: #6b6b6b;
    --bidan-profile-stat-size: 112px;
    background: var(--ibid-white);
}

.bidan-profile__container {
    max-width: 1200px;
}

/* Hero top row: Bootstrap row — photo (col) | stat circles + book (col) */
.bidan-profile__hero-top {
    margin-bottom: 0;
}

.bidan-profile__hero-stats {
    min-width: 0;
    padding-top: 0;
}

.bidan-profile__photo-wrap {
    width: 100%;
    max-width: 100%;
    border-radius: 12px;
    overflow: hidden;
    background: transparent;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

.bidan-profile__photo {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 400 / 600;
    object-fit: cover;
}

.bidan-profile__hero-heading .bidan-profile__name {
    margin-top: 0;
}

.bidan-profile__hero-heading .bidan-profile__role {
    margin-bottom: 0;
}

.bidan-profile__badges {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
}

.bidan-profile__stat-badge {
    border: 2px solid #d98e39;
    border-radius: 50%;
    width: var(--bidan-profile-stat-size);
    height: var(--bidan-profile-stat-size);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0.4rem;
    background: var(--ibid-white);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.07);
}

.bidan-profile__stat-badge-num {
    font-size: 1.15rem;
    font-weight: 800;
    color: #d98e39;
    line-height: 1.1;
}

.bidan-profile__stat-badge-caption {
    display: block;
    margin-top: 0.15rem;
    font-size: 0.56rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #888;
    line-height: 1.2;
}

.bidan-profile__stat-badge-caption--caps {
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.5rem;
}

.bidan-profile__name {
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    font-weight: 800;
    color: #d98e39;
    margin: 0 0 0.35rem;
    line-height: 1.2;
}

.bidan-profile__role {
    font-size: 1rem;
    font-weight: 500;
    color: #e8a040;
    margin: 0;
    line-height: 1.35;
}

.bidan-profile__book {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    width: 100%;
    max-width: 100%;
    padding: 0.75rem 1.25rem;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ibid-white);
    text-decoration: none;
    border-radius: 999px;
    background: linear-gradient(180deg, #ffa126 0%, var(--bidan-profile-orange) 100%);
    box-shadow: 0 4px 16px rgba(243, 146, 0, 0.35);
    transition: transform 0.15s, box-shadow 0.15s;
}

.bidan-profile__book--beside-photo {
    width: var(--bidan-profile-stat-size);
    max-width: var(--bidan-profile-stat-size);
    min-width: 0;
    box-sizing: border-box;
    justify-content: space-between;
    flex-direction: row;
    align-items: center;
    gap: 0.2rem;
    padding: 0.45rem 0.4rem 0.45rem 0.5rem;
    font-size: 0.58rem;
    line-height: 1.15;
    text-align: left;
}

.bidan-profile__book--beside-photo > span:first-child {
    min-width: 0;
}

.bidan-profile__book:hover {
    color: var(--ibid-white);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(243, 146, 0, 0.45);
}

.bidan-profile__book-play {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    font-size: 0.62rem;
    line-height: 1;
    opacity: 0.95;
}

.bidan-profile__facts {
    margin: 1.5rem 0 0;
    font-size: 0.88rem;
    color: var(--bidan-profile-muted);
}

.bidan-profile__fact {
    margin-bottom: 0.65rem;
}

.bidan-profile__fact dt {
    font-weight: 700;
    color: var(--bidan-profile-text);
    margin: 0 0 0.15rem;
    font-size: 0.82rem;
}

.bidan-profile__fact dd {
    margin: 0;
    line-height: 1.45;
}

/* Super Mama Story — outer card, inner orange frame, + badge top-right */
.bidan-profile__mama-box {
    display: block;
    margin-top: 1.25rem;
    padding: 1rem 0.85rem 0.75rem;
    border-radius: 14px;
    background: var(--ibid-white);
    box-shadow: 0 4px 22px rgba(0, 0, 0, 0.08);
    text-decoration: none;
    color: inherit;
    overflow: visible;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
}

.bidan-profile__mama-box:hover {
    color: inherit;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12);
    transform: translateY(-1px);
}

.bidan-profile__mama-inner {
    position: relative;
    border: 1px solid var(--bidan-profile-orange);
    border-radius: 12px;
    padding: 1.35rem 1rem 1.15rem;
}

.bidan-profile__mama-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.2rem;
}

.bidan-profile__mama-plus {
    position: absolute;
    top: 0;
    right: 0;
    width: 44px;
    height: 44px;
    transform: translate(45%, -45%);
    border-radius: 50%;
    background: linear-gradient(160deg, #ffc14d 0%, var(--bidan-profile-orange) 50%, #e07800 100%);
    border: 4px solid var(--ibid-white);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
    color: var(--ibid-white);
    font-weight: 700;
    font-size: 1.35rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.bidan-profile__mama-num {
    display: block;
    font-size: clamp(1.85rem, 5vw, 2.35rem);
    font-weight: 800;
    color: var(--bidan-profile-orange);
    line-height: 1.05;
}

.bidan-profile__mama-line {
    display: block;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: var(--bidan-profile-text);
    line-height: 1.2;
}

.bidan-profile__review-row {
    margin-top: 1rem;
}

.bidan-profile__pill-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.85rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-decoration: none;
    border-radius: 999px;
    background: var(--bidan-profile-orange);
    color: var(--ibid-white);
    border: 2px solid var(--bidan-profile-orange);
    transition: background 0.15s, color 0.15s;
}

.bidan-profile__pill-btn:hover {
    color: var(--ibid-white);
    background: #e08500;
}

.bidan-profile__pill-btn--outline {
    background: var(--ibid-white);
    color: var(--bidan-profile-orange);
}

.bidan-profile__pill-btn--outline:hover {
    background: #fff8ed;
    color: var(--bidan-profile-orange);
}

.bidan-profile__block {
    margin-bottom: 1.75rem;
}

.bidan-profile__block-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--bidan-profile-text);
    margin: 0 0 0.85rem;
    text-transform: capitalize;
}

.bidan-profile__checklist li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.55rem;
    font-size: 0.9rem;
    color: var(--bidan-profile-muted);
    line-height: 1.5;
}

.bidan-profile__checklist i {
    position: absolute;
    left: 0;
    top: 0.2rem;
    color: var(--bidan-profile-orange);
    font-size: 0.8rem;
}

.bidan-profile__recognition-group {
    margin-bottom: 1.75rem;
}

.bidan-profile__recognition-group > .bidan-profile__block-title {
    margin-bottom: 0.65rem;
}

.bidan-profile__recognition {
    background: var(--ibid-white);
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.07);
    border-left: 4px solid var(--bidan-profile-orange);
    padding: 1.25rem 1.25rem 1.25rem 1rem;
    margin-bottom: 0;
}

.bidan-profile__recognition-item {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    margin-bottom: 0.85rem;
    font-size: 0.88rem;
    color: var(--bidan-profile-text);
    line-height: 1.45;
}

.bidan-profile__recognition-item:last-child {
    margin-bottom: 0;
}

.bidan-profile__recognition-dot {
    flex-shrink: 0;
    width: 10px;
    height: 10px;
    margin-top: 0.35rem;
    border-radius: 50%;
    background: var(--bidan-profile-orange);
}

.bidan-profile__recognition-item a {
    color: var(--bidan-profile-text);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.bidan-profile__recognition-item a:hover {
    color: var(--bidan-profile-orange);
}

.bidan-profile__pillars-block {
    margin-bottom: 1.75rem;
}

.bidan-profile__pillar-row {
    margin-bottom: 1rem;
}

.bidan-profile__pillar-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
}

.bidan-profile__pillar-name {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--bidan-profile-text);
    line-height: 1.3;
}

.bidan-profile__pillar-pct {
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--bidan-profile-orange);
    flex-shrink: 0;
}

.bidan-profile__pillar-track {
    height: 8px;
    border-radius: 999px;
    background: #e8e8e8;
    overflow: hidden;
}

.bidan-profile__pillar-fill {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #ffb84d, var(--bidan-profile-orange));
    transition: width 0.4s ease;
}

.bidan-profile__pillar-kv {
    margin-top: 0.35rem;
    font-size: 0.75rem;
}

.bidan-profile__summary-body {
    font-size: 0.95rem;
    line-height: 1.65;
}

@media (max-width: 991.98px) {
    .bidan-profile {
        --bidan-profile-stat-size: 100px;
    }

    .bidan-profile__stat-badge-num {
        font-size: 1.05rem;
    }

    .bidan-profile__book--beside-photo {
        font-size: 0.52rem;
    }
}

@media (max-width: 575.98px) {
    .bidan-profile__hero-stats .bidan-profile__badges {
        flex-direction: row;
        justify-content: center;
        flex-wrap: wrap;
    }

    .bidan-profile__book--beside-photo {
        margin-inline: auto;
    }

    .bidan-profile__hero-heading {
        text-align: center;
    }
}

/* Booking result (lookup by serial) */
body.page-booking-result .booking-result-page__dl--kv dt,
body.page-booking-result .booking-result-page__dl--kv dd {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--ibid-border);
    margin-bottom: 0;
}

body.page-booking-result .booking-result-page__dl--kv dt {
    align-self: center;
}

body.page-booking-result .booking-result-page__dl--kv dt:last-of-type,
body.page-booking-result .booking-result-page__dl--kv dd:last-of-type {
    border-bottom: none;
}

body.page-booking-result .booking-result-page__dl--aside dt,
body.page-booking-result .booking-result-page__dl--aside dd {
    font-size: 0.8125rem;
    padding-top: 0.35rem;
    padding-bottom: 0.35rem;
}

/* Sidebar: one sticky column so Payment list + Summary move together (no overlapping stickies). */
@media (min-width: 992px) {
    body.page-booking-result .booking-result-page__aside-col {
        position: sticky;
        top: calc(var(--site-header-offset) + 1rem);
        align-self: flex-start;
        z-index: 2;
    }

    body.page-booking-result .booking-result-page__aside-col .booking-checkout-card {
        position: relative;
        top: auto;
    }
}

body.page-booking-result .booking-result-page__payment-stack {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

body.page-booking-result .booking-result-page__payment-block {
    border: 1px solid var(--ibid-border);
    border-radius: 12px;
    overflow: hidden;
    background: var(--ibid-white);
    box-shadow: 0 2px 12px rgba(26, 95, 74, 0.06);
}

body.page-booking-result .booking-result-page__payment-block-head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.35rem 0.75rem;
    padding: 0.55rem 0.85rem;
    background: rgba(26, 95, 74, 0.07);
    border-bottom: 1px solid var(--ibid-border);
}

body.page-booking-result .booking-result-page__payment-block-label {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--ibid-primary);
    letter-spacing: -0.02em;
}

body.page-booking-result .booking-result-page__payment-block-serial {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ibid-text-muted);
    max-width: 100%;
}

body.page-booking-result .booking-result-page__payment-block-body {
    padding: 0.25rem 0.65rem 0.75rem;
    background: var(--ibid-white);
}

body.page-booking-result .booking-result-page__dl--payment-block dt:last-of-type,
body.page-booking-result .booking-result-page__dl--payment-block dd:last-of-type {
    border-bottom: none;
}

body.page-booking-result .booking-result-page__attachments {
    margin-top: 0.45rem;
    padding-top: 0.45rem;
    border-top: 1px solid rgba(26, 95, 74, 0.1);
}

body.page-booking-result .booking-result-page__attachments-label {
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--ibid-text-muted);
    margin: 0 0 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

body.page-booking-result .booking-result-page__attachment-item + .booking-result-page__attachment-item {
    margin-top: 0.25rem;
}

body.page-booking-result .booking-result-page__attachment-row {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    min-width: 0;
    max-width: 100%;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ibid-primary);
    text-decoration: none;
    line-height: 1.2;
}

body.page-booking-result .booking-result-page__attachment-row:hover {
    color: var(--ibid-primary-dark);
    text-decoration: underline;
}

body.page-booking-result .booking-result-page__attachment-row:hover .booking-result-page__attachment-thumb-xs {
    border-color: var(--ibid-primary);
}

body.page-booking-result .booking-result-page__attachment-name {
    flex: 1 1 auto;
    min-width: 0;
}

body.page-booking-result .booking-result-page__attachment-open {
    font-size: 0.65rem;
    opacity: 0.75;
}

body.page-booking-result .booking-result-page__attachment-icon {
    display: flex;
    width: 32px;
    height: 32px;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 0.75rem;
    color: var(--ibid-text-muted);
    background: rgba(26, 95, 74, 0.06);
    border-radius: 6px;
    border: 1px solid var(--ibid-border);
}

body.page-booking-result .booking-result-page__attachment-thumb-xs {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--ibid-border);
    vertical-align: middle;
}

body.page-booking-result .booking-result-page__dl dt {
    font-weight: 500;
    color: var(--ibid-text-muted);
    font-size: 0.875rem;
}

body.page-booking-result .booking-result-page__dl dd {
    font-size: 0.9375rem;
}

body.page-booking-result .booking-result-page__guest {
    margin-bottom: 0.75rem;
}

body.page-booking-result .booking-result-page__guest:last-child {
    margin-bottom: 0;
}

/* Override booking-card green gradient so Bootstrap danger utilities show (style.css loads after Bootstrap). */
body.page-booking-result .booking-result-page__invalid .booking-card__header.bg-danger {
    background: var(--bs-danger) !important;
    color: var(--bs-white) !important;
}

body.page-booking-result .booking-result-page .booking-btn.booking-btn--primary.btn-primary,
body.page-booking-result .booking-result-page .btn-primary.booking-btn--primary {
    --bs-btn-color: var(--ibid-white);
    --bs-btn-bg: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-color: var(--ibid-white);
    --bs-btn-hover-bg: var(--ibid-primary-dark);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
    --bs-btn-active-color: var(--ibid-white);
    --bs-btn-active-bg: var(--ibid-primary-dark);
    --bs-btn-active-border-color: var(--ibid-primary-dark);
    font-weight: 600;
    padding: 0.55rem 1.35rem;
    border-radius: 10px;
    background-color: var(--ibid-primary) !important;
    border-color: var(--ibid-primary) !important;
    color: var(--ibid-white) !important;
}

body.page-check-booking .check-booking-page .booking-btn.booking-btn--primary.btn-primary,
body.page-check-booking .check-booking-page .btn-primary.booking-btn--primary {
    --bs-btn-color: var(--ibid-white);
    --bs-btn-bg: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-color: var(--ibid-white);
    --bs-btn-hover-bg: var(--ibid-primary-dark);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
    --bs-btn-active-color: var(--ibid-white);
    --bs-btn-active-bg: var(--ibid-primary-dark);
    --bs-btn-active-border-color: var(--ibid-primary-dark);
    font-weight: 600;
    padding: 0.55rem 1.35rem;
    border-radius: 10px;
    background-color: var(--ibid-primary) !important;
    border-color: var(--ibid-primary) !important;
    color: var(--ibid-white) !important;
}

body.page-check-booking .check-booking-page .booking-btn.booking-btn--outline.btn-outline-secondary,
body.page-check-booking .check-booking-page .btn-outline-secondary.booking-btn--outline {
    --bs-btn-color: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-bg: rgba(26, 95, 74, 0.08);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
    --bs-btn-hover-color: var(--ibid-primary-dark);
    font-weight: 600;
    border-radius: 10px;
    padding: 0.5rem 1.15rem;
}

/* Payment link — Pay CTA matches Summary card header (secondary / ochre theme) */
body.page-payment-link-booking .booking-result-page .booking-btn.booking-btn--primary.btn-primary,
body.page-payment-link-booking .booking-result-page .btn-primary.booking-btn--primary {
    --bs-btn-color: var(--ibid-white);
    --bs-btn-bg: var(--ibid-secondary);
    --bs-btn-border-color: var(--ibid-secondary-dark);
    --bs-btn-hover-color: var(--ibid-white);
    --bs-btn-hover-bg: var(--ibid-secondary-dark);
    --bs-btn-hover-border-color: var(--ibid-secondary-dark);
    --bs-btn-active-color: var(--ibid-white);
    --bs-btn-active-bg: var(--ibid-secondary-dark);
    --bs-btn-active-border-color: var(--ibid-secondary-dark);
    box-shadow: 0 2px 12px rgba(184, 110, 36, 0.22);
    background: linear-gradient(135deg, var(--ibid-secondary) 0%, var(--ibid-secondary-dark) 100%) !important;
    border-color: var(--ibid-secondary-dark) !important;
    color: var(--ibid-white) !important;
}

body.page-payment-link-booking .booking-result-page .booking-btn.booking-btn--primary.btn-primary:hover:not(:disabled),
body.page-payment-link-booking .booking-result-page .btn-primary.booking-btn--primary:hover:not(:disabled) {
    box-shadow: 0 4px 16px rgba(184, 110, 36, 0.28);
    background: var(--ibid-secondary-dark) !important;
    border-color: var(--ibid-secondary-dark) !important;
    color: var(--ibid-white) !important;
}

body.page-payment-link-booking .booking-result-page .booking-btn.booking-btn--primary.btn-primary:active:not(:disabled),
body.page-payment-link-booking .booking-result-page .btn-primary.booking-btn--primary:active:not(:disabled) {
    background: var(--ibid-secondary-dark) !important;
    border-color: var(--ibid-secondary-dark) !important;
}

/* Booking review (serial in URL + feedback form) */
@media (min-width: 992px) {
    body.page-booking-review .booking-result-page__aside-col {
        position: sticky;
        top: calc(var(--site-header-offset) + 1rem);
        align-self: flex-start;
        z-index: 2;
    }
}

.booking-review-stars {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
}

.booking-review-stars__btn {
    border: none;
    background: transparent;
    padding: 0.2rem;
    line-height: 1;
    border-radius: 0.25rem;
    cursor: pointer;
    transition: transform 0.12s ease;
}

.booking-review-stars__btn:hover {
    transform: scale(1.08);
}

.booking-review-stars__btn:focus-visible {
    outline: 2px solid var(--ibid-primary);
    outline-offset: 2px;
}

.booking-review-stars__icon {
    font-size: 1.35rem;
    line-height: 1;
}

.booking-review-stars__icon--on {
    color: #e6b007;
}

.booking-review-stars__icon--off {
    color: #c5cdd6;
}

.booking-review-bidan-list__item + .booking-review-bidan-list__item {
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px solid var(--ibid-border);
}

.booking-review-bidan-list__avatar img,
.booking-review-bidan-list__placeholder {
    width: 56px;
    height: 56px;
}

.booking-review-bidan-list__placeholder {
    background: rgba(26, 95, 74, 0.08);
    border: 1px solid var(--ibid-border);
}

body.page-booking-review .booking-result-page .booking-btn.booking-btn--primary.btn-primary,
body.page-booking-review .booking-result-page .btn-primary.booking-btn--primary {
    --bs-btn-color: var(--ibid-white);
    --bs-btn-bg: var(--ibid-primary);
    --bs-btn-border-color: var(--ibid-primary);
    --bs-btn-hover-color: var(--ibid-white);
    --bs-btn-hover-bg: var(--ibid-primary-dark);
    --bs-btn-hover-border-color: var(--ibid-primary-dark);
}

body.page-booking-review .booking-result-page__invalid .booking-card__header.bg-danger {
    background: var(--bs-danger) !important;
    color: var(--bs-white) !important;
}

/* Booking review — one grouped summary card */
.booking-review-summary .booking-review-summary__body {
    padding-top: 0.25rem;
}

.booking-review-summary__section {
    padding: 1rem 0;
}

.booking-review-summary__section--last {
    padding-bottom: 0.15rem;
}

.booking-review-summary__label {
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ibid-primary);
    margin: 0 0 0.75rem;
}

.booking-review-summary__divider {
    height: 1px;
    margin: 0;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(26, 95, 74, 0.15) 12%,
        rgba(26, 95, 74, 0.15) 88%,
        transparent 100%
    );
    border: 0;
}

/* Review photo upload (aligned with backend attachment-upload pattern) */
.booking-review-upload__group .input-group-text.booking-review-upload__preview {
    background-color: var(--ibid-surface-alt, #f4f7f6);
    border-color: rgba(26, 95, 74, 0.2);
    padding: 0;
}

.booking-review-upload__btn {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.attachment-upload-loading {
    width: 38px;
    height: 38px;
    min-width: 38px;
    border-right: 1px solid rgba(26, 95, 74, 0.15);
    background-color: var(--ibid-surface-alt, #f4f7f6);
}

.attachment-upload-image {
    width: 38px;
    height: 38px;
    object-fit: cover;
    display: block;
    vertical-align: middle;
}

.attachment-upload-icon-wrapper {
    width: 38px;
    height: 38px;
    min-width: 38px;
    text-decoration: none;
    border-right: 1px solid rgba(26, 95, 74, 0.15);
}
