.container,
.nav-container {
    margin: 0 auto;
    max-width: 1200px
}

.btn,
.footer-section h4 {
    text-transform: uppercase
}

.dropdown-menu,
.footer-section ul,
.nav-menu {
    list-style: none
}

#lead-popup-box,
body {
    background-color: #fff
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    transition: color .3s, background-color .3s, transform .3s
}

body {
    font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    line-height: 1.6;
    color: #333
}

.container {
    padding: 0 20px
}

.header {
    background: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .1);
    position: sticky;
    top: 0;
    z-index: 1000;
    transition: transform .5s ease-in-out
}

.footer-section a,
.nav-link {
    transition: color .3s;
    text-decoration: none
}

body.pre-scroll .header {
    transform: translateY(-100%)
}

.navbar {
    padding: 1rem 0
}

.nav-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px
}

.logo {
    height: 40px;
    width: auto
}

.nav-menu {
    display: flex;
    gap: 2rem;
    margin: 0
}

.nav-link {
    color: #333;
    font-weight: 500
}

.nav-item:hover .nav-link,
.nav-link:hover {
    color: #cf2f35
}

.nav-buttons,
.social-media {
    display: flex;
    gap: 1rem;
    align-items: center
}

.btn {
    padding: .6rem 1.2rem;
    border: none;
    border-radius: 20px;
    text-decoration: none;
    font-weight: 600;
    font-size: .8rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: .5rem
}

.btn-outline,
.btn-primary,
.btn-secondary {
    background: 0 0;
    color: #cf2f35;
    border: 2px solid #cf2f35
}

.btn-donate,
.btn-outline:hover,
.btn-primary:hover,
.btn-report:hover,
.btn-secondary:hover,
.share-button:hover {
    background: #cf2f35;
    color: #fff
}

.btn-donate {
    width: 100%;
    justify-content: center;
    padding: 1rem;
    font-size: 1rem;
    margin-top: 1.5rem
}

.btn-report {
    background: 0 0;
    color: #cf2f35;
    border: 2px solid #fff;
    font-size: .875rem;
    padding: .5rem 1rem;
    transition: .3s
}

.btn-report:hover {
    border: 2px solid #fff
}

#main-content-wrapper {
    transition: padding-top .8s ease-in-out
}

body.pre-scroll #main-content-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100vh;
    padding-top: 0;
    overflow: hidden
}

body.pre-scroll .campaign-header {
    margin-bottom: 0;
    transform: translateY(-50%)
}

.mobile-only,
body.pre-scroll .content-grid,
body.scrolled .scroll-indicator {
    display: none
}

.scroll-indicator {
    position: absolute;
    bottom: 5vh;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    color: #aaa;
    opacity: 0;
    transition: opacity .5s ease-in-out;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    font-size: .8rem
}

body.pre-scroll .scroll-indicator {
    opacity: 1;
    animation: 2s infinite bounce
}

@keyframes bounce {
    0%,
    100%,
    20%,
    50%,
    80% {
        transform: translateX(-50%) translateY(0)
    }
    40% {
        transform: translateX(-50%) translateY(-15px)
    }
    60% {
        transform: translateX(-50%) translateY(-7px)
    }
}

body.scrolled #main-content-wrapper {
    padding-top: 2rem
}

body.scrolled .content-grid {
    display: grid;
    animation: 1s ease-in-out forwards fadeIn
}

@keyframes fadeIn {
    from {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

.main-content {
    padding: 0;
    min-height: calc(100vh - 200px)
}

.campaign-header {
    text-align: center;
    margin-bottom: 3rem;
    transition: transform .8s ease-in-out, margin-bottom .8s ease-in-out
}

.campaign-title {
    font-size: 1.6rem;
    font-weight: 700;
    color: #2d3748;
    margin-bottom: 1rem;
    line-height: 1.2
}

.campaign-author {
    color: #718096;
    font-size: .625rem
}

.content-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 3rem;
    align-items: start
}

.story-column {
    background: #fff
}

.campaign-images {
    margin-bottom: 2rem
}

.featured-image {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: 12px;
    margin-bottom: 1rem
}

.gallery-image,
.highlight,
.quote {
    border-radius: 8px
}

.image-gallery {
    display: flex;
    gap: .5rem;
    overflow-x: auto
}

.gallery-image {
    width: 80px;
    height: 80px;
    object-fit: cover;
    cursor: pointer
}

.gallery-image:hover {
    transform: scale(1.05)
}

.story-description {
    text-align: left;
    margin-top: 2rem
}

.story-description h2 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
    color: #2d3748
}

.story-content {
    font-size: .95rem;
    line-height: 1.8;
    color: #4a5568
}

.story-content p {
    margin-bottom: 1.5rem
}

.highlight {
    background: #fef5e7;
    padding: 1rem;
    border-left: 4px solid #f6ad55;
    font-weight: 600;
    color: #c05621
}

.quote,
.signature {
    font-style: italic;
    color: #cf2f35
}

.quote {
    font-size: 1.125rem;
    text-align: center;
    padding: 1rem;
    background: #fed7d7;
    margin: 2rem 0
}

.story-content h3 {
    color: #2d3748;
    font-size: .95rem;
    font-weight: 700;
    margin: 2rem 0 1rem
}

.story-content ul {
    margin-left: 1.5rem;
    margin-bottom: 1.5rem
}

.footer-section li,
.story-content li {
    margin-bottom: .5rem
}

.signature {
    text-align: right;
    font-weight: 500;
    margin-top: 2rem
}

.updates-section {
    margin: 3rem 0;
    padding: 2rem;
    background: #f7fafc;
    border-radius: 12px
}

.updates-title {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.5rem;
    color: #2d3748;
    margin-bottom: 2rem
}

.updates-title i {
    color: #4299e1;
    font-size: 2rem
}

.update-item {
    background: #fff;
    padding: 1.5rem;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, .1)
}

.update-date {
    color: #718096;
    font-size: .875rem;
    margin-bottom: .5rem
}

.update-title {
    font-size: 1.25rem;
    color: #2d3748;
    margin-bottom: 1rem
}

.update-content {
    color: #4a5568;
    line-height: 1.6
}

.report-section {
    margin-top: 2rem;
    text-align: left
}

.footer {
    background: #cf2f35;
    color: #fff;
    padding: 3rem 0 1rem;
    margin-top: 4rem
}

.footer-container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px
}

.footer-section h4 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1rem;
    letter-spacing: .5px
}

.footer-section a {
    color: #fed7d7
}

.amount-option label,
.btn,
.dropdown-link,
.dropdown-menu,
.gallery-image,
.social-link {
    transition: .3s
}

.footer-bottom {
    border-top: 1px solid #e53e3e;
    margin-top: 2rem;
    padding-top: 1rem;
    text-align: center
}

.language-selector {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    color: #fed7d7
}

.donation-widget {
    animation: .6s ease-out slideInUp
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateY(30px)
    }
    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.amount-option input[type=radio]:focus+label,
.btn:focus,
.dropdown-link:focus,
.nav-link:focus,
.social-link:focus {
    outline: #4299e1 solid 2px;
    outline-offset: 2px
}

@media print {
    .floating-donate,
    .footer,
    .header {
        display: none
    }
    .main-content {
        padding: 0
    }
    .content-grid {
        grid-template-columns: 1fr
    }
}

.dropdown {
    position: relative
}

.dropdown-toggle {
    display: flex;
    align-items: center;
    gap: .5rem
}

.dropdown-toggle i {
    font-size: .75rem;
    transition: transform .3s
}

.dropdown:hover .dropdown-toggle i {
    transform: rotate(180deg)
}

.dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    background: #fff;
    min-width: 200px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, .15);
    border-radius: 8px;
    padding: .5rem 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    z-index: 1000
}

.dropdown:hover .dropdown-menu,
body.scrolled .floating-donate-link {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.dropdown-menu li {
    margin: 0
}

.dropdown-link {
    display: block;
    padding: .75rem 1.5rem;
    color: #4a5568;
    text-decoration: none;
    font-weight: 500
}

.dropdown-link:hover {
    background: #f7fafc;
    color: #cf2f35
}

.mobile-menu-toggle {
    display: none;
    background: 0 0;
    border: none;
    font-size: 1.5rem;
    color: #cf2f35;
    cursor: pointer;
    padding: .5rem
}

.social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    background: #fff;
    color: #cf2f35;
    border-radius: 4px;
    text-decoration: none;
    font-size: 1rem;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .05)
}

.social-link:hover {
    background: #fed7d7;
    color: #cf2f35;
    transform: translateY(-2px)
}

.footer-copyright {
    text-align: center;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, .1);
    color: #fed7d7;
    font-size: .875rem
}

.support-share-section {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 11rem;
    margin-top: 2rem
}

@media (max-width:768px) {
    .nav-container {
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: relative;
        flex-wrap: wrap
    }
    .nav-logo {
        order: 1
    }
    .mobile-menu-toggle {
        display: block;
        order: 2
    }
    .nav-menu {
        display: none;
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
        text-align: left;
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background: #fff;
        box-shadow: 0 4px 20px rgba(0, 0, 0, .15);
        padding: 1rem;
        z-index: 999;
        order: 3
    }
    .nav-menu.mobile-open {
        display: flex
    }
    .donation-column.desktop-only,
    .dropdown:not(.active) .dropdown-menu,
    .nav-buttons {
        display: none
    }
    .campaign-title {
        font-size: 1.65rem
    }
    .content-grid {
        grid-template-columns: 1fr;
        gap: 2rem
    }
    .support-share-section {
        gap: 2rem;
        justify-content: center
    }
    .donation-column.mobile-only {
        display: block
    }
    .footer-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem
    }
    .dropdown-menu {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        background: #f7fafc;
        margin-top: .5rem;
        border-radius: 4px;
        width: 100%
    }
    .dropdown.active .dropdown-menu {
        display: flex;
        flex-direction: column
    }
}

#lead-popup-overlay,
.floating-donate-link {
    opacity: 0;
    visibility: hidden;
    position: fixed
}

@media (max-width:480px) {
    .container {
        padding: 0 15px
    }
    .campaign-title {
        font-size: 1.4rem
    }
    .footer-container {
        grid-template-columns: 1fr
    }
}

.footer-section a:hover {
    color: #fff;
    padding-left: .5rem
}

.company-icon {
    height: 80px;
    width: auto;
    display: inline-block
}

.footer-bottom-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 1rem
}

.footer-column {
    text-align: center
}

.social-media {
    justify-content: center
}

.footer-column.left-column p {
    font-size: .75rem
}

@media (min-width:769px) {
    .footer-bottom-content {
        flex-direction: row;
        justify-content: space-between
    }
    .footer-column.left-column {
        text-align: left
    }
    .footer-column.right-column {
        text-align: right
    }
    .social-media {
        justify-content: flex-end
    }
}

.donating-to-banner {
    text-align: center;
    font-size: .7rem;
    font-weight: 500;
    color: #cf2f35;
    margin-bottom: 1rem;
    position: relative;
    display: inline-block;
    padding-bottom: 6px
}

.donating-to-banner::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0;
    width: 150%;
    height: 2px;
    background-color: #cf2f35;
    border-radius: 1px
}

.expandable-text {
    overflow: hidden;
    transition: max-height .6s ease-in-out;
    max-height: 1500px
}

.expandable-text.collapsed {
    max-height: 200px
}

.read-more-toggle {
    background: 0 0;
    border: none;
    color: #cf2f35;
    font-weight: 600;
    cursor: pointer;
    margin-top: 1rem;
    font-size: .95rem;
    text-decoration: underline;
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: fit-content
}

.read-more-toggle:hover {
    color: #a82429
}

.story-content {
    text-align: justify
}

.support-box {
    border: none;
    padding: 1rem 2rem;
    text-align: center;
    border-radius: 4px
}

.support-count {
    font-size: 1.8rem;
    color: #cf2f35;
    font-weight: 700;
    margin: 0
}

.support-label {
    font-size: .95rem;
    color: #333;
    margin-top: .2rem
}

.share-button {
    border: 1.5px solid #cf2f35;
    background: 0 0;
    color: #cf2f35;
    padding: .6rem 1.2rem;
    font-weight: 600;
    font-size: .95rem;
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: .5rem;
    transition: background .3s, color .3s
}

.share-icon {
    font-size: 1rem
}

.section-divider {
    border: none;
    border-top: 1px solid #555;
    margin: 1.5rem auto;
    width: 100%;
    max-width: 800px
}

.comment-section,
.donation-info-bar,
.donation-info-subtext,
.donation-ranking {
    max-width: 750px;
    font-family: Arial, sans-serif
}

.donation-info-bar {
    margin: 20px auto 0;
    background-color: #fef3f3;
    color: #b00020;
    font-size: 10px;
    text-align: center;
    padding: 14px 20px;
    border: 1px solid #f5c2c7;
    border-radius: 8px 8px 0 0;
    box-shadow: 0 -1px 4px rgba(0, 0, 0, .05);
    line-height: 1.6
}

.donation-info-subtext {
    margin: 0 auto 20px;
    padding: 10px 20px;
    border-left: 1px solid #f5c2c7;
    border-right: 1px solid #f5c2c7;
    font-size: 9px;
    color: #777;
    text-align: center;
    line-height: 1.5;
    display: flex;
    justify-content: center
}

.donation-info-subtext a {
    color: #1e90ff;
    text-decoration: underline;
    font-weight: 700;
    transition: color .3s
}

.donation-info-subtext a:hover {
    color: #004080
}

.donation-ranking {
    width: 100%;
    margin: 0 auto 40px;
    border-collapse: collapse;
    border-radius: 0 0 12px 12px;
    overflow: hidden;
    box-shadow: 0 0 10px rgba(0, 0, 0, .15)
}

.donation-ranking th {
    background-color: #e63946;
    color: #fff;
    padding: 12px;
    text-align: left;
    font-size: 11px
}

.donation-ranking td {
    padding: 12px;
    border-bottom: 1px solid #eee;
    font-size: 9px;
    vertical-align: middle
}

.donation-ranking tr:first-child td {
    background-color: #ffeaa7;
    font-weight: 700
}

.donation-ranking tr:nth-child(2) td {
    background-color: #dfe6e9;
    font-weight: 700
}

.donation-ranking tr:nth-child(3) td {
    background-color: #fdcb6e;
    font-weight: 700
}

.donation-ranking tr:hover td {
    background-color: #f1f1f1
}

.donation-rank {
    font-weight: 700;
    width: 40px
}

.donation-amount {
    color: #2d3436;
    font-weight: 700
}

.donor-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    margin-right: 10px;
    object-fit: cover;
    vertical-align: middle
}

.donor-name {
    display: flex;
    align-items: center;
    gap: 10px
}

.comment-section {
    margin: 40px auto;
    font-size: 14px;
    color: #333
}

.comment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    margin-bottom: 12px
}

.comment,
.comment-input,
.comment-meta {
    margin-bottom: 20px;
    display: flex
}

.comment-input {
    align-items: center;
    border: 1px solid #ccc;
    padding: 8px;
    border-radius: 6px;
    background: #f9f9f9
}

.comment-input input {
    border: none;
    outline: 0;
    flex-grow: 1;
    font-size: 14px;
    background: 0 0;
    padding-left: 10px;
    color: #999
}

.comment-meta {
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    border-bottom: 1px solid #ddd;
    padding-bottom: 6px
}

.comment-filters select,
.comment-filters span {
    margin-left: 10px;
    cursor: pointer
}

.comment-filters .active {
    color: #e63946;
    border-bottom: 2px solid #e63946
}

.comment.reply {
    margin-top: 12px;
    margin-left: 50px;
    background: #f6f6f6;
    padding: 10px;
    border-radius: 6px
}

.comment-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    margin-right: 12px
}

.comment-body,
.main-column {
    flex: 1
}

.comment-author {
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 4px
}

.comment-author span {
    font-weight: 400;
    color: #888;
    margin-left: 6px;
    font-size: 12px
}

.comment-text {
    font-size: 14px;
    margin-bottom: 8px
}

.comment-actions {
    font-size: 12px;
    color: #777
}

.comment-actions span,
.upvote-button {
    color: #2e7d32;
    cursor: pointer
}

.upvote-button {
    background: 0 0;
    border: none;
    font-weight: 700;
    font-size: 13px;
    padding: 0;
    margin-right: 6px;
    transition: color .3s
}

.upvote-button:hover {
    color: #1b5e20
}

.upvote-button:disabled {
    cursor: default;
    color: #aaa
}

.reply-link {
    color: #aaa !important;
    cursor: pointer;
    transition: color .2s
}

.reply-link:hover {
    color: #888 !important
}

.update-image {
    border-radius: 8px
}

.image-carousel {
    position: relative;
    max-width: 280px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center
}

.carousel-image-container {
    width: 100%;
    height: 250px;
    overflow: hidden;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .15)
}

#carousel-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px
}

.carousel-button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, .4);
    border: none;
    color: #fff;
    font-size: 1.8rem;
    cursor: pointer;
    padding: .4rem .8rem;
    border-radius: 50%;
    z-index: 10
}

.donorbox-facade,
.notification {
    background-color: #fef3f3;
    text-align: center
}

.carousel-button.left {
    left: -20px
}

.carousel-button.right {
    right: -20px
}

.carousel-button:hover {
    background-color: rgba(0, 0, 0, .6)
}

.layout-container {
    display: flex;
    gap: 2rem;
    align-items: flex-start
}

.desktop-only {
    display: block
}

.lazy-load-section {
    min-height: 450px
}

.lazy-load-section:not(:empty) {
    min-height: auto
}

#notification-container {
    position: fixed;
    bottom: 80px;
    left: 50%;
    transform: translateX(-50%);
    width: 240px;
    z-index: 1000
}

.notification {
    color: #b00020;
    padding: 12px;
    margin-top: 8px;
    border-radius: 8px;
    border: 1px solid #f5c2c7;
    box-shadow: 0 4px 8px rgba(0, 0, 0, .1);
    font-family: Arial, sans-serif;
    font-size: 12px;
    animation: 5s forwards fadeInOut
}

@keyframes fadeInOut {
    0% {
        opacity: 0;
        transform: translateY(20px)
    }
    10% {
        opacity: 1;
        transform: translateY(0)
    }
    90% {
        opacity: 1
    }
    100% {
        opacity: 0;
        transform: translateY(-20px)
    }
}

.donorbox-facade {
    border: 2px dashed #d02f35;
    border-radius: 12px;
    padding: 2rem;
    cursor: pointer;
    transition: background-color .3s, transform .3s;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    min-height: 400px;
    height: 100%
}

#popup-form button,
.btn-donate-facade {
    color: #fff;
    cursor: pointer;
    transition: background-color .3s
}

.donorbox-facade:hover {
    background-color: #fed7d7;
    transform: translateY(-5px)
}

.facade-content h3 {
    font-size: 1.6rem;
    font-weight: 700;
    color: #d02f35;
    margin-bottom: 1rem
}

.facade-content p {
    font-size: 1rem;
    color: #333;
    margin-bottom: 1.5rem
}

.btn-donate-facade {
    background: #d02f35;
    padding: 1rem 2.5rem;
    border-radius: 50px;
    border: none;
    font-size: 1.2rem;
    font-weight: 700
}

#popup-form button:hover,
.btn-donate-facade:hover {
    background-color: #a82429
}

.update-image {
    display: block;
    width: auto;
    max-width: 100%;
    height: auto;
    margin: 1.5rem auto 0
}

#lead-popup-overlay {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .7);
    z-index: 2000;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity .4s
}

#popup-form,
.deadline-text {
    flex-direction: column;
    display: flex
}

#lead-popup-overlay.popup-visible {
    opacity: 1;
    visibility: visible
}

#lead-popup-box {
    padding: 25px 20px;
    border-radius: 10px;
    max-width: 380px;
    width: 90%;
    text-align: center;
    position: relative;
    box-shadow: 0 5px 25px rgba(0, 0, 0, .2);
    transform: scale(.9);
    transition: transform .4s
}

#lead-popup-overlay.popup-visible #lead-popup-box {
    transform: scale(1)
}

#close-popup-btn {
    position: absolute;
    top: 5px;
    right: 10px;
    background: 0 0;
    border: none;
    font-size: 2rem;
    color: #b0b0b0;
    cursor: pointer;
    line-height: 1;
    padding: 0
}

.popup-content h3 {
    font-size: 1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 10px
}

.popup-content p {
    font-size: .75rem;
    line-height: 1.5;
    color: #555;
    margin-bottom: 15px
}

#popup-form {
    gap: 10px
}

#popup-email-input {
    padding: 11px;
    border: 1px solid #ccc;
    border-radius: 6px;
    font-size: .9rem
}

.checkbox-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 4px 0 8px
}

.checkbox-wrapper label {
    font-size: .7rem;
    color: #666;
    cursor: pointer
}

#case-updates-subscribe,
#newsletter-subscribe {
    transform: scale(1);
    cursor: pointer;
    margin: 0
}

#popup-form button {
    background-color: #cf2f35;
    border: none;
    padding: 10px 35px;
    border-radius: 6px;
    font-size: .9rem;
    font-weight: 600;
    align-self: center;
    width: fit-content
}

.donation-progress {
    margin: 2.5rem 0;
    padding: 20px;
    background-color: #f7fafc;
    border-radius: 12px;
    border: 1px solid #e2e8f0
}

.progress-labels {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    font-size: .9rem;
    color: #4a5568
}

.progress-labels .raised strong {
    color: #cf2f35;
    font-size: 1.1rem
}

.progress-bar-background {
    width: 100%;
    height: 20px;
    background-color: #e2e8f0;
    border-radius: 20px;
    overflow: hidden
}

#progress-bar-fill {
    height: 100%;
    width: 0%;
    background-color: #cf2f35;
    border-radius: 20px;
    transition: width 1.5s ease-in-out
}

.progress-percentage {
    text-align: center;
    margin-top: 8px;
    font-size: .9rem;
    font-weight: 600;
    color: #cf2f35
}

.compact-trust-section {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 20px;
    padding: 30px 15px;
    margin: 40px auto;
    max-width: 900px;
    border-top: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0
}

.compact-trust-box {
    flex: 1;
    min-width: 150px;
    max-width: 280px;
    background: #f8f9fa;
    border: 1px solid #cf2f35;
    border-radius: 12px;
    padding: 20px 15px;
    text-align: center;
    box-shadow: 0 4px 15px rgba(0, 0, 0, .05);
    transition: transform .3s, box-shadow .3s
}

.compact-trust-box:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, .1)
}

.compact-trust-icon {
    font-size: 1.6rem;
    color: #cf2f35;
    margin-bottom: 12px
}

.compact-trust-box p {
    font-size: .7rem;
    line-height: 1.4;
    color: #666;
    margin: 0
}

@media (max-width:768px) {
    .layout-container {
        flex-direction: column
    }
    .desktop-only {
        display: none !important
    }
    .mobile-only {
        display: block;
        margin-top: 2rem
    }
    .compact-trust-section {
        flex-direction: column;
        align-items: center;
        gap: 20px
    }
    .compact-trust-box {
        width: 100%;
        max-width: 380px
    }
}

.campaign-deadline {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 20px;
    padding: 10px;
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    max-width: 300px;
    margin-left: auto;
    margin-right: auto
}

.deadline-icon i {
    font-size: 1.5rem;
    color: #555
}

.deadline-text {
    align-items: flex-start;
    line-height: 1.3
}

.deadline-main {
    font-size: .9rem;
    font-weight: 600;
    color: #333
}

.deadline-specific {
    font-size: .75rem;
    color: #666
}

.floating-donate-link {
    right: 20px;
    bottom: 20px;
    z-index: 1050;
    background-color: #fff;
    padding: 8px 15px;
    border-radius: 50px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .25);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    transform: translateY(20px);
    transition: opacity .4s, transform .4s, box-shadow .3s
}

.floating-donate-link:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .3)
}

.floating-donate-text {
    color: #cf2f35;
    font-size: .9rem;
    font-weight: 700;
    line-height: 1
}

.floating-donate-link i {
    color: #cf2f35;
    font-size: 1.2rem;
    line-height: 1;
    margin-top: 4px
}

html {
    scroll-behavior: smooth
}