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

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Inter', sans-serif;
    background:#fff;
    color:#1d1d1f;
    line-height:1.6;
    font-size:15px;
}

a{
    text-decoration:none;
    color:inherit;
}

img{
    max-width:100%;
    display:block;
}

.container{
    width:min(1120px, 92%);
    margin:auto;
}

.site-header{
    position:sticky;
    top:0;
    z-index:1000;
    background:rgba(255,255,255,0.96);
    backdrop-filter:blur(10px);
    border-bottom:1px solid #ececec;
}

.nav-wrap{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    padding:14px 0;
}

.logo{
    display:flex;
    align-items:center;
    gap:10px;
    font-size:20px;
    font-weight:800;
}

.logo img{
    width:32px;
    height:32px;
    object-fit:contain;
}

.main-nav{
    display:flex;
    align-items:center;
    gap:14px;
}

.main-nav a{
    font-size:14px;
    font-weight:600;
}

.main-nav a.active{
    color:#02A95C;
}

.menu-toggle{
    display:none;
    border:none;
    background:none;
    font-size:24px;
    cursor:pointer;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:11px 18px;
    border-radius:999px;
    font-weight:700;
    border:1px solid transparent;
    transition:.25s ease;
}

.btn-primary{
    background:#02A95C;
    color:#fff !important;
}

.btn-primary:hover{
    background:#02844A;
}

.btn-light{
    background:#fff;
    border:1px solid #e7e7e7;
}

.btn-light:hover{
    background:#f7f7f7;
}

.home-minimal{
    padding:56px 0 24px;
}

.home-copy{
    max-width:760px;
}

.home-copy h1{
    font-size:58px;
    line-height:1.02;
    letter-spacing:-1.8px;
    margin-bottom:14px;
}

.home-copy p{
    font-size:18px;
    color:#6b7280;
    max-width:680px;
    margin-bottom:20px;
}

.home-actions{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin-bottom:18px;
}

.search-bar{
    display:flex;
    align-items:center;
    border:1px solid #e7e7e7;
    border-radius:999px;
    overflow:hidden;
    max-width:620px;
    background:#fff;
    margin-bottom:16px;
}

.search-bar input{
    flex:1;
    border:none;
    outline:none;
    padding:16px 18px;
    font-size:15px;
    background:transparent;
}

.search-bar button{
    border:none;
    background:#111;
    color:#fff;
    padding:16px 22px;
    font-weight:700;
    cursor:pointer;
}

.trust-line{
    display:flex;
    gap:18px;
    flex-wrap:wrap;
    color:#6b7280;
    font-size:14px;
    font-weight:600;
}

.trust-line span{
    position:relative;
}

.section{
    padding:36px 0;
}

.section-tight{
    padding-top:8px;
}

.section-head{
    display:flex;
    justify-content:space-between;
    align-items:end;
    gap:18px;
    margin-bottom:18px;
}

.section-title{
    font-size:30px;
    line-height:1.1;
    letter-spacing:-0.8px;
}

.section-subtitle{
    color:#6b7280;
    margin-top:6px;
}

.link-arrow{
    color:#02A95C;
    font-weight:700;
    white-space:nowrap;
}

.mini-stats{
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:14px;
}

.mini-stat{
    border:1px solid #ececec;
    border-radius:18px;
    padding:16px 18px;
    background:#fafafa;
}

.mini-stat strong{
    display:block;
    font-size:24px;
    line-height:1.1;
    margin-bottom:6px;
}

.mini-stat span{
    color:#6b7280;
    font-size:14px;
}

.grid{
    display:grid;
    gap:20px;
}

.grid-3{
    grid-template-columns:repeat(3, 1fr);
}

.card{
    background:#fff;
    border:1px solid #ececec;
    border-radius:22px;
    overflow:hidden;
    transition:.25s ease;
}

.card:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 24px rgba(0,0,0,0.04);
}

.card-pad{
    padding:22px;
}



.campaign-content{
    padding:18px;
}

.campaign-meta{
    font-size:13px;
    color:#02A95C;
    font-weight:700;
    margin-bottom:8px;
}

.campaign-content h3{
    font-size:19px;
    line-height:1.3;
    margin-bottom:8px;
}

.campaign-content p{
    color:#6b7280;
    font-size:14px;
}

.progress{
    width:100%;
    height:8px;
    background:#ededee;
    border-radius:999px;
    overflow:hidden;
    margin:16px 0 12px;
}

.progress-bar{
    height:100%;
    background:#02A95C;
}

.campaign-amounts{
    display:flex;
    justify-content:space-between;
    gap:12px;
    margin-bottom:14px;
    font-size:14px;
}

.campaign-amounts strong{
    display:block;
    color:#1d1d1f;
}

.campaign-amounts span{
    color:#6b7280;
}

.card-link{
    display:inline-block;
    font-weight:700;
    color:#02A95C;
}

.category-pills{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
}

.category-pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:12px 16px;
    border-radius:999px;
    border:1px solid #e7e7e7;
    background:#fff;
    font-weight:600;
    transition:.2s ease;
}

.category-pill:hover{
    border-color:#02A95C;
    color:#02A95C;
}

.simple-trust-box{
    border:1px solid #ececec;
    border-radius:26px;
    padding:28px;
    background:#fafafa;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
}

.simple-trust-box h2{
    font-size:28px;
    line-height:1.1;
    margin-bottom:8px;
}

.simple-trust-box p{
    color:#6b7280;
}

.simple-testimonial{
    padding:20px;
}

.simple-testimonial h3{
    font-size:17px;
    margin-bottom:4px;
}

.simple-testimonial small{
    display:block;
    color:#6b7280;
    margin-bottom:10px;
}

.simple-testimonial p{
    color:#1d1d1f;
}

.site-footer{
    margin-top:48px;
    border-top:1px solid #ececec;
    background:#fff;
}

.footer-grid{
    display:grid;
    grid-template-columns:2fr 1fr 1fr 1fr;
    gap:24px;
    padding:38px 0 24px;
}

.footer-grid h3,
.footer-grid h4{
    margin-bottom:12px;
}

.footer-grid p,
.footer-grid a{
    color:#6b7280;
    font-size:14px;
}

.footer-grid ul{
    list-style:none;
}

.footer-grid li{
    margin-bottom:10px;
}

.footer-bottom{
    border-top:1px solid #ececec;
    padding:16px 0;
    text-align:center;
    color:#6b7280;
    font-size:14px;
}

@media (max-width: 992px){
    .grid-3,
    .mini-stats,
    .footer-grid{
        grid-template-columns:1fr 1fr;
    }

    .home-copy h1{
        font-size:46px;
    }
}

@media (max-width: 768px){
    .menu-toggle{
        display:block;
    }

    .main-nav{
        display:none;
        position:absolute;
        top:66px;
        left:0;
        width:100%;
        padding:18px;
        background:#fff;
        border-top:1px solid #ececec;
        flex-direction:column;
        align-items:flex-start;
    }

    .main-nav.show{
        display:flex;
    }

    .grid-3,
    .mini-stats,
    .footer-grid{
        grid-template-columns:1fr;
    }

    .section-head,
    .simple-trust-box{
        flex-direction:column;
        align-items:flex-start;
    }

    .home-copy h1{
        font-size:38px;
    }

    .home-copy p{
        font-size:16px;
    }

    .search-bar{
        border-radius:18px;
        flex-direction:column;
        align-items:stretch;
        overflow:hidden;
    }

    .search-bar button{
        width:100%;
    }

    .section-title{
        font-size:26px;
    }
}

.listing-hero{
    margin-bottom:20px;
}

.filter-bar{
    margin-bottom:24px;
}

.filter-grid{
    display:grid;
    grid-template-columns:2fr 1fr 1fr auto;
    gap:12px;
    background:#fafafa;
    border:1px solid #ececec;
    border-radius:22px;
    padding:14px;
}

.filter-grid input,
.filter-grid select{
    width:100%;
    border:1px solid #e7e7e7;
    background:#fff;
    border-radius:14px;
    padding:14px 16px;
    font-size:14px;
    outline:none;
}

.filter-grid button{
    border:none;
    background:#111;
    color:#fff;
    padding:14px 20px;
    border-radius:14px;
    font-weight:700;
    cursor:pointer;
}

.pagination-wrap{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:26px;
}

.page-link{
    min-width:42px;
    height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border:1px solid #e7e7e7;
    border-radius:12px;
    background:#fff;
    font-weight:700;
}

.page-link.active,
.page-link:hover{
    background:#02A95C;
    border-color:#02A95C;
    color:#fff;
}

.campaign-layout{
    display:grid;
    grid-template-columns:minmax(0, 2fr) 360px;
    gap:28px;
    align-items:start;
}

.campaign-single-top{
    margin-bottom:18px;
}

.single-title{
    font-size:42px;
    line-height:1.05;
    letter-spacing:-1.2px;
    margin:8px 0 10px;
}

.single-subtitle{
    color:#6b7280;
    font-size:17px;
    max-width:760px;
}

.single-image-wrap{
    border-radius:26px;
    overflow:hidden;
    border:1px solid #ececec;
    margin-bottom:20px;
}

.single-image-wrap img{
    width:100%;
    height:460px;
    object-fit:cover;
}

.single-gallery{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:12px;
    margin-bottom:24px;
}

.single-gallery img{
    width:100%;
    height:150px;
    object-fit:cover;
    border-radius:18px;
    border:1px solid #ececec;
}

.single-section{
    margin-bottom:28px;
}

.single-section h2{
    font-size:26px;
    margin-bottom:12px;
    letter-spacing:-0.5px;
}

.single-richtext{
    background:#fff;
    border:1px solid #ececec;
    border-radius:22px;
    padding:22px;
    color:#1d1d1f;
}

.update-list{
    display:grid;
    gap:14px;
}

.update-item{
    border:1px solid #ececec;
    border-radius:20px;
    padding:18px;
    background:#fafafa;
}

.update-item h3{
    font-size:18px;
    margin-bottom:4px;
}

.update-item small{
    display:block;
    color:#6b7280;
    margin-bottom:10px;
}

.update-item p{
    color:#1d1d1f;
}

.donation-card{
    border:1px solid #ececec;
    border-radius:24px;
    padding:22px;
    background:#fff;
    margin-bottom:18px;
    position:sticky;
    top:88px;
}

.donation-card h3{
    font-size:30px;
    line-height:1.1;
    margin-bottom:6px;
}

.muted-text{
    color:#6b7280;
}

.donation-stats{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
    margin:16px 0 18px;
}

.donation-stats div{
    background:#fafafa;
    border:1px solid #ececec;
    border-radius:16px;
    padding:14px;
}

.donation-stats strong{
    display:block;
    font-size:18px;
    margin-bottom:4px;
}

.donation-stats span{
    color:#6b7280;
    font-size:13px;
}

.donate-btn{
    width:100%;
    margin-bottom:18px;
}

.campaign-side-meta{
    display:grid;
    gap:10px;
    font-size:14px;
}

.donor-list{
    display:grid;
    gap:12px;
    margin-top:14px;
}

.donor-item{
    display:flex;
    align-items:start;
    justify-content:space-between;
    gap:12px;
    padding-bottom:12px;
    border-bottom:1px solid #f0f0f0;
}

.donor-item:last-child{
    border-bottom:none;
    padding-bottom:0;
}

.donor-item span{
    display:block;
    color:#6b7280;
    font-size:13px;
    margin-top:3px;
}

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

    .campaign-layout{
        grid-template-columns:1fr;
    }

    .donation-card{
        position:static;
    }

    .single-title{
        font-size:34px;
    }

    .single-gallery{
        grid-template-columns:1fr 1fr;
    }
}

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

    .single-title{
        font-size:30px;
    }

    .single-image-wrap img{
        height:260px;
    }

    .single-gallery{
        grid-template-columns:1fr;
    }

    .donation-stats{
        grid-template-columns:1fr;
    }
}
.auth-wrap{
    display:flex;
    justify-content:center;
}

.wide-wrap{
    justify-content:flex-start;
}

.auth-card{
    width:100%;
    max-width:760px;
    border:1px solid #ececec;
    border-radius:26px;
    background:#fff;
    padding:28px;
}

.auth-form{
    display:grid;
    gap:16px;
    margin-top:18px;
}

.auth-form label{
    display:block;
    font-size:14px;
    font-weight:700;
    margin-bottom:8px;
}

.auth-form input,
.auth-form select,
.auth-form textarea{
    width:100%;
    border:1px solid #e7e7e7;
    border-radius:16px;
    padding:14px 16px;
    background:#fff;
    font:inherit;
    outline:none;
}

.auth-form textarea{
    resize:vertical;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.full-btn{
    width:100%;
}

.auth-switch{
    margin-top:16px;
    color:#6b7280;
}

.auth-switch a{
    color:#02A95C;
    font-weight:700;
}

.alert{
    border-radius:18px;
    padding:14px 16px;
    margin-top:18px;
    margin-bottom:4px;
}

.alert p{
    margin:4px 0;
}

.alert-danger{
    background:#fff3f2;
    border:1px solid #f3c7c2;
    color:#a13228;
}

.alert-success{
    background:#edfdf3;
    border:1px solid #b7ebc6;
    color:#167a45;
}

.dashboard-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
    margin-bottom:20px;
}

.dashboard-table-wrap{
    width:100%;
    overflow:auto;
    border:1px solid #ececec;
    border-radius:22px;
    background:#fff;
}

.dashboard-table{
    width:100%;
    border-collapse:collapse;
    min-width:760px;
}

.dashboard-table th,
.dashboard-table td{
    padding:16px;
    text-align:left;
    border-bottom:1px solid #f0f0f0;
    font-size:14px;
}

.dashboard-table th{
    background:#fafafa;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.4px;
    color:#6b7280;
}

.status-pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:7px 12px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
}

.status-active{
    background:#edfdf3;
    color:#167a45;
}

.status-pending{
    background:#fff7ed;
    color:#b45309;
}

.status-draft{
    background:#f3f4f6;
    color:#4b5563;
}

.status-paused{
    background:#fef3c7;
    color:#92400e;
}

.status-completed{
    background:#eef2ff;
    color:#4338ca;
}

.status-rejected{
    background:#fff3f2;
    color:#a13228;
}

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

    .auth-card{
        padding:22px;
    }

    .dashboard-head{
        flex-direction:column;
        align-items:flex-start;
    }
}
.captcha-wrap{
    margin-top:4px;
}

.captcha-wrap > div{
    transform-origin:left top;
}
.password-wrap{
    position:relative;
}

.password-wrap input{
    padding-right:52px;
}

.toggle-password{
    position:absolute;
    right:12px;
    top:50%;
    transform:translateY(-50%);
    border:none;
    background:transparent;
    cursor:pointer;
    font-size:18px;
    line-height:1;
    color:#6b7280;
    padding:4px;
}

.auth-wrap{
    display:flex;
    justify-content:center;
    align-items:flex-start;
    width:100%;
}

.wide-wrap{
    display:flex;
    justify-content:center;
    align-items:flex-start;
    width:100%;
}

.auth-card{
    width:100%;
    max-width:760px;
    margin:0 auto;
    border:1px solid #ececec;
    border-radius:26px;
    background:#fff;
    padding:28px;
}

.section{
    padding:36px 0;
}

.container{
    width:min(1120px, 92%);
    margin:0 auto;
}

.dashboard-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
    margin-bottom:20px;
}

.card-pad{
    padding:22px;
}

.grid{
    display:grid;
    gap:20px;
}

.grid-3{
    grid-template-columns:repeat(3, 1fr);
}

.auth-form{
    display:grid;
    gap:16px;
    margin-top:18px;
}

.auth-form label{
    display:block;
    font-size:14px;
    font-weight:700;
    margin-bottom:8px;
}

.auth-form input,
.auth-form select,
.auth-form textarea{
    width:100%;
    border:1px solid #e7e7e7;
    border-radius:16px;
    padding:14px 16px;
    background:#fff;
    font:inherit;
    outline:none;
}

.auth-form textarea{
    resize:vertical;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.full-btn{
    width:100%;
}

.password-wrap{
    position:relative;
}

.password-wrap input{
    padding-right:52px;
}

.toggle-password{
    position:absolute;
    right:12px;
    top:50%;
    transform:translateY(-50%);
    border:none;
    background:transparent;
    cursor:pointer;
    font-size:18px;
    line-height:1;
    color:#6b7280;
    padding:4px;
}

.alert{
    border-radius:18px;
    padding:14px 16px;
    margin-top:18px;
    margin-bottom:4px;
}

.alert p{
    margin:4px 0;
}

.alert-danger{
    background:#fff3f2;
    border:1px solid #f3c7c2;
    color:#a13228;
}

.alert-success{
    background:#edfdf3;
    border:1px solid #b7ebc6;
    color:#167a45;
}

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

    .auth-card{
        max-width:100%;
        padding:22px;
    }

    .dashboard-head{
        flex-direction:column;
        align-items:flex-start;
    }

    .grid-3{
        grid-template-columns:1fr;
    }
}
.auth-wrap{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:flex-start;
}

.wide-wrap{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:flex-start;
}

.auth-card{
    width:100%;
    max-width:760px;
    margin:0 auto;
    border:1px solid #ececec;
    border-radius:26px;
    background:#fff;
    padding:28px;
}

.auth-card.narrow{
    max-width:640px;
}

.auth-form{
    display:grid;
    gap:16px;
    margin-top:18px;
}

.auth-form label{
    display:block;
    font-size:14px;
    font-weight:700;
    margin-bottom:8px;
}

.auth-form input,
.auth-form select,
.auth-form textarea{
    width:100%;
    border:1px solid #e7e7e7;
    border-radius:16px;
    padding:14px 16px;
    background:#fff;
    font:inherit;
    outline:none;
}

.auth-form textarea{
    resize:vertical;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.full-btn{
    width:100%;
}

.password-wrap{
    position:relative;
}

.password-wrap input{
    padding-right:52px;
}

.toggle-password{
    position:absolute;
    right:12px;
    top:50%;
    transform:translateY(-50%);
    border:none;
    background:transparent;
    cursor:pointer;
    font-size:18px;
    line-height:1;
    color:#6b7280;
    padding:4px;
}

.alert{
    border-radius:18px;
    padding:14px 16px;
    margin-top:18px;
    margin-bottom:4px;
}

.alert p{
    margin:4px 0;
}

.alert-danger{
    background:#fff3f2;
    border:1px solid #f3c7c2;
    color:#a13228;
}

.alert-success{
    background:#edfdf3;
    border:1px solid #b7ebc6;
    color:#167a45;
}

.upload-card{
    border:1px solid #ececec;
    border-radius:20px;
    padding:16px;
    background:#fafafa;
}

.upload-card h4{
    font-size:15px;
    margin-bottom:6px;
}

.upload-card p{
    color:#6b7280;
    font-size:13px;
    margin-bottom:12px;
}

.capture-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.dashboard-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
    margin-bottom:20px;
}

.dashboard-actions{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
    margin-top:22px;
}

.card-pad{
    padding:22px;
}

.status-note{
    font-size:14px;
    color:#6b7280;
    margin-top:8px;
}

@media (max-width: 768px){
    .form-grid,
    .capture-grid,
    .dashboard-actions{
        grid-template-columns:1fr;
    }

    .auth-card{
        max-width:100%;
        padding:22px;
    }

    .dashboard-head{
        flex-direction:column;
        align-items:flex-start;
    }
}
.file-capture{
    position:relative;
    border:1px dashed #d8d8dc;
    border-radius:22px;
    background:#fafafa;
    padding:18px;
    transition:.2s ease;
}

.file-capture:hover{
    border-color:#bfc3c9;
    background:#f7f7f8;
}

.file-capture input[type="file"]{
    position:absolute;
    inset:0;
    opacity:0;
    cursor:pointer;
    width:100%;
    height:100%;
    z-index:3;
}

.file-capture-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:14px;
    margin-bottom:14px;
}

.file-capture-text h4{
    font-size:15px;
    margin-bottom:6px;
}

.file-capture-text p{
    font-size:13px;
    color:#6b7280;
}

.file-capture-badge{
    padding:8px 12px;
    border-radius:999px;
    background:#fff;
    border:1px solid #e7e7e7;
    font-size:12px;
    font-weight:700;
    color:#111;
    white-space:nowrap;
}

.preview-box{
    width:100%;
    min-height:220px;
    border-radius:18px;
    background:#fff;
    border:1px solid #ececec;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    position:relative;
}

.preview-box.empty{
    background:linear-gradient(180deg,#ffffff,#f7f7f8);
}

.preview-placeholder{
    text-align:center;
    padding:24px;
    color:#6b7280;
}

.preview-placeholder .icon{
    font-size:34px;
    margin-bottom:10px;
    display:block;
}

.preview-box img{
    width:100%;
    height:240px;
    object-fit:cover;
    display:block;
}

.preview-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:12px;
}

.preview-btn{
    border:none;
    border-radius:999px;
    padding:10px 14px;
    font-size:13px;
    font-weight:700;
    cursor:pointer;
    background:#111;
    color:#fff;
}

.preview-btn.light{
    background:#fff;
    color:#111;
    border:1px solid #e7e7e7;
}

.file-name-note{
    font-size:12px;
    color:#6b7280;
    margin-top:8px;
    word-break:break-word;
}


.identity-with-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
}

.verified-badge{
    width:20px;
    height:20px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    position:relative;
    flex:0 0 20px;
}

.verified-badge svg{
    width:20px;
    height:20px;
    display:block;
}

.verified-badge .check{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-size:11px;
    font-weight:900;
    line-height:1;
    transform:translateY(-0.2px);
}

.identity-with-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
}

.verified-badge{
    width:20px;
    height:20px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    position:relative;
    flex:0 0 20px;
    vertical-align:middle;
}

.verified-badge svg{
    width:20px;
    height:20px;
    display:block;
}

.verified-badge .check{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-size:11px;
    font-weight:900;
    line-height:1;
    transform:translateY(-0.2px);
}

.campaign-owner-line{
    display:flex;
    align-items:center;
    gap:6px;
    flex-wrap:wrap;
    margin-top:10px;
    color:#6b7280;
    font-size:14px;
}

.donor-name-line{
    display:inline-flex;
    align-items:center;
    gap:6px;
    flex-wrap:wrap;
}
.campaign-owner-line a:hover{
    text-decoration:underline;
}
input[readonly],
input[disabled],
select[disabled],
textarea[disabled],
button[disabled]{
    background:#f5f5f6 !important;
    color:#7a7f87 !important;
    cursor:not-allowed !important;
    opacity:.8;
}

.disabled-note{
    color:#b45309;
    font-size:13px;
    margin-top:8px;
}

.report-box{
    margin-top:28px;
    border-top:1px solid #ececec;
    padding-top:24px;
}

.report-box h3{
    margin-bottom:8px;
}

.report-box p{
    color:#6b7280;
    margin-bottom:14px;
}
.reaction-bar{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:14px;
}

.reaction-btn{
    display:inline-flex;
    align-items:center;
    gap:8px;
    border:1px solid #e7e7e7;
    background:#fff;
    border-radius:999px;
    padding:10px 14px;
    cursor:pointer;
    font:inherit;
    transition:.2s ease;
}

.reaction-btn:hover{
    background:#f8f8f8;
    border-color:#d7d7db;
}

.reaction-btn.active{
    border-color:#02A95C;
    background:#edfdf3;
}

.reaction-btn .emoji{
    font-size:16px;
    line-height:1;
}

.reaction-btn .label{
    font-size:14px;
    font-weight:600;
}

.reaction-btn .count{
    font-size:13px;
    color:#6b7280;
}

.reaction-bar{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:14px;
}

.reaction-btn{
    display:flex;
    align-items:center;
    gap:10px;
    border:1px solid #e7e7e7;
    background:#fff;
    border-radius:999px;
    padding:8px 14px;
    cursor:pointer;
    transition:.2s;
}

.reaction-btn:hover{
    background:#fafafa;
}

.reaction-btn.active{
    border-color:#02A95C;
    background:#edfdf3;
}

.sticker img{
    width:32px;
    height:32px;
    object-fit:contain;
}

.reaction-btn .label{
    font-weight:600;
    font-size:14px;
}

.reaction-btn .count{
    font-size:13px;
    color:#6b7280;
}

.sticker img{
    width:32px;
    height:32px;
    transition:transform .2s ease;
}

.reaction-btn:hover .sticker img{
    transform:scale(1.15);
}

.reaction-wrap{
    position:relative;
    display:inline-block;
    overflow:visible;
    z-index:20;
}

.reaction-summary-btn{
    display:inline-flex;
    align-items:center;
    gap:12px;
    border:1px solid #e7e7e7;
    background:#fff;
    border-radius:999px;
    padding:10px 16px;
    cursor:pointer;
    font:inherit;
    transition:.2s ease;
}

.reaction-summary-btn:hover{
    background:#fafafa;
    border-color:#d9d9de;
}

.reaction-summary-icons{
    display:flex;
    align-items:center;
    margin-right:2px;
}

.reaction-summary-icon{
    width:24px;
    height:24px;
    border-radius:50%;
    overflow:hidden;
    border:2px solid #fff;
    background:#fff;
    margin-left:-6px;
    box-shadow:0 1px 4px rgba(0,0,0,.08);
}

.reaction-summary-icon:first-child{
    margin-left:0;
}

.reaction-summary-icon img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.reaction-summary-empty{
    width:24px;
    height:24px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#f3f4f6;
    color:#6b7280;
    font-weight:700;
}

.reaction-summary-text{
    font-size:14px;
    font-weight:600;
    color:#1d1d1f;
}

.reaction-picker{
    position:absolute;
    left:0;
    bottom:calc(100% + 12px);
    background:#fff;
    border:1px solid #ececec;
    border-radius:999px;
    padding:10px 12px;
    box-shadow:0 18px 40px rgba(0,0,0,.12);
    opacity:0;
    visibility:hidden;
    transform:translateY(10px) scale(.96);
    transition:.18s ease;
    z-index:1000;
    pointer-events:none;
    min-width:max-content;
    white-space:nowrap;
}

.reaction-wrap.open .reaction-picker{
    opacity:1;
    visibility:visible;
    transform:translateY(0) scale(1);
    pointer-events:auto;
}

.reaction-picker-form{
    display:flex;
    align-items:flex-end;
    gap:10px;
}

.reaction-picker-item{
    border:none;
    background:transparent;
    padding:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:6px;
    cursor:pointer;
    transition:.18s ease;
}

.reaction-picker-item img{
    width:42px;
    height:42px;
    object-fit:contain;
    transition:transform .18s ease;
}

.reaction-picker-item span{
    font-size:11px;
    font-weight:600;
    color:#4b5563;
    opacity:0;
    transform:translateY(4px);
    transition:.18s ease;
    white-space:nowrap;
}

.reaction-picker-item:hover img,
.reaction-picker-item.active img{
    transform:translateY(-8px) scale(1.18);
}

.reaction-picker-item:hover span,
.reaction-picker-item.active span{
    opacity:1;
    transform:translateY(0);
}

@media (max-width: 768px){
    .reaction-picker{
        max-width:calc(100vw - 40px);
        overflow-x:auto;
        border-radius:28px;
    }

    .reaction-picker-form{
        gap:12px;
    }

    .reaction-picker-item img{
        width:38px;
        height:38px;
    }
}


.campaign-slider-main{
    position:relative;
    border-radius:28px;
    overflow:hidden;
    border:1px solid #ececec;
    background:#fff;
}

.campaign-slider-track-wrap{
    overflow:hidden;
    width:100%;
}

.campaign-slider-track{
    display:flex;
    transition:transform .35s ease;
    will-change:transform;
}



.campaign-slide{
    min-width:100%;
    flex:0 0 100%;
    position:relative;
    height:480px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    background:#f8f8f8;
}

.campaign-slide-bg{
    position:absolute;
    inset:0;
    background-size:cover;
    background-position:center;
   filter:blur(24px) brightness(.82) saturate(1.05);
    transform:scale(1.08);
    opacity:.9;
}

.campaign-slide img{
    position:relative;
    z-index:2;
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
    object-fit:contain;
    display:block;
}

.slider-nav{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:44px;
    height:44px;
    border:none;
    border-radius:50%;
    background:rgba(255,255,255,0.92);
    box-shadow:0 6px 18px rgba(0,0,0,.12);
    font-size:28px;
    line-height:1;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    z-index:3;
}

.slider-nav.prev{
    left:14px;
}

.slider-nav.next{
    right:14px;
}

.campaign-thumbs{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:14px;
}

.campaign-thumb{
    border:none;
    padding:0;
    width:78px;
    height:78px;
    border-radius:18px;
    overflow:hidden;
    cursor:pointer;
    background:#fff;
    border:2px solid transparent;
    transition:.2s ease;
}

.campaign-thumb.active{
    border-color:#02A95C;
}

.campaign-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.story-reaction-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:12px;
    flex-wrap:wrap;
}

.story-reaction-head h2{
    margin-bottom:0;
}

.reaction-wrap{
    position:relative;
    display:inline-block;
    overflow:visible;
    z-index:20;
}

.reaction-summary-btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    border:none;
    background:transparent;
    border-radius:999px;
    padding:0;
    cursor:pointer;
    font:inherit;
    transition:.2s ease;
}

.reaction-summary-icons{
    display:flex;
    align-items:center;
}

.reaction-summary-icon{
    width:28px;
    height:28px;
    border-radius:50%;
    overflow:hidden;
    margin-left:-8px;
}

.reaction-summary-icon:first-child{
    margin-left:0;
}

.reaction-summary-icon img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
}

.reaction-summary-empty{
    width:28px;
    height:28px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#f3f4f6;
    color:#6b7280;
    font-weight:700;
}

.reaction-summary-text{
    font-size:14px;
    font-weight:700;
    color:#1d1d1f;
}

.reaction-picker{
    position:absolute;
    right:0;
    bottom:calc(100% + 14px);
    background:#fff;
    border:none;
    border-radius:999px;
    padding:10px 12px;
    box-shadow:0 18px 40px rgba(0,0,0,.14);
    opacity:0;
    visibility:hidden;
    transform:translateY(10px) scale(.96);
    transition:.18s ease;
    z-index:1000;
    pointer-events:none;
    min-width:max-content;
    white-space:nowrap;
}

.reaction-wrap.open .reaction-picker{
    opacity:1;
    visibility:visible;
    transform:translateY(0) scale(1);
    pointer-events:auto;
}

.reaction-picker-form{
    display:flex;
    align-items:flex-end;
    gap:12px;
}

.reaction-picker-item{
    border:none;
    background:transparent;
    padding:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:6px;
    cursor:pointer;
    transition:.18s ease;
}

.reaction-picker-item img{
    width:48px;
    height:48px;
    object-fit:contain;
    transition:transform .18s ease;
}

.reaction-picker-item span{
    font-size:11px;
    font-weight:700;
    color:#4b5563;
    opacity:0;
    transform:translateY(4px);
    transition:.18s ease;
    white-space:nowrap;
}

.reaction-picker-item:hover img,
.reaction-picker-item.active img{
    transform:translateY(-9px) scale(1.22);
}

.reaction-picker-item:hover span,
.reaction-picker-item.active span{
    opacity:1;
    transform:translateY(0);
}

@media (max-width: 768px){
    .campaign-slide{
        height:300px;
    }

    .campaign-thumb{
        width:64px;
        height:64px;
        border-radius:14px;
    }

    .reaction-picker{
        right:auto;
        left:0;
        max-width:calc(100vw - 40px);
        overflow-x:auto;
        border-radius:28px;
    }

    .reaction-picker-item img{
        width:42px;
        height:42px;
    }
}
.slider-counter{
    position:absolute;
    right:16px;
    bottom:16px;
    background:rgba(0,0,0,.7);
    color:#fff;
    padding:6px 12px;
    border-radius:20px;
    font-size:13px;
    font-weight:600;
}

.slider-dots{
    display:flex;
    gap:8px;
}

.slider-dot{
    width:10px;
    height:10px;
    border-radius:50%;
    border:none;
    background:#d1d5db;
}

.slider-dot.active{
    background:#02A95C;
}

.campaign-slider-meta{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-top:10px;
}

.campaign-card-simple img{
    width:100%;
    height:220px;
    object-fit:cover;
    display:block;
    background:#f3f4f6;
}

.card-actions-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-top:14px;
}

.card-reaction-link{
    display:inline-flex;
    align-items:center;
    gap:8px;
    text-decoration:none;
    color:#1d1d1f;
    font-size:13px;
    font-weight:700;
    flex-shrink:0;
}

.card-reaction-text{
    color:#4b5563;
    font-size:13px;
    font-weight:700;
}

.reaction-summary-icons.small{
    display:flex;
    align-items:center;
}

.reaction-summary-icon.small{
    width:20px;
    height:20px;
    border-radius:50%;
    overflow:hidden;
    margin-left:-6px;
    border:2px solid #fff;
    background:#fff;
    box-shadow:0 1px 4px rgba(0,0,0,.08);
}

.reaction-summary-icon.small:first-child{
    margin-left:0;
}

.reaction-summary-icon.small img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
}

.reaction-summary-empty.small{
    width:20px;
    height:20px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#f3f4f6;
    color:#6b7280;
    font-size:12px;
    font-weight:700;
}
.donor-item{
display:flex;
justify-content:space-between;
align-items:center;
gap:12px;
padding:12px 0;
border-bottom:1px solid #eee;
}

.donor-name-line{
font-weight:700;
display:block;
}

.donor-item span{
font-size:12px;
color:#6b7280;
}
.donation-ticker{

position:fixed;
bottom:30px;
left:30px;
background:#fff;
padding:14px 18px;
border-radius:14px;
box-shadow:0 10px 30px rgba(0,0,0,.12);
font-size:14px;
font-weight:600;
display:none;
z-index:9999;
animation:fadeSlide 0.4s ease;

}

@keyframes fadeSlide{

from{
opacity:0;
transform:translateY(10px);
}

to{
opacity:1;
transform:translateY(0);
}

}
/* CAMPAIGN PAGE */
.campaign-layout{
    display:grid;
    grid-template-columns:minmax(0, 1.5fr) minmax(320px, .9fr);
    gap:28px;
    align-items:start;
}

.campaign-main,
.campaign-sidebar{
    min-width:0;
}

.campaign-single-top{
    margin-bottom:18px;
}

.single-title{
    font-size:40px;
    line-height:1.1;
    margin:8px 0 10px;
    letter-spacing:-0.02em;
}

.single-subtitle{
    font-size:17px;
    line-height:1.6;
    color:#6b7280;
    margin:0;
}

.single-section{
    margin-top:28px;
}

.single-section h2{
    font-size:24px;
    line-height:1.2;
    margin:0 0 14px;
}

.single-richtext{
    font-size:16px;
    line-height:1.8;
    color:#1f2937;
}

.donation-card{
    border:1px solid #ececec;
    border-radius:24px;
    background:#fff;
    padding:22px;
    margin-bottom:18px;
    position:sticky;
    top:18px;
}

.donation-card h3{
    font-size:30px;
    line-height:1.1;
    margin:0 0 8px;
}

.muted-text{
    font-size:14px;
    line-height:1.5;
    color:#6b7280;
}

.donation-stats{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    margin:16px 0;
}

.donation-stats strong{
    display:block;
    font-size:20px;
    line-height:1.1;
}

.donation-stats span{
    font-size:13px;
    color:#6b7280;
}

.donate-btn{
    width:100%;
    margin-top:14px;
}

.campaign-side-meta{
    margin-top:16px;
    display:grid;
    gap:10px;
}

.campaign-side-meta p{
    margin:0;
    font-size:14px;
    line-height:1.5;
}

.campaign-amounts{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
    margin-top:12px;
}

.campaign-amounts strong{
    display:block;
    font-size:15px;
    line-height:1.2;
}

.campaign-amounts span{
    display:block;
    margin-top:4px;
    font-size:12px;
    line-height:1.4;
    color:#6b7280;
}

.campaign-owner-line{
    font-size:14px;
    line-height:1.5;
}

.donor-list{
    display:grid;
    gap:0;
}

.donor-item{
    display:flex;
    justify-content:space-between;
    gap:12px;
    padding:12px 0;
    border-bottom:1px solid #eee;
}

.donor-item:last-child{
    border-bottom:none;
}

.donor-item strong{
    font-size:14px;
    line-height:1.4;
}

.donor-item span{
    display:block;
    font-size:12px;
    line-height:1.4;
    color:#6b7280;
}

.update-item{
    border:1px solid #ececec;
    border-radius:18px;
    padding:16px;
    margin-bottom:14px;
    background:#fff;
}

.update-item h3{
    font-size:17px;
    margin:0 0 6px;
}

.update-item small{
    display:block;
    font-size:12px;
    color:#6b7280;
    margin-bottom:10px;
}

.update-item p{
    margin:0;
    font-size:14px;
    line-height:1.7;
}

@media (max-width: 900px){
    .campaign-layout{
        grid-template-columns:1fr;
        gap:20px;
    }

    .campaign-main{
        order:1;
    }

    .campaign-sidebar{
        order:2;
    }

    .donation-card{
        position:static;
    }

    .single-title{
        font-size:28px;
    }

    .single-subtitle{
        font-size:15px;
        line-height:1.6;
    }

    .single-section{
        margin-top:22px;
    }

    .single-section h2{
        font-size:20px;
    }

    .single-richtext{
        font-size:15px;
        line-height:1.75;
    }

    .donation-card{
        padding:18px;
        border-radius:20px;
    }

    .donation-card h3{
        font-size:24px;
    }

    .campaign-slide{
        height:260px;
    }

    .story-reaction-head{
        align-items:flex-start;
    }
}

/* Force professional mobile order */
@media (max-width: 900px){
    .campaign-sidebar{
        display:contents;
    }

    .campaign-sidebar > .donation-card:first-child{
        order:2;
    }

    .campaign-main .single-section:nth-of-type(1){
        order:3;
    }

    .campaign-sidebar > .donation-card:nth-of-type(2){
        order:4;
    }
}
@media (max-width: 900px){
    body{
        -webkit-text-size-adjust:100%;
    }

    .campaign-meta{
        font-size:12px;
    }

    .card-link,
    .card-reaction-text,
    .reaction-summary-text{
        font-size:13px;
    }

    .campaign-card-simple h3{
        font-size:18px;
        line-height:1.35;
    }

    .campaign-card-simple p{
        font-size:14px;
        line-height:1.6;
    }
}