/* RESET */
@font-face{
    font-family:'Manrope';
    src:url('../fonts/Manrope-Bold.ttf') format('truetype');
    font-weight:600;
}





.mobile-menu,
.menu-toggle{

    display:none;

}






*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
  
    background:#f6f8fb;
    position:relative;
    color:#111;
    line-height:1.5;
    font-family:'Manrope',sans-serif !important;
    min-width:1500px;

}

body::before{

    content:'';

    position:fixed;

    inset:0;

    pointer-events:none;

    z-index:0;

    background:

    radial-gradient(
        1200px circle at -15% 50%,
        rgba(148,163,184,.35),
        transparent 55%
    ),

    radial-gradient(
        1200px circle at 115% 50%,
        rgba(148,163,184,.35),
        transparent 55%
    );

    filter:blur(140px);
}
.main-wrapper{
    min-width:1500px !important;
    width:100% !important;
    margin:0 auto;
}
.main-header{

    position:fixed;
    
    top:0px;

  

    transform:none;

    width:100%;
    min-width: none;
    max-width:none;

    height:120px;

    background:rgba(255,255,255,.82);

    backdrop-filter:blur(24px);

    border:1px solid rgba(255,255,255,.6);

    border-radius:0;

    box-shadow:
    0 10px 40px rgba(0,0,0,.08);

    z-index:9999;

}

.header-inner{

    width:100%;

    height:100%;

    padding:0 50px;

    display:flex;

    align-items:center;

    justify-content:space-between;

}

.brand{

    display:flex;

    align-items:center;

    gap:14px;

    text-decoration:none;
    margin-right: auto;

}

.brand img{

    width:110px;

}

.brand-text{

    display:flex;

    flex-direction:column;

    line-height:1.1;

}

.brand-text span{

    font-size:46px;

    font-weight:800;

    color:#111827;

}

.brand-text small{

    font-size:28px;

    color:#6b7280;
    letter-spacing: 1px;

}

.brand,
.main-nav,
.cta-btn{
    flex-shrink:0 !important;
}

.main-nav{

    display:flex;
    align-items: center;
    flex-wrap: nowrap !important;
    white-space: nowrap;
margin-right: 60px;
margin-left: auto;
    gap:60px;

}

.main-nav a{
    display: :inline-block;

    text-decoration:none;

    color:#374151;

    font-size:26px;
    
    font-weight:600;

    transition:.25s;
    white-space: nowrap;

}

.main-nav a:hover{

    color:#1800ad;

}

.cta-btn{

    height:88px;

    padding:0 50px;

    display:flex;

    align-items:center;

    justify-content:center;

    text-decoration:none;

    border-radius:16px;

    background:rgba(59,130,246,.12);

    border:2px solid rgba(59,130,246,.20);

    backdrop-filter:blur(20px);

    color:#1d4ed8;

    font-size:28px;

    font-weight:500;

    box-shadow:
    0 8px 30px rgba(59,130,246,.08);

    transition:.3s ease;
    gap: 12px;
}

.cta-btn svg{

    width:34px;

    height:28px;

    flex-shrink:0;

}


/* CONTAINER */





/*  footer */

.main-footer{

    background:
    linear-gradient(
    135deg,
    #14008f 0%,
    #3526d8 100%
    );

    padding:90px 90px;

}

.footer-container{

    max-width:1400px;

    margin:auto;

    display:flex;

    justify-content:space-between;

    align-items:flex-start;

    gap:120px;

}

.footer-left{

    width:42%;

    text-align:left;

}

.footer-left h3{

    color:#ffffff;

    font-size:34px;

    font-weight:800;

    margin-bottom:30px;

    line-height:1.4;

}

.footer-left p{

    color:rgba(255,255,255,0.92);

    font-size:22px;

    line-height:2;

    margin:0;

}

.footer-right{

    width:58%;

    text-align:left;

    padding-top:12px;

}

.footer-right p{

    color:rgba(255,255,255,0.88);

    font-size:22px;

    line-height:2.1;

    margin:0;

}
/* HERO SECTION */

.hero-section{

    position:relative;

    min-height:950px;

    overflow:hidden;

    padding-top:180px;
    margin-left: -60px;

}

.hero-section::before{

    content:'';

    position:absolute;

    top:0;
    right:0;
    bottom:0;

    width:100%;
    min-width: 1700px;

    background:
linear-gradient(
to right,
rgba(255,255,255,.35) 0%,
rgba(255,255,255,.15) 30%,
rgba(255,255,255,.03) 55%,
rgba(255,255,255,0) 100%
),
url('../images/hero-family.webp')
    right center /
    cover
    no-repeat;

    z-index:0;

}

.hero-section::after{

    content:'';

    position:absolute;

    inset:0;

    background:
    linear-gradient(
        90deg,
        rgba(255,255,255,.95) 0%,
        rgba(255,255,255,.85) 30%,
        rgba(255,255,255,.15) 60%,
        transparent 100%
    );

    z-index:1;

}

.hero-title{
    font-family:'Manrope';
    font-weight:900 !important;
    letter-spacing:-2px;
    font-size:75px;
    line-height:1;
    color:#111;
    margin-top:0px;
    padding-top: 30px !important;

}

.hero-title span{
    
    color:#1800ad;
}

.hero-subheading{

    margin-top:10px;
    font-size:62px;



    letter-spacing:0.5px;

    color:#111;

    margin-bottom:35px;
   
    
    font-family:'Manrope';
    font-weight:600;
    line-height:1;
}

.hero-org-logos{

    display:flex;
  
    align-items:center;

    gap:32px !important;

    margin-top:30px;

    margin-bottom:35px;
}

.hero-org-logos img{

    height:170px;

    width:auto;
    gap: 30px;
    object-fit:contain;
    

}

.logo-amil{
    gap: 40px;
}
.hero-btn{

    display:flex !important;
    align-items:center !important;

    justify-content:center !important;

    gap:14px !important;

    width:650px !important;

    padding:26px 50px !important;

    background:linear-gradient(135deg,#1800ad,#4f46ff) !important;

    color:#fff !important;

    text-decoration:none !important;

    border-radius:16px !important;

    font-size:24px !important;

    font-weight:700 !important;

    margin-top:350px !important;
    backdrop-filter:blur(16px);

    box-shadow:0 10px 30px rgba(0,0,0,0.08) !important;

}

.hero-btn svg{

    width:26px !important;

    height:26px !important;

}

.hero-btn:hover{

    transform:translateY(-4px);

    box-shadow:0 10px 30px rgba(0,0,0,0.08);

}
.hero-description{
    font-size:32px;
    line-height:1.2;
    color:#444;
    max-width:100%;
    margin-bottom:15px;
    margin-top: 15px;

}

.hero-features{
    list-style:none;
    display:flex;
    flex-direction:column;
    gap:18px;
}

.hero-features li{
    font-size:18px;
    line-height:1.6;
    color:#111;
    font-weight:600;
}

/* SERVICES */




.services-section{
   background:
    linear-gradient(
    135deg,
    #2418b8 0%,
    #3f34e8 55%,
    #6a63ff 100%
    ) !important;
    padding:10px 0 50px;
}

.services-description{

    max-width:1400px;

    margin:35px auto 70px;

    text-align:center;

    font-size:32px;

    line-height:1.8;

    color:#ffffff;

    font-weight:500;
    letter-spacing:0.3px;

}


.service-title{
    
width:100%;

    text-align:center;
    line-height:1;
    margin-top: 40px;
    margin-bottom: 40px;
    
}

.service-title h2{
    font-size:72px;
    color:#fff;
 
}
.section-title{

    width:100%;

    text-align:center;
    line-height:1;
    margin-bottom:60px !important;

}

.section-title h2{
    font-size:72px;
    color:#fff;
 
}

.section-title p{

    font-size:26px;

    line-height:1.45;

    font-weight:500;

    color:#ffffff;

    max-width:1450px;

    margin:25px auto 40px;

    text-align:center;

}





.service-card{

    background:#fff;

    border-radius:24px;

    overflow:hidden;
    min-height: 600px;

    box-shadow:0 10px 30px rgba(0,0,0,0.08);




}

.service-card img{

    width:100%;

    height:400px;

    object-fit:cover;

}

.service-content{

padding:30px 30px 40px;
}

.service-grid{

    display:grid;

    grid-template-columns:repeat(3, 600px);

    gap:30px;

    justify-content:center;

    min-width:1500px;

}

.service-content p{
    margin-bottom:25px;
    color:#444;
    font-size:28px;
    line-height:1.7;
    text-align: center;
}

.services-link{

    display:block;

    text-align:center;

    margin-top:28px;

    font-size:24px;

    font-weight:600;

    color:#ffffff !important;

    text-decoration:none;

    word-break:break-word;

}

.service-btn{

    display:flex ;

    align-items:center ;

    justify-content:center ;

    width:260px ;

    height:68px ;

    margin:35px auto 0 ;

    background:linear-gradient(135deg,#1800ad,#4f46ff) ;

    border-radius:18px ;

    font-size:24px ;

    font-weight:700 ;

    color:#fff ;

    text-decoration:none ;

    box-shadow:0 10px 30px rgba(0,0,0,0.08);

}

.zakat-grid{

    display:grid;

    grid-template-columns:repeat(4, 270px);

    justify-content:center;
    margin-top: 30px;
    column-gap:40px;

    row-gap:28px;

}
.zakat-card{

    background:rgba(255,255,255,0.22);

    border:1px solid rgba(255,255,255,0.30);

    box-shadow:
    0 10px 30px rgba(0,0,0,0.08),
    0 0 25px rgba(255,255,255,0.12);

    -webkit-backdrop-filter:blur(12px);

    backdrop-filter:blur(12px);

    border:1px solid rgba(255,255,255,0.12);

    border-radius:28px;

    height:220px;

    padding:45px 30px;
    width:220px;

    display:flex;

    flex-direction:column;

    align-items:center;

    justify-content:center;

    text-align:center;

    transition:.3s;

}

.zakat-icon{

    width:150px;

    height:150px;

    border-radius:28px;

    background:rgba(255,255,255,0.28);
    
    backdrop-filter:blur(20px);

    display:flex;

    align-items:center;

    justify-content:center;

    margin:0 auto 28px;

}

.zakat-card h3{

    color:#ffffff;

    font-size:24px;

    line-height:1.4;

    font-weight:700;

}

.zakat-card:hover{

    transform:translateY(-6px);

}


.zakat-icon svg{

    width:52px;

    height:52px;

    stroke:#ffffff;

    color:#ffffff;

}
/* PAYMENT SECTION */

.payment-section{


    background:#f5f7ff;

}

.payment-wrapper{
    display:grid;
    grid-template-columns:280px 1fr !important;
    gap:36px;
    align-items:start;
}

.payment-left{

    padding-top:200px ;

}



.payment-badge{

    display:inline-block;

    background:#1800ad;

    color:#fff;

    padding:12px 24px;

    border-radius:999px;

    font-size:15px;

    font-weight:600;

    margin-bottom:28px;

}

.payment-left h2{

    font-size:68px;

    line-height:1.05;

    margin-bottom:28px;

    color:#111;

}

.payment-left p{

    font-size:24px;

    line-height:1.7;

    color:#444;

    margin-bottom:35px;

}

.payment-features{

    list-style:none;

    display:flex;

    flex-direction:column;

    gap:18px;

}

.payment-features li{

    font-size:22px;

    font-weight:600;

    color:#111;

}

/* CARD */

.payment-card{
    
    
    margin-top: 80px;
    margin-bottom: 80px;
    background:#eef5ff;
    border-radius:24px;

    padding:100px;
    
    width: 100% !important;

   position:relative;

    z-index:5;

    border:1px solid rgba(79,70,255,.12);

    box-shadow:
    0 30px 80px rgba(59,130,246,.15),
    0 10px 30px rgba(0,0,0,.05);




}

.payment-card::before{

    content:'';

    position:absolute;

    top:-2px;
    left:-2px;
    right:-2px;
    bottom:-2px;

    border-radius:34px;

    z-index:-1;

}

.payment-card h2{
    text-align: center;
    font-size:34px;
    margin-bottom: 30px;
}
.form-logo{

    text-align:center;

    margin-bottom:15px;

}

.form-logo img{

    height:70px;

}

.form-sublogos{

    display:flex;

    justify-content:center;

    gap:18px;

    margin-bottom:30px;

}

.form-sublogos img{

    height:55px;

}


/* STEP TEXT */




/* BULAT NUMBER */

.progress-step span{

    width:88px;

    height:88px;

    border-radius:50%;

    background:#e2e8f0;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:26px;

    font-weight:800;

    transition:.3s;

}

/* ACTIVE */

.progress-step.active{

    color:#1800ad;

}

.progress-step.active span{

    background:#1800ad;

    color:#fff;

    box-shadow:0 10px 30px rgba(0,0,0,0.08);

}

.form-progress{

    display:flex;

    align-items:flex-start;

    justify-content:space-between;

    gap:18px;

    margin-bottom:60px;

}


.progress-step{

    display:flex;

    flex-direction:column;

    align-items:center;

    min-width:100px;

    gap:14px;

}




.progress-step p{

    font-size:15px;

    font-weight:600;

    color:#94a3b8;

    margin:0;

}


.progress-line{

    flex:1;

    height:2px;

    margin-top:28px;

    background:#e2e8f0;

    border-radius:999px;

    position:relative;

    overflow:hidden;

}


.progress-line.active::after{

    content:"";

    position:absolute;

    inset:0;

    background:
    linear-gradient(
        90deg,
        #1d4ed8,
        #4338ca
    );

}


/* ACTIVE */

.progress-step.active span{

    background:#1d4ed8;

    color:white;

    box-shadow:
    0 12px 30px rgba(37,99,235,0.20);

}


.progress-step.active p{

    color:#0f172a;

}


/* COMPLETED */

.progress-step.completed span{

    background:#0f172a;

    color:white;

}


.progress-step.completed p{

    color:#0f172a;

}

.form-step{

    display:none;

    flex-direction:column;

    gap:4px;

    animation:fadeSlide .35s ease;

}

.form-step.active-step{
    display:block;
}

.form-title{

    font-size:28px;

    margin-bottom:25px;
    margin-top: 0px;
    color:#111;

}



.active-step{

    display:flex;

}

.step-buttons{

    display:flex;
    flex-direction:column;
    gap:10px !important;
    margin-top:20px !important;
    
}

.step-buttons .submit-btn{

flex:2;

}

@keyframes fadeSlide{

    from{

        opacity:0;

        transform:translateY(12px);

    }

    to{

        opacity:1;

        transform:translateY(0);

    }

}

.next-btn{

    width:100%;

    height:72px;

    border:none;

    border-radius:20px;

    background:linear-gradient(135deg,#1800ad,#4f46ff);

    color:#fff;

    font-size:22px;

    font-weight:700;

    margin-top:35px;

    cursor:pointer;

}



.payment-card label{

    display:block;

    font-size:24px;

    font-weight:600;

    margin:10px 0 4px;
    margin-bottom: 8px;

    line-height:1.1;

}

.payment-card input,
.payment-card select,
.payment-card textarea{

    height: 60px;
    font-size: 18px;
    border-radius: 6px;

}
.payment-card input::placeholder,
.payment-card textarea::placeholder{

    font-size:24px;

}
.payment-card select option{

    font-size:30px;

}

.service-card,
.payment-card{

    border:1px solid rgba(255,255,255,0.35);

    backdrop-filter:blur(10px);
}

.payment-card input,
.payment-card select,
.payment-card textarea{

    width:100%;

    border:1px solid #dbe1ea;

    border-radius:8px;

    padding:0 22px;

    font-size:24px;

    outline:none;

    transition:.2s;

    background:#fff;

}

.payment-card input,
.payment-card select{

    height:62px;
    margin-bottom: 10px;

}

.payment-card textarea{

    min-height:140px;
    font-size: 22px;

    padding-top:18px;

}

.payment-card input:focus,
.payment-card select:focus{

    border-color:#1800ad;

}

.radio-group{

    display:flex;

    gap:20px;

    margin-top:10px;

}

.radio-group label{

    margin:0;

    display:flex;

    align-items:center;

    gap:8px;

}

.submit-btn{

    width:100%;

    height:72px;

    border:none;

    border-radius:20px;

    background:linear-gradient(135deg,#1800ad,#4f46ff);

    color:#fff;

    font-size:22px;

    font-weight:700;

    margin-top:35px;

    cursor:pointer;

    box-shadow:0 10px 30px rgba(0,0,0,0.08);

}

.akad-box{

    background:#f8faff;

    border:1px solid #dbe7ff;

    border-radius:24px;

    padding:35px;

    margin-top:20px;

}

.akad-arabic{

    font-size:34px;

    text-align:center;

    margin-bottom:30px;

    color:#1800ad;

    font-weight:700;

}

.akad-text{

    font-size:26px;

    line-height:1.8;

    text-align:center;

    color:#111;

}

.akad-text strong{

    color:#1800ad;

}
.back-btn{

    width:100%;

    height:68px;

    border:none;

    border-radius:18px;

    background:#e5e7eb;

    color:#111827;

    font-size:20px;

    font-weight:700;

    margin-top:20px;

    cursor:pointer;

}

.payment-note{

    margin-top:20px;

    padding:24px 30px;

    border-radius:20px;

    background:#eef2ff;

    text-align:center;

    font-size:22px;

    line-height:1.4;

    font-weight:600;

    color:#1800ad;
    
    box-shadow:0 10px 30px rgba(0,0,0,0.08);

}

/* TAULIAH */

.tauliah-section{

    padding:60px 100px !important;

    

    background:
    linear-gradient(
    135deg,
    #2418b8 0%,
    #3f34e8 55%,
    #6a63ff 100%
    ) !important;


    overflow:hidden;

}

.tauliah-grid{

    display:grid !important;

    grid-template-columns:0.85fr 1.15fr !important;

    align-items:center !important;

    gap:70px !important;

}

.tauliah-text{

    padding-left:20px !important;

    max-width:620px !important;

}

.tauliah-text h2{

    font-size:76px !important;

    line-height:1.02 !important;

    font-weight:800 !important;

    color:#ffffff !important;

    margin-bottom:34px !important;

    letter-spacing:-3px !important;

}

.tauliah-description{

    font-size:26px !important;

    line-height:1.85 !important;

    color:rgba(255,255,255,0.93) !important;

    margin-bottom:26px !important;

    font-weight:400 !important;

}

.tauliah-link{

    display:inline-flex !important;

    align-items:center !important;

    justify-content:center !important;

    padding:18px 40px !important;

    border-radius:18px !important;

    background:#ffffff !important;

    color:#16009a !important;

    font-size:22px !important;

    font-weight:700 !important;

    text-decoration:none !important;

    box-shadow:0 10px 30px rgba(0,0,0,0.08) !important;

}

.tauliah-image img{

    width:100% !important;

    border-radius:34px !important;

    box-shadow:0 10px 30px rgba(0,0,0,0.08) !important;

}
/* WHATSAPP */

.whatsapp-float{
    position:fixed;
    right:20px;
    bottom:20px;
    background:#25D366;
    color:#fff;
    text-decoration:none;
    padding:16px 24px;
    border-radius:50px;
    font-weight:700;
    z-index:999;
}

.bayar-float{

    position:fixed;

    right:20px;

    bottom:95px;

    background:
    linear-gradient(
    135deg,
    #1800ad,
    #4f46ff
    );

    color:#fff;

    text-decoration:none;

    padding:18px 28px;

    border-radius:999px;

    font-weight:700;

    font-size:18px;

    box-shadow:0 10px 30px rgba(0,0,0,0.08);

    z-index:999;

}

.float-icon{

    width:26px !important;

    height:26px !important;

    max-width:26px !important;

    max-height:26px !important;

    min-width:26px !important;

    min-height:26px !important;

    object-fit:contain !important;

    display:block !important;

}



.site-width{

    width:1500px;

    max-width:none;
    min-width: 1500px;

    margin:0 auto;

    position:relative;

}


.site-shell{
    position:relative;
    z-index:1;
}
.site-canvas{

    min-width:1600px !important;
    width:1600px !important;
    max-width:none !important;
  margin-left:620px;

 position:relative;
    z-index:2;
}


.zakat-switcher{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:14px;

}


.zakat-option{

    position:relative;

    padding:20px;

    border:none;

    border-radius:24px;

    background:#ffffff;

    text-align:left;

    cursor:pointer;

    transition:0.28s ease;

    box-shadow:
    0 4px 14px rgba(15,23,42,0.05);

    border:1px solid rgba(15,23,42,0.05);

}


.zakat-option:hover{

    transform:translateY(-3px);

    box-shadow:
    0 18px 35px rgba(37,99,235,0.10);

}


.zakat-option.active{

    background:
    linear-gradient(
        135deg,
        #1d4ed8,
        #2563eb
    );

    color:white;

    box-shadow:
    0 20px 40px rgba(37,99,235,0.25);

}


.zakat-title{

    display:block;

    font-size:17px;

    font-weight:700;

    margin-bottom:6px;

}


.zakat-desc{

    display:block;

    font-size:13px;

    opacity:0.78;

    line-height:1.5;

}

/* FIXED DESKTOP LAYOUT */

html,
body{
    min-width:1500px;
    overflow-x:hidden;
    overflow-y:auto;

}


/* PREVENT ALL SQUEEZE */
/* BESARKAN RUANG PAYMENT SECTION */

.payment-section .nisab-card{
    display:grid;
    grid-template-columns:600px 1fr;
    gap:10px;
    width:100%;
    max-width:1800px;
    margin:0 auto;
}

.payment-left{
    margin-top:300px !important;
}


