:root {
    --motion-green: #129447;
    --motion-green-dark: #075b2a;
    --motion-green-soft: #eaf8ef;
    --motion-blue: #2563eb;
    --motion-blue-soft: #edf4ff;
    --motion-shadow: 0 24px 58px rgba(15, 66, 43, .14), 0 8px 20px rgba(37, 99, 235, .08);
    --motion-shadow-hover: 0 34px 78px rgba(15, 66, 43, .2), 0 14px 30px rgba(37, 99, 235, .12);
}

.poster-section,
.poster-banner-section,
.campaign-search-poster-section,
.about-poster-gallery-section {
    background:
        linear-gradient(135deg, rgba(234, 248, 239, .92), rgba(255, 255, 255, .98) 48%, rgba(237, 244, 255, .9));
    border-bottom: 1px solid rgba(18, 148, 71, .14);
    overflow: clip;
    padding: clamp(.85rem, 2vw, 2rem);
    position: relative;
}

.poster-section::before,
.poster-banner-section::before,
.campaign-search-poster-section::before,
.about-poster-gallery-section::before {
    background:
        repeating-linear-gradient(135deg, rgba(18, 148, 71, .045) 0, rgba(18, 148, 71, .045) 1px, transparent 1px, transparent 18px);
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.poster-page-shell,
.poster-gallery-shell {
    margin-inline: auto;
    max-width: 1840px;
    position: relative;
    width: 100%;
    z-index: 1;
}

.poster-page-shell-narrow {
    max-width: 1536px;
}

.poster-card,
.about-poster-card {
    background: rgba(255, 255, 255, .9);
    border: 1px solid rgba(18, 148, 71, .2);
    border-radius: 8px;
    box-shadow: var(--motion-shadow);
    margin: 0;
    overflow: hidden;
    position: relative;
    transform-style: preserve-3d;
}

.poster-card::after,
.about-poster-card::after {
    border: 1px solid rgba(255, 255, 255, .78);
    border-radius: inherit;
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
    transform: translateZ(12px);
}

.poster-image {
    display: block;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.poster-card[data-tilt],
.about-poster-card[data-tilt] {
    transition: box-shadow .38s ease, border-color .38s ease;
}

.poster-card[data-tilt]:hover,
.about-poster-card[data-tilt]:hover {
    border-color: rgba(37, 99, 235, .28);
    box-shadow: var(--motion-shadow-hover);
}

.poster-banner-section {
    padding-block: clamp(.7rem, 1.5vw, 1.5rem);
}

.poster-banner-card {
    margin-inline: auto;
    max-width: 1942px;
}

.home-purpose-poster-section {
    padding-top: clamp(.7rem, 1.6vw, 1.6rem);
}

.home-how-poster-section,
.pan-india-poster-section {
    padding-block: clamp(1.2rem, 3vw, 3rem);
}

.poster-interactive {
    isolation: isolate;
}

.poster-hotspot {
    border: 2px solid transparent;
    border-radius: 6px;
    position: absolute;
    transform: translateZ(24px);
    z-index: 4;
}

.poster-hotspot:hover {
    background: rgba(255, 255, 255, .08);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .14);
}

.poster-hotspot:focus-visible {
    border-color: #fff;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, .8);
    outline: 0;
}

.how-poster-donate {
    height: 6.8%;
    left: 8.6%;
    top: 83.4%;
    width: 38.4%;
}

.how-poster-campaign {
    height: 6.2%;
    left: 49.3%;
    top: 84.9%;
    width: 34.5%;
}

.poster-mobile-actions {
    display: none;
}

.about-poster-gallery-section {
    padding-block: clamp(2rem, 4vw, 4.5rem);
}

.poster-gallery-heading {
    margin: 0 auto 1.5rem;
    max-width: 1800px;
}

.poster-gallery-heading h1 {
    font-size: clamp(2rem, 4vw, 4rem);
    margin-bottom: 0;
}

.about-poster-grid {
    display: grid;
    gap: clamp(1rem, 2vw, 1.75rem);
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.about-poster-card {
    display: grid;
    grid-template-rows: auto minmax(72px, auto);
}

.about-poster-card figcaption {
    align-items: center;
    background: linear-gradient(90deg, rgba(234, 248, 239, .98), rgba(237, 244, 255, .94));
    border-top: 1px solid rgba(18, 148, 71, .18);
    color: #153b29;
    display: flex;
    font-family: var(--font-heading, Georgia, serif);
    font-size: clamp(1.05rem, 1.5vw, 1.35rem);
    font-weight: 800;
    justify-content: center;
    line-height: 1.4;
    padding: 1rem 1.25rem;
    text-align: center;
}

.contact-poster-page .contact-left {
    align-items: center;
    background: linear-gradient(145deg, #effaf3, #ffffff 52%, #edf4ff);
    display: flex;
    justify-content: center;
    padding: clamp(1rem, 2.5vw, 2.5rem);
}

.contact-poster-wrap {
    max-width: 760px;
    width: 100%;
}

.contact-poster-card {
    width: 100%;
}

.campaign-search-poster-card {
    isolation: isolate;
}

.campaign-poster-search {
    background: rgba(255, 255, 255, .96);
    border: 1px solid rgba(18, 148, 71, .17);
    border-radius: 8px;
    box-shadow: 0 22px 44px rgba(4, 40, 25, .2);
    padding: clamp(.8rem, 1.4vw, 1.35rem);
    position: absolute;
    right: 5.5%;
    top: 39%;
    transform: translateZ(28px);
    width: 36%;
    z-index: 5;
}

.campaign-poster-search .form-label {
    color: #193a2a;
    font-weight: 850;
}

.campaign-poster-search .input-group {
    box-shadow: 0 8px 18px rgba(15, 66, 43, .08);
}

.campaign-poster-search .form-control,
.campaign-poster-search .input-group-text {
    min-height: 46px;
}

.poster-login-auth {
    align-items: center;
    background: #edf5ef;
    display: flex;
    isolation: isolate;
    min-height: calc(100vh - 76px);
    overflow: hidden;
    padding: clamp(2rem, 5vw, 5rem) 0;
    position: relative;
}

.poster-login-backdrop {
    inset: 0;
    position: absolute;
    z-index: -2;
}

.poster-login-backdrop::after {
    background: linear-gradient(90deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .2));
    content: "";
    inset: 0;
    position: absolute;
}

.poster-login-image {
    height: 100%;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.poster-login-auth > .container {
    position: relative;
    z-index: 2;
}

.poster-login-panel {
    backdrop-filter: blur(14px);
    background: rgba(255, 255, 255, .96);
    border: 1px solid rgba(255, 255, 255, .86);
    border-radius: 8px;
    box-shadow: 0 28px 72px rgba(4, 40, 25, .22), 0 8px 22px rgba(37, 99, 235, .1);
}

.motion-enabled main .btn,
.motion-enabled main .text-link,
.motion-enabled main .cause-icon-tile {
    transition: box-shadow .24s ease, transform .24s ease, border-color .24s ease, background-color .24s ease;
}

.motion-enabled main .btn:hover,
.motion-enabled main .cause-icon-tile:hover {
    box-shadow: 0 10px 24px rgba(18, 148, 71, .18);
    transform: translateY(-2px) scale(1.01);
}

.motion-enabled main .cause-icon-tile i,
.motion-enabled main .assurance-item > i,
.motion-enabled main .how-step > span,
.motion-enabled main .trust-proof-ribbon i {
    animation: premiumIconFloat 4.8s ease-in-out infinite;
}

@keyframes premiumIconFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
}

@media (max-width: 991.98px) {
    .contact-poster-page {
        grid-template-columns: 1fr;
    }

    .poster-login-image {
        object-fit: contain;
        object-position: center top;
    }

    .poster-login-backdrop {
        background: #edf5ef;
    }
}

@media (max-width: 767.98px) {
    .poster-section,
    .poster-banner-section,
    .campaign-search-poster-section,
    .about-poster-gallery-section {
        padding: .75rem;
    }

    .about-poster-grid {
        grid-template-columns: 1fr;
    }

    .poster-hotspot {
        display: none;
    }

    .poster-mobile-actions {
        display: grid;
        gap: .7rem;
        grid-template-columns: 1fr 1fr;
        margin-top: .85rem;
    }

    .poster-mobile-actions .btn {
        align-items: center;
        display: inline-flex;
        justify-content: center;
        min-height: 46px;
    }

    .campaign-poster-search {
        border-color: rgba(18, 148, 71, .25);
        border-radius: 0 0 8px 8px;
        box-shadow: none;
        position: relative;
        right: auto;
        top: auto;
        transform: none;
        width: 100%;
    }

    .campaign-poster-search .input-group {
        align-items: stretch;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
    }

    .campaign-poster-search .btn {
        grid-column: 1 / -1;
        margin-top: .55rem;
        width: 100%;
    }

    .poster-login-auth {
        min-height: calc(100vh - 66px);
        padding: 2rem .35rem;
    }

    .poster-login-backdrop::after {
        background: rgba(239, 248, 242, .56);
    }
}

@media (max-width: 480px) {
    .poster-mobile-actions {
        grid-template-columns: 1fr;
    }

    .about-poster-card figcaption {
        min-height: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    [data-reveal],
    [data-reveal-stagger] > *,
    [data-parallax],
    [data-tilt] {
        opacity: 1 !important;
        transform: none !important;
    }

    .motion-enabled main .cause-icon-tile i,
    .motion-enabled main .assurance-item > i,
    .motion-enabled main .how-step > span,
    .motion-enabled main .trust-proof-ribbon i {
        animation: none !important;
    }

    .motion-enabled main *,
    .motion-enabled main *::before,
    .motion-enabled main *::after {
        scroll-behavior: auto !important;
        transition-duration: .01ms !important;
    }
}
