
/* Campaign page custom styling */

.campaign-page{
    gap:28px;
}

.campaign-hero-text{
    animation:fadeUp .45s ease both;
}

.campaign-card{
    position:relative;
    overflow:hidden;
    border-radius:32px;
    animation:fadeUp .55s ease both;
}

.campaign-card::before{
    content:"";
    position:absolute;
    inset:-2px;
    background:
        radial-gradient(circle at top left,rgba(34,197,94,.28),transparent 38%),
        radial-gradient(circle at bottom right,rgba(6,182,212,.26),transparent 40%);
    pointer-events:none;
}

.campaign-card::after{
    content:"";
    position:absolute;
    width:170px;
    height:170px;
    top:-70px;
    right:-70px;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    pointer-events:none;
}

.campaign-card > *{
    position:relative;
    z-index:2;
}

.money-icon{
    font-size:42px;
    filter:drop-shadow(0 12px 20px rgba(34,197,94,.25));
}

.reward,
.reward-grid{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:12px !important;
    margin:18px 0 !important;
}

.reward-box{
    width:100%;
    padding:18px;
    border-radius:22px;
    background:linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.055));
    border:1px solid rgba(255,255,255,.13);
    box-shadow:
        inset 0 1px rgba(255,255,255,.12),
        0 12px 28px rgba(0,0,0,.12);
}

.reward-box small{
    display:block;
    color:rgba(255,255,255,.70);
    font-weight:900;
    margin-bottom:6px;
}

.reward-box .amount{
    font-size:30px;
    line-height:1.15;
    word-break:break-word;
}

.goal-text{
    font-size:20px !important;
    color:#bfdbfe !important;
    padding-top:3px;
}

.action-box{
    margin:14px 0 22px;
    padding:18px;
    border-radius:28px;
    background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(6,182,212,.15));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:
        0 18px 38px rgba(0,0,0,.18),
        inset 0 1px rgba(255,255,255,.08);
}

.input-label{
    display:block;
    margin-bottom:9px;
    color:#e5e7eb;
    font-size:13px;
    font-weight:900;
}

.input{
    width:100% !important;
    height:58px !important;
    padding:0 18px !important;
    background:#fff !important;
    color:#0f172a !important;
    border:2px solid transparent !important;
    border-radius:18px !important;
    font-size:16px !important;
    font-weight:800 !important;
    outline:none !important;
    box-shadow:0 12px 28px rgba(0,0,0,.16) !important;
}

.input::placeholder{
    color:#94a3b8 !important;
    font-weight:600;
}

.input:focus{
    border-color:#22c55e !important;
    box-shadow:
        0 0 0 4px rgba(34,197,94,.18),
        0 12px 28px rgba(0,0,0,.16) !important;
}

.action-buttons{
    display:grid;
    grid-template-columns:1.12fr .88fr;
    gap:12px;
    margin-top:14px;
    align-items:stretch;
}

.action-buttons form,
.action-buttons button{
    width:100%;
}

.start-campaign-btn{
    height:58px !important;
    box-shadow:0 16px 35px rgba(34,197,94,.30) !important;
}

button.track-card-btn{
    all:unset !important;
    box-sizing:border-box !important;
    width:100% !important;
    min-height:58px !important;
    padding:10px 14px !important;
    border-radius:18px !important;
    cursor:pointer !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:12px !important;
    color:#fff !important;
    background:linear-gradient(135deg,#2563eb,#06b6d4) !important;
    box-shadow:0 16px 35px rgba(37,99,235,.30) !important;
    font-family:inherit !important;
    transition:.25s !important;
}

button.track-card-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 20px 42px rgba(37,99,235,.42) !important;
}

button.track-card-btn b{
    display:block !important;
    font-size:14px !important;
    font-weight:900 !important;
    line-height:1.1 !important;
}

button.track-card-btn small{
    display:block !important;
    font-size:11px !important;
    color:rgba(255,255,255,.80) !important;
    margin-top:3px;
}

.track-icon-mini{
    width:36px !important;
    height:36px !important;
    min-width:36px !important;
    display:grid !important;
    place-items:center !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.18) !important;
    box-shadow:inset 0 1px rgba(255,255,255,.18);
}

.refer-earn-box{
    margin-top:14px !important;
    padding:14px !important;
    border-radius:22px !important;
    display:flex !important;
    align-items:center !important;
    gap:13px !important;
    text-decoration:none !important;
    color:#fff !important;
    background:linear-gradient(135deg,rgba(250,204,21,.17),rgba(34,197,94,.15)) !important;
    border:1px solid rgba(250,204,21,.26) !important;
    box-shadow:0 14px 30px rgba(0,0,0,.12);
    transition:.25s !important;
}

.refer-earn-box:hover{
    transform:translateY(-2px);
    background:linear-gradient(135deg,rgba(250,204,21,.23),rgba(34,197,94,.20)) !important;
}

.refer-icon{
    width:44px;
    height:44px;
    min-width:44px;
    display:grid;
    place-items:center;
    border-radius:16px;
    font-size:23px;
    background:rgba(255,255,255,.15);
}

.refer-earn-box b{
    display:block;
    font-size:15px;
    font-weight:900;
}

.refer-earn-box small{
    display:block;
    margin-top:3px;
    color:rgba(255,255,255,.74);
    font-size:12px;
    line-height:1.4;
}

.refer-earn-box > span{
    margin-left:auto;
    font-size:24px;
    font-weight:900;
    color:#fde68a;
}

.upi-error{
    display:none;
    margin-top:10px;
    padding:10px 12px;
    border-radius:14px;
    color:#fecaca;
    background:rgba(239,68,68,.14);
    border:1px solid rgba(239,68,68,.30);
    font-size:13px;
    font-weight:800;
}

.section-title{
    margin:0 0 15px;
    color:#fff;
}

.step-card{
    display:flex;
    align-items:flex-start;
    gap:14px;
    padding:15px;
    margin-bottom:14px;
    background:rgba(255,255,255,.065);
    border:1px solid rgba(255,255,255,.11);
    border-radius:22px;
    transition:.25s;
}

.step-card:hover{
    transform:translateY(-2px);
    background:rgba(255,255,255,.095);
}

.step-icon{
    width:44px;
    height:44px;
    min-width:44px;
    border-radius:16px;
    display:grid;
    place-items:center;
    font-size:17px;
    font-weight:900;
    color:#fff;
    background:linear-gradient(135deg,#22c55e,#06b6d4);
    box-shadow:0 10px 25px rgba(34,197,94,.25);
}

.step-card b{
    color:#fff;
}

.step-card p{
    margin:5px 0 0;
    color:rgba(255,255,255,.74);
    line-height:1.55;
}

.soft-line{
    border:0;
    border-top:1px solid rgba(255,255,255,.12);
    margin:20px 0;
}

.terms{
    margin-top:18px;
}

@keyframes fadeUp{
    from{
        opacity:0;
        transform:translateY(12px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

@media(max-width:850px){
    .campaign-page{
        gap:18px;
    }

    .reward,
    .reward-grid{
        grid-template-columns:1fr 1fr !important;
    }
}

@media(max-width:520px){
    .campaign-page{
        padding-top:34px;
    }

    .campaign-card{
        border-radius:26px;
    }

    .money-icon{
        font-size:36px;
    }

    .reward,
    .reward-grid{
        grid-template-columns:1fr 1fr !important;
        gap:10px !important;
    }

    .reward-box{
        padding:14px 10px;
        text-align:center;
        border-radius:19px;
    }

    .reward-box .amount{
        font-size:22px;
    }

    .goal-text{
        font-size:14px !important;
        line-height:1.25;
    }

    .action-box{
        padding:15px;
        border-radius:24px;
    }

    .action-buttons{
        grid-template-columns:1fr;
    }

    button.track-card-btn{
        justify-content:flex-start !important;
        padding-left:14px !important;
    }

    .refer-earn-box{
        padding:13px !important;
    }

    .refer-earn-box small{
        font-size:11px;
    }

    .step-card{
        padding:13px;
        border-radius:20px;
    }

    .step-icon{
        width:40px;
        height:40px;
        min-width:40px;
    }
}
