/* Camp detail — hero, tabs, two-column body, sidebar (matches system + reference layout) */
:root {
    --cd-red: #c52327;
    --cd-red-soft: #fde8e8;
    --cd-navy: #1b2537;
    --cd-navy-soft: #282a46;
    --cd-muted: #6b7280;
    --cd-border: #e5e7eb;
    --cd-surface: #f8f9fa;
    --cd-radius: 12px;
    --cd-font: 'Inter', sans-serif;
    --cd-serif: Georgia, 'Times New Roman', serif;
}

.camp-detail-page {
    font-family: var(--cd-font);
    background: transparent;
    padding-bottom: 0;
}

/* System UI shell — same max-width as donations / travel packages */
.camp-detail-shell {
    max-width: 1174px !important;
    padding: 36px 15px 64px;
}

.camp-detail-panel {
    background: #fff;
    border-radius: 18px;
    border: 1px solid rgba(40, 42, 70, 0.08);
    box-shadow: 0 14px 40px rgba(40, 42, 70, 0.08);
    overflow: hidden;
}

/* ---- Hero: image on right half, fading in from the left ---- */
.camp-detail-hero {
    position: relative;
    min-height: clamp(280px, 42vh, 480px);
    background: #0f172a;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    overflow: hidden;
    border-radius: 18px 18px 0 0;
}

.camp-detail-hero__bg-layer {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 58%;
    pointer-events: none;
}

.camp-detail-hero__slideshow {
    position: relative;
    width: 100%;
    height: 100%;
    pointer-events: auto;
}

.camp-detail-hero__slide,
.camp-detail-hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
    -webkit-mask-image: linear-gradient(
        90deg,
        transparent 0%,
        rgba(0, 0, 0, 0.15) 10%,
        rgba(0, 0, 0, 0.65) 28%,
        #000 48%,
        #000 100%
    );
    mask-image: linear-gradient(
        90deg,
        transparent 0%,
        rgba(0, 0, 0, 0.15) 10%,
        rgba(0, 0, 0, 0.65) 28%,
        #000 48%,
        #000 100%
    );
    opacity: 0;
    transition: opacity 1.1s ease-in-out;
    z-index: 0;
}

.camp-detail-hero__slide.is-active {
    opacity: 1;
    z-index: 1;
}

.camp-detail-hero__dots {
    position: absolute;
    bottom: 1.15rem;
    right: 1.15rem;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    pointer-events: auto;
}

.camp-detail-hero__dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.45);
    cursor: pointer;
    transition: transform 0.2s ease, background 0.2s ease;
}

.camp-detail-hero__dot.is-active {
    background: #fff;
    transform: scale(1.15);
}

.camp-detail-hero__dot:hover {
    background: rgba(255, 255, 255, 0.85);
}

.camp-detail-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(15, 23, 42, 0.97) 0%,
        rgba(15, 23, 42, 0.88) 38%,
        rgba(15, 23, 42, 0.35) 52%,
        rgba(15, 23, 42, 0.08) 62%,
        transparent 72%
    );
    pointer-events: none;
}

.camp-detail-hero__vignette {
    display: none;
}

.camp-detail-hero__wishlist {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    z-index: 2;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.95);
    color: #9ca3af;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    transition: color 0.2s, transform 0.15s;
}

.camp-detail-hero__wishlist:hover {
    color: var(--cd-red);
    transform: scale(1.05);
}

.camp-detail-hero__inner {
    position: relative;
    z-index: 1;
    max-width: min(540px, 52%);
    padding: clamp(1.5rem, 4vw, 2.75rem) clamp(1.25rem, 3vw, 2rem) calc(2.5rem + 10px);
}

@media (max-width: 767.98px) {
    .camp-detail-hero__bg-layer {
        width: 100%;
    }

    .camp-detail-hero__slide,
    .camp-detail-hero__image {
        background-position: center;
        -webkit-mask-image: linear-gradient(
            90deg,
            transparent 0%,
            rgba(0, 0, 0, 0.35) 18%,
            rgba(0, 0, 0, 0.85) 45%,
            #000 70%
        );
        mask-image: linear-gradient(
            90deg,
            transparent 0%,
            rgba(0, 0, 0, 0.35) 18%,
            rgba(0, 0, 0, 0.85) 45%,
            #000 70%
        );
    }

    .camp-detail-hero__dots {
        bottom: 0.85rem;
        right: 0.85rem;
    }

    .camp-detail-hero__overlay {
        background: linear-gradient(
            90deg,
            rgba(15, 23, 42, 0.96) 0%,
            rgba(15, 23, 42, 0.82) 55%,
            rgba(15, 23, 42, 0.45) 78%,
            rgba(15, 23, 42, 0.2) 100%
        );
    }

    .camp-detail-hero__inner {
        max-width: 100%;
    }
}

.camp-detail-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.85rem;
    background: rgba(13, 159, 110, 0.95);
    color: #fff;
}

.camp-detail-hero__badge--summer {
    background: linear-gradient(135deg, #eab308, #ca8a04);
}
.camp-detail-hero__badge--winter {
    background: linear-gradient(135deg, #0ea5e9, #0369a1);
}
.camp-detail-hero__badge--spring {
    background: linear-gradient(135deg, #34d399, #059669);
}
.camp-detail-hero__badge--fall {
    background: linear-gradient(135deg, #f97316, #ea580c);
}

.camp-detail-hero__badge--default {
    background: linear-gradient(135deg, #64748b, #475569);
}

.camp-detail-hero h1 {
    font-family: var(--cd-serif);
    font-size: clamp(1.65rem, 4vw, 2.5rem);
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 0.65rem;
    color: #fff;
    max-width: 900px;
}

.camp-detail-hero__lead {
    font-size: clamp(0.95rem, 2vw, 1.05rem);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.92);
    max-width: 720px;
    margin: 0 0 1rem;
}

.camp-detail-hero__quickline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.5rem;
    font-size: 0.92rem;
    margin-bottom: 1rem;
    color: rgba(255, 255, 255, 0.95);
}

.camp-detail-hero__quickline span {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.45rem;
}

.camp-detail-hero__quickline i {
    margin-top: 3px;
    opacity: 0.95;
}

/* Org strip — light red so it never blends into dark photos */
.camp-detail-hero__org {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-top: 0;
    padding: 0.65rem 1rem;
    margin-left: -0.75rem;
    margin-right: -0.75rem;
    border-radius: var(--cd-radius);
    background: #fee2e2;
    border: 1px solid rgba(197, 35, 39, 0.15);
    max-width: min(100%, 520px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

@media (min-width: 576px) {
    .camp-detail-hero__org {
        margin-left: 0;
        margin-right: 0;
    }
}

.camp-detail-hero__org-logo {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #fff;
    background: #fff;
    flex-shrink: 0;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.camp-detail-hero__org-name {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--cd-navy);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.camp-detail-hero__org-name .fa-circle-check {
    color: #2563eb;
    font-size: 0.8rem;
}

/* ---- Main + sidebar (single overview, no tabs) ---- */
.camp-detail-body {
    padding: 2rem clamp(1.25rem, 3vw, 2rem) 2.5rem;
}

.camp-detail-body-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.camp-detail-body-grid__columns {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

@media (min-width: 992px) {
    .camp-detail-body-grid__columns {
        flex-direction: row;
        align-items: flex-start;
        gap: 2.5rem;
    }

    .camp-detail-main {
        flex: 1 1 0;
        min-width: 0;
    }

    .camp-detail-sidebar {
        flex: 0 0 min(360px, 34%);
        max-width: min(360px, 34%);
        position: sticky;
        top: 1rem;
    }
}

/* Share + Help + Discover — full panel width, one row */
.camp-detail-bottom-strip {
    width: 100%;
    margin-top: 1.75rem;
    padding-top: 1.75rem;
    border-top: 1px solid var(--cd-border);
}

.camp-detail-bottom-strip__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    width: 100%;
}

@media (min-width: 768px) {
    .camp-detail-bottom-strip__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        align-items: stretch;
    }
}

.camp-detail-bottom-strip__grid .camp-detail-sidecard {
    margin-bottom: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.camp-detail-bottom-strip__grid .camp-detail-sidecard__sub {
    flex: 1;
}

.camp-detail-bottom-promo-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: auto;
    padding-top: 0.5rem;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--cd-red);
    text-decoration: none;
}

.camp-detail-bottom-promo-link:hover {
    color: #9e1c20;
}

.camp-detail-sidecard--promo {
    background: linear-gradient(160deg, #f8fafc 0%, #fff 100%);
}

/* Legacy main-footer (travel packages) */
.camp-detail-main-footer {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    margin-top: 2.5rem;
    padding-top: 2rem;
    border-top: 1px solid var(--cd-border);
}

@media (min-width: 576px) {
    .camp-detail-main-footer {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.camp-detail-main-footer .camp-detail-sidecard {
    margin-bottom: 0;
    height: 100%;
}

/* Full-width strip below columns — map / browse promo */
.camp-detail-fullstrip {
    width: 100%;
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid var(--cd-border);
}

.camp-detail-map-card--fullwidth {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    background: #fff;
    border: 1px solid rgba(27, 37, 55, 0.08);
    border-radius: var(--cd-radius);
    padding: 1.35rem 1.5rem;
    box-shadow: 0 8px 24px rgba(27, 37, 55, 0.06);
}

@media (min-width: 992px) {
    .camp-detail-map-card--fullwidth {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.35fr);
        align-items: stretch;
        gap: 1.5rem;
        padding: 1.5rem 1.75rem;
    }
}

.camp-detail-map-card__head {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.camp-detail-map-card--fullwidth .camp-detail-map-card__embed {
    min-height: 220px;
    height: 100%;
}

.camp-detail-promo-card--fullwidth {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
    background: linear-gradient(135deg, #f0f4f8 0%, #fff 55%, #f8fafc 100%);
    border: 1px solid rgba(27, 37, 55, 0.08);
    border-radius: var(--cd-radius);
    padding: 1.35rem 1.5rem;
    box-shadow: 0 8px 24px rgba(27, 37, 55, 0.06);
}

@media (min-width: 768px) {
    .camp-detail-promo-card--fullwidth {
        flex-direction: row;
        align-items: center;
        gap: 1.25rem;
        padding: 1.5rem 2rem;
    }
}

.camp-detail-promo-card--fullwidth .camp-detail-promo-card__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-width: 0;
}

@media (min-width: 768px) {
    .camp-detail-promo-card--fullwidth .camp-detail-promo-card__body {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
    }
}

.camp-detail-promo-card__text h3 {
    font-family: var(--cd-serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cd-navy);
    margin: 0 0 0.35rem;
}

.camp-detail-promo-card__text p {
    font-size: 0.88rem;
    color: var(--cd-muted);
    margin: 0;
    line-height: 1.45;
}

.camp-detail-promo-card__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    flex-shrink: 0;
    padding: 0.75rem 1.35rem;
    border-radius: 10px;
    background: var(--cd-navy);
    color: #fff !important;
    font-size: 0.88rem;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.2s ease;
}

.camp-detail-promo-card__btn:hover {
    background: #1f2138;
    color: #fff !important;
}

.camp-detail-sidecard--compact {
    margin-bottom: 0;
}

.camp-detail-main .camp-description-content,
.camp-detail-about .camp-description-content {
    font-size: 0.98rem;
    line-height: 1.65;
    color: #374151;
}

.camp-detail-main .camp-description-content p:last-child,
.camp-detail-about .camp-description-content p:last-child {
    margin-bottom: 0;
}

/* Quick info grid */
.camp-detail-quickgrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    margin-top: 1.75rem;
}

@media (min-width: 576px) {
    .camp-detail-quickgrid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 992px) {
    .camp-detail-quickgrid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.camp-detail-quickbox {
    border: 1px solid var(--cd-border);
    border-radius: 10px;
    background: #fff;
    padding: 1rem 0.9rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-height: 100%;
}

.camp-detail-quickbox__label {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--cd-muted);
}

.camp-detail-quickbox__value {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--cd-navy);
    line-height: 1.35;
}

.camp-detail-quickbox__value--accent {
    color: var(--cd-red);
}

.camp-detail-quickbox i {
    color: var(--cd-muted);
    font-size: 1.1rem;
    margin-bottom: 0.2rem;
}

.camp-detail-services-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.65rem 0;
    border-bottom: 1px solid var(--cd-border);
    font-size: 0.95rem;
    color: #374151;
}

.camp-detail-services-list li:last-child {
    border-bottom: none;
}

@media (min-width: 768px) {
    .camp-detail-services-list--grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        column-gap: 1.5rem;
    }

    .camp-detail-services-list--grid li {
        border-bottom: 1px solid var(--cd-border);
    }
}

/* Services — full panel width, single equal row */
.camp-detail-services--fullwidth {
    width: 100%;
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid var(--cd-border);
}

.camp-detail-services-list--row {
    display: grid;
    width: 100%;
    gap: 0.65rem;
    grid-template-columns: repeat(var(--service-count, 1), minmax(0, 1fr));
}

.camp-detail-services-list--row li {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.8rem 0.75rem;
    margin: 0;
    border: 1px solid var(--cd-border);
    border-radius: 10px;
    background: #fafbfc;
    font-size: 0.88rem;
    font-weight: 600;
    color: #374151;
    text-align: center;
    min-width: 0;
}

.camp-detail-services-list--row .camp-detail-services-list__label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

.camp-detail-services-list--row li:last-child {
    border-bottom: 1px solid var(--cd-border);
}

.camp-detail-services-list--row .camp-detail-services-list__icon {
    flex-shrink: 0;
    margin-top: 0;
}

@media (max-width: 767.98px) {
    .camp-detail-services-list--row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 479.98px) {
    .camp-detail-services-list--row {
        grid-template-columns: 1fr;
    }

    .camp-detail-services-list--row li {
        justify-content: flex-start;
        text-align: left;
    }
}

.camp-detail-inclusions-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 2.5rem;
}

@media (min-width: 992px) {
    .camp-detail-inclusions-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.5rem 2rem;
    }

    .camp-detail-inclusions-grid .camp-detail-services,
    .camp-detail-inclusions-grid .tp-detail-inclusions {
        margin-top: 0;
    }
}

.camp-detail-map-card,
.camp-detail-promo-card:not(.camp-detail-promo-card--fullwidth) {
    background: #fff;
    border: 1px solid rgba(27, 37, 55, 0.08);
    border-radius: var(--cd-radius);
    padding: 1.25rem;
    box-shadow: 0 8px 24px rgba(27, 37, 55, 0.06);
}

.camp-detail-map-card__title {
    font-family: var(--cd-serif);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--cd-navy);
    margin: 0 0 0.65rem;
}

.camp-detail-map-card__address {
    font-size: 0.88rem;
    color: #374151;
    margin-bottom: 0.85rem;
    line-height: 1.45;
}

.camp-detail-map-card__address i {
    color: var(--cd-red);
    margin-right: 0.35rem;
}

.camp-detail-map-card__embed {
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--cd-border);
    aspect-ratio: 16 / 9;
    background: #eef1f6;
}

.camp-detail-map-card__embed iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

.camp-detail-map-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.75rem;
    font-size: 0.86rem;
    font-weight: 600;
    color: var(--cd-navy);
    text-decoration: none;
}

.camp-detail-map-card__link:hover {
    color: var(--cd-red);
}

.camp-detail-promo-card:not(.camp-detail-promo-card--fullwidth) {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: linear-gradient(135deg, #f8fafc 0%, #fff 100%);
}

.camp-detail-promo-card:not(.camp-detail-promo-card--fullwidth) .camp-detail-promo-card__body h3 {
    font-family: var(--cd-serif);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--cd-navy);
    margin: 0 0 0.35rem;
}

.camp-detail-promo-card:not(.camp-detail-promo-card--fullwidth) .camp-detail-promo-card__body p {
    font-size: 0.86rem;
    color: var(--cd-muted);
    margin: 0 0 0.65rem;
    line-height: 1.45;
}

.camp-detail-promo-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.86rem;
    font-weight: 700;
    color: var(--cd-red);
    text-decoration: none;
}

.camp-detail-promo-card__link:hover {
    color: #9e1c20;
}

.camp-detail-promo-card__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: var(--cd-navy);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.camp-detail-section-title {
    font-family: var(--cd-serif);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--cd-navy);
    margin: 0 0 1rem;
}

.camp-detail-services-list__icon {
    color: var(--cd-red);
    width: 1.5rem;
    flex-shrink: 0;
    text-align: center;
    margin-top: 2px;
}

.camp-detail-schedule-list strong {
    font-size: 0.7rem;
}

.camp-detail-schedule,
.camp-detail-services {
    margin-top: 2.5rem;
}

/* Highlights */
.camp-detail-highlights {
    margin-top: 2.5rem;
}

.camp-detail-highlights__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 0.75rem;
}

@media (min-width: 576px) {
    .camp-detail-highlights__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 992px) {
    .camp-detail-highlights__grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

.camp-detail-hl-item {
    text-align: center;
}

.camp-detail-hl-item__icon {
    width: 56px;
    height: 56px;
    margin: 0 auto 0.45rem;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--cd-border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cd-red);
    font-size: 1.15rem;
    box-shadow: 0 4px 12px rgba(27, 37, 55, 0.06);
}

.camp-detail-hl-item__label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--cd-navy);
    line-height: 1.25;
}

/* Gallery */
.camp-detail-gallery-block {
    margin-top: 2.5rem;
}

.camp-detail-gallery {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

@media (min-width: 768px) {
    .camp-detail-gallery {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.camp-detail-gallery a {
    display: block;
    border-radius: 10px;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: #e5e7eb;
}

.camp-detail-gallery img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.camp-detail-gallery a:hover img {
    transform: scale(1.04);
}

.camp-detail-gallery-more {
    margin-top: 1rem;
}

.camp-detail-btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 1.1rem;
    border-radius: 8px;
    border: 1px solid var(--cd-border);
    background: #fff;
    color: var(--cd-navy);
    font-weight: 600;
    font-size: 0.88rem;
    text-decoration: none;
    transition: border-color 0.2s, background 0.2s;
}

.camp-detail-btn-outline:hover {
    border-color: var(--cd-navy);
    color: var(--cd-navy);
}

button.camp-detail-btn-outline {
    cursor: pointer;
    font: inherit;
}

/* Placeholder tab panels */
.camp-detail-placeholder {
    padding: 1.5rem 1.1rem;
    border: 1px dashed var(--cd-border);
    border-radius: var(--cd-radius);
    background: #fff;
    color: var(--cd-muted);
    font-size: 0.95rem;
    line-height: 1.6;
}

/* Sidebar cards */
.camp-detail-sidecard {
    background: #fff;
    border: 1px solid rgba(27, 37, 55, 0.08);
    border-radius: var(--cd-radius);
    padding: 1.35rem 1.25rem;
    margin-bottom: 1.25rem;
    box-shadow: 0 8px 24px rgba(27, 37, 55, 0.06);
}

.camp-detail-sidebar .camp-detail-sidecard:last-child {
    margin-bottom: 0;
}

.camp-detail-sidecard h3 {
    font-family: var(--cd-serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cd-navy);
    margin: 0 0 0.35rem;
}

.camp-detail-sidecard__sub {
    font-size: 0.86rem;
    color: var(--cd-muted);
    margin-bottom: 1.1rem;
    line-height: 1.45;
}

.camp-detail-btn-primary-lg {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.85rem 1rem;
    border-radius: 10px;
    border: none;
    background: var(--cd-red);
    color: #fff !important;
    font-weight: 700;
    font-size: 0.95rem;
    text-decoration: none;
    margin-bottom: 0.65rem;
    transition: background 0.2s, transform 0.15s;
}

.camp-detail-btn-primary-lg:hover {
    background: #9e1c20;
    color: #fff !important;
}

.camp-detail-btn-ghost-lg {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: 10px;
    border: 1px solid var(--cd-navy);
    background: #fff;
    color: var(--cd-navy) !important;
    font-weight: 600;
    font-size: 0.88rem;
    text-decoration: none;
}

.camp-detail-btn-ghost-lg:hover {
    background: #f9fafb;
    color: var(--cd-navy) !important;
}

.camp-detail-infolist {
    list-style: none;
    padding: 0;
    margin: 0;
}

.camp-detail-infolist li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.55rem 0;
    border-bottom: 1px solid var(--cd-border);
    font-size: 0.88rem;
    color: #374151;
}

.camp-detail-infolist li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.camp-detail-infolist i {
    color: var(--cd-muted);
    margin-top: 3px;
    width: 1.1rem;
    text-align: center;
}

.camp-detail-infolist strong {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--cd-muted);
    font-weight: 700;
    margin-bottom: 0.15rem;
}

.camp-detail-share {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.camp-detail-share a,
.camp-detail-share button {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--cd-border);
    background: #fff;
    color: var(--cd-navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 0.95rem;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

.camp-detail-share a:hover,
.camp-detail-share button:hover {
    border-color: var(--cd-navy);
    background: #f9fafb;
}

.camp-detail-share .camp-detail-share-copy.is-done {
    border-color: #059669;
    color: #059669;
}

.camp-detail-help-contact {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.camp-detail-help-contact a {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    color: var(--cd-navy);
    text-decoration: none;
    font-weight: 600;
}

.camp-detail-help-contact a:hover {
    color: var(--cd-red);
}

/* Bottom donate strip */
.camp-detail-cta-strip {
    background: var(--cd-red-soft);
    border: 1px solid rgba(197, 35, 39, 0.12);
    border-radius: 18px;
    padding: 1.5rem clamp(1.25rem, 3vw, 2rem);
    margin-top: 1.75rem;
}

.camp-detail-cta-strip__inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}

@media (min-width: 768px) {
    .camp-detail-cta-strip__inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
    }
}

.camp-detail-cta-strip__text {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    max-width: 640px;
}

.camp-detail-cta-strip__text i {
    font-size: 1.5rem;
    color: var(--cd-red);
    margin-top: 2px;
}

.camp-detail-cta-strip__text p {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--cd-navy);
    line-height: 1.5;
}

.camp-detail-cta-strip .camp-detail-btn-primary-lg {
    width: auto;
    margin: 0;
    padding: 0.75rem 1.5rem;
    white-space: nowrap;
}

/* Sidebar column spacing on mobile */
@media (max-width: 991.98px) {
    .camp-detail-sidebar {
        margin-top: 0.5rem;
    }
}
