

body{
    
}

.section-title{
    margin-top: 60px;
    margin-bottom: 15px;
}



.nisab-left{
    margin-top: 150px;
    width:800px;
    max-width:800px;
    text-align:center;
    padding:40px;
}


.nisab-price{
    font-size:72px;
}

.nisab-card{

    display:flex;

    grid-template-columns:600px 1080px;

    gap:40px;

    justify-content:center;
    

    margin-top: 100px;

}




.nisab-left,
.nisab-right{

    flex:1;
    min-width: 0;
}

.nisab-right{
    margin-top: 50px !important;
    display:flex;

    flex-direction:column;

    

    align-items:center;


}




.nisab-right h3{
    margin: 0;
    white-space: nowrap;
     margin-bottom:20px;

    color:#0d47a1;

}


.jenis-zakat-bar{

    display:flex;

    align-items:center;

    gap:24px;

    margin-bottom:35px;

    background:#f8fbff;

    border:1px solid #e3edf7;

    border-radius:24px;

    padding:24px 28px;

}

.jenis-zakat-bar h3{

    margin:0;

    font-size:22px;

    font-weight:700;

    color:#0d47a1;

    white-space:nowrap;

}

#jenisZakat{

    flex:1;

    height:64px;

    border-radius:18px;

    border:1px solid #d7e3f0;

    background:#ffffff;

    padding:0 22px;

    font-size:18px;

    font-weight:600;

    color:#111827;

    outline:none;

    transition:0.25s ease;

    box-shadow:
    0 4px 12px rgba(15,23,42,0.04);

}

#jenisZakat:hover{

    border-color:#90caf9;

}

#jenisZakat:focus{

    border-color:#1565c0;

    box-shadow:
    0 0 0 5px rgba(21,101,192,0.12);

}


.jenis-zakat-bar select{

    flex:1;

}



.jenis-zakat-business{
    display:flex;
    flex-direction: column;
    align-items:center;
    margin-bottom: 50px !important;
    padding:8px 14px;

    background:#eef5ff;

    border-radius:999px;

    color:#1565c0;

    font-size:40px !important;
    font-weight:700;

    text-transform:uppercase;
    letter-spacing:6px;
}

.progress-step p{
    font-size:26px;
    font-weight:650;
    letter-spacing:-0.3px;
}

.progress-line{
    height:5px;
    border-radius:999px;
    position: relative;
    top:-40px;
}

.form-progress{
    display:flex;
    align-items:center;
}
/* =========================
   CARD
========================= */

.card{
    background:#fff;

    padding:40px;

    border-radius:30px;

    box-shadow:
    0 20px 50px rgba(0,0,0,0.06);
}

/* =========================
   NISAB
========================= */



.nisab-price{
    
    font-size:80px;
    font-weight:800;
    color:#0d47a1;
}

.nisab-left h2{
    font-size:52px;
    font-weight:650;
    letter-spacing:-1px;
    margin-bottom:16px;
    color:#0f172a;
}

.updated-text{
    
    font-size:38px;
    margin-top:15px;
    color:#777;
}

/* =========================
   FORM LAYOUT
========================= */

.zakat-form-card{
    background:#fff;

    border-radius:30px;

    padding:45px;

    box-shadow:
    0 20px 50px rgba(0,0,0,0.06);
width: 100%;
max-width: none;
}





.step-badge{

    display:inline-flex;

    align-items:center;
    justify-content:center;

    height:36px;

    padding:0 18px;

    border-radius:999px;

    background:#eef5ff;

    color:#1565c0;

    font-size:14px;
    font-weight:700;

    margin-bottom:20px;
}

/* STEP BUTTONS */






.

/* =========================
   BOX
========================= */

.kira-box{
    
    width:100%;
    box-sizing: border-box;
    padding: 30px;

    background:#f8fbff;

    border-radius:28px;

    padding:15px;

    margin-bottom:15px;

    border:1px solid #e5edf5;
}

.kira-box select,
.kira-box option{

    font-size:24px !important;

}
/* =========================
   ROW
========================= */

.kira-row,
.jumlah-row{
    
    display:flex;
    
    width: 100%;
    justify-content:space-between;

    align-items:center;
    flex-wrap:nowrap;
    gap:30px;

    margin-bottom:28px;
}

.jumlah-row select{
    
    font-size: 22px !important;

    width:220px !important;

    max-width:220px !important;

    flex:none !important;
}

.kira-row:last-child,
.jumlah-row:last-child{
    margin-bottom:0;
}

/* =========================
   LABEL
========================= */

.kira-label{

    flex:1;
    font-size:24px;
    min-width:0;
}

.kira-label h4{

  

    margin-bottom:8px;

    color:#111827;
}

.kira-label p{

    color:#6b7280;



    line-height:1.6;
}

/* =========================
   MONEY INPUT
========================= */

.money-input{
    flex-shrink: 0;
    font-size: 20px;

    display:flex;

    align-items:center;

    justify-content:space-between;

    width:260px;

    height:76px;

    padding:0 26px;

    border-radius:26px;

    background:
    linear-gradient(
        180deg,
        #fcfdff,
        #f8fafc
    );

    border:1px solid rgba(15,23,42,0.05);

    transition:0.28s ease;

}



.currency{

    position:relative;

    font-size:18px;

    font-weight:700;

    color:#94a3b8;

    padding-right:24px;

    letter-spacing:-0.2px;

}

.currency::after{

    content:"";

    position:absolute;

    top:50%;

    right:0;

    transform:translateY(-50%);

    width:1px;

    height:38px;

    background:#e2e8f0;

}

.money-input:hover{

    transform:translateY(-1px);

    box-shadow:
    0 14px 28px rgba(15,23,42,0.06);

}

.money-input:focus-within{

    background:#ffffff;

    border-color:rgba(37,99,235,0.20);

    box-shadow:
    0 0 0 4px rgba(37,99,235,0.10);

}

.money-input input,
.jumlah-row select{

    font-size:22px !important;
    align-items: center !important;
    letter-spacing:1.1px !important;
    font-weight: 300 !important;
}

.money-input input::placeholder{

    color:#cbd5e1;

}



.money-input input{

    width:100%;

    border:none;

    background:transparent;

    outline:none;

    text-align:right;

    font-size:26px;

    font-weight:650;

    letter-spacing:-1.2px;

    color:#0f172a;

    padding-left:10px;

}
/* =========================
   SELECT
========================= */

select{

    width:220px;
    height:58px;

    border-radius:18px;

    border:1px solid #dbe3ec;

    padding:0 16px;

    background:#fff;

    font-size:15px;

    outline:none;
}

/* =========================
   BUTTON
========================= */

.btn-kira{

    width:100%;

    height:64px;

    border:none;

    border-radius:20px;

    margin-top:35px;

    background:
    linear-gradient(
        135deg,
        #1565c0,
        #1976d2
    );

    color:#fff;

    font-size:18px;
    font-weight:700;

    cursor:pointer;

    transition:0.25s ease;

    box-shadow:
    0 14px 30px rgba(21,101,192,0.22);
}

.btn-kira:hover{
    transform:translateY(-2px);
}

/* =========================
   RESULT
========================= */

.result-box{
    margin-top:40px;
}

.success-box,
.error-box{

    padding:30px;

    border-radius:28px;
}

.success-box{

    background:#f8fbff;

    border:1px solid #dbeafe;
}

.error-box{

    background:#fff6f6;

    border:1px solid #ffdede;
}

.zakat-total{

    font-size:52px;

    font-weight:800;

    color:#0d47a1;

    margin-top:12px;
}

/* =========================
   HARGA
========================= */

.harga-list{

    display:flex;

    flex-direction:column;

    gap:18px;
}

.harga-item{

    display:flex;

    justify-content:space-between;

    align-items:center;

    padding:18px 20px;

    border-radius:20px;

    background:#f8fbff;
}

.harga-item strong{
    color:#0d47a1;
}

/* REMOVE NUMBER SPINNER */

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{

    -webkit-appearance:none;

    margin:0;
}

input[type=number]{

    -moz-appearance:textfield;
}

.step-buttons .submit-btn1,
.step-buttons .back-btn1{

    width:100% !important;

   

    min-height:60px !important;

    display:flex !important;

    align-items:center !important;

    justify-content:center !important;

    padding:0 20px !important;
}

.step-buttons{

    gap:16px !important;
}

.step-buttons .submit-btn1{

    margin-top:0 !important;
}

    .step-buttons .back-btn1{
    margin-bottom:0 !important;
}

.step-buttons .submit1-btn,
.step-buttons .back-btn1{

    box-shadow:none !important;
}

*{
    box-sizing:border-box;
}

.submit1-btn{
    width:100%;
    height:64px;

    border:none;
    border-radius:18px;

    background:#2563eb;

    color:#fff;
    font-size:24px;
    font-weight:700;

    cursor:pointer;

    transition:all .25s ease;
}

.submit1-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 12px 30px rgba(37,99,235,.25);
}


.back1-btn{
    width:100%;
    height:64px;

    border:1.5px solid #dbe3ec;
    border-radius:18px;

    background:#fff;

    color:#0f172a;
    font-size:24px;
    font-weight:600;

    cursor:pointer;

    transition:all .25s ease;
}

.back1-btn:hover{
    border-color:#94a3b8;
    background:#f8fafc;
}

html,
body{
font-family:'Plus Jakarta Sans', sans-serif;
    margin:0;
    padding:0;
background:#fff;
    overflow-x:auto;
}

.site-width{

    width:100%;

   
    margin:auto;

}



.zakat-divider{

    position:relative;

    margin-top:28px;

    padding-top:30px;

}





.main-header{

    overflow-x:auto;
}

.zakat-divider::before{

    content:'';

    position:absolute;

    top:0;

    left:0;

    width:100%;

    height:1px;

    background:#dbe3ec;

}

.rumusan-box{

    background:#f8fbff;

    border:1px solid #e5edf5;

    border-radius:28px;

    padding:24px;

}

.rumusan-row{

    display:flex;

    justify-content:space-between;

    align-items:center;

    padding:20px 8px;

}

.rumusan-row span{

    font-size:24px;

    color:#111827;

}

.rumusan-row strong{

    font-size:26px;

    font-weight:800;

    color:#1565c0;

}

.rumusan-divider{

    height:1px;

    background:#dbe3ec;

    margin:18px 0 28px;

}

.rumusan-zakat{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:24px;

}

.rumusan-zakat-box{

    background:#ffffff;

    border:1px solid #dbe3ec;

    border-radius:22px;

    padding:24px;

}

.rumusan-zakat-box span{

    display:block;

    font-size:26px;

    color:#64748b;

    margin-bottom:10px;

}

.rumusan-zakat-box strong{

    font-size:40px;

    font-weight:800;

    color:#1565c0;

}

.rumusan-value{

    font-size:32px;

    font-weight:700;

    color:#1f66c2;

    text-align:right;

}

.bayar-btn{

    display:inline-block;

    margin-top:20px;

    padding:12px 20px;

    background:#1f66c2;

    color:#fff;

    border-radius:12px;

    text-decoration:none;

    font-weight:600;

    transition:0.3s;
    font-size:24px !important;

}

.bayar-btn:hover{

    background:#174f97;

}

.reset-btn{

    width:200%;

    height:74px;

    margin-top:18px;

    border:none;

    border-radius:22px;

    background:#f1f5f9;

    color:#475569;

    font-size:26px;

    font-weight:600;

    cursor:pointer;

    transition:0.25s ease;

}

.reset-btn:hover{

    background:#e2e8f0;

    transform:translateY(-1px);

}

.section-header-business{

    display:flex;

    justify-content:space-between;

    align-items:center;

    gap:20px;

    margin-bottom:10px;
}

.jenis-zakat-business{

    display:flex;

    align-items:center;

    gap:12px;

    color:#1565c0;

    font-size:24px;

    font-weight:700;
}

.total-box{

    padding-top:10px;

    border-top:1px solid #dbe3ec;
}

.status-zakat{

    margin-top:20px;

    padding:18px 20px;

    border-radius:16px;

    background:#eef5ff;

    border:1px solid #dbeafe;

    color:#0d47a1;

    font-size:22px;

    font-weight:600;

    line-height:1.5;
}

.zakat-ai{



    margin-top: 50px;

    box-shadow:
    0 20px 45px rgba(15,23,42,0.04);
    
    border:3px solid #dbeafe;
    border-radius:24px;
    padding:24px;

    background:#f8fbff;

}


.zakat-head{

    margin-bottom:34px;

}


.eyebrow{

    display:inline-block;

    font-size:48px;

    font-weight:700;

    letter-spacing:0.14em;

    text-transform:uppercase;

    color:#2563eb;

    margin-bottom:18px;

}


.zakat-head h2{

    font-size:42px;

    line-height:1.05;

    letter-spacing:-1.8px;

    color:#0f172a;

    margin-bottom:14px;

    font-weight:650;

}


.zakat-head p{
    
    margin-top:28px;

    font-size:30px;

    line-height:1;

    color:#64748b;

}


.zakat-options{

    display:flex;

    flex-direction:column;

}


.zakat-item{

    display:flex;

    align-items:flex-start;

    gap:18px;

    padding:24px 0;

    background:none;

    border:none;

    border-bottom:
    3px solid rgba(15,23,42,0.06);

    text-align:left;

    width:100%;

    cursor:pointer;

    transition:0.25s ease;
    

}


.zakat-item:last-child{

    border-bottom:none;

}


.dot{

    width:12px;

    height:12px;

    border-radius:999px;

    background:#cbd5e1;

    margin-top:10px;

    transition:0.25s ease;

}


.zakat-item.active .dot{

    background:#2563eb;

    box-shadow:
    0 0 14px rgba(37,99,235,0.45);

}


.zakat-text h3{

    font-size:35px;

    font-weight:650;

    letter-spacing:-0.4px;

    color:#0f172a;

    margin-bottom:6px;

    transition:0.25s ease;

}


.zakat-text span{

    font-size:25px;

    line-height:1.7;

    color:#64748b;

}


.zakat-item:hover{

    transform:translateX(4px);

}


.zakat-item:hover .dot{

    background:#2563eb;

}

.nisab-status{

    margin-top:24px;

    padding:18px 22px;

    border-radius:20px;

    font-size:26px;

    font-weight:600;

    text-align:center;

    transition:0.3s ease;

}

.nisab-status.not-pass{

    background:
    rgba(239,68,68,0.08);

    color:#dc2626;

    border:
    1px solid rgba(239,68,68,0.12);

}
.nisab-status.pass{

    background:
    rgba(34,197,94,0.08);

    color:#16a34a;

    border:
    1px solid rgba(34,197,94,0.12);

}

.bahagian-header{

display:flex;
justify-content:space-between;
align-items:center;

padding:20px 24px;

border-radius:24px;

background:white;

border:1px solid #E5E7EB;

cursor:pointer;

transition:0.25s;

margin-bottom:16px;

}

.bahagian-header:hover{

transform:translateY(-1px);

box-shadow:
0 8px 24px rgba(15,23,42,0.06);

}

.bahagian-left{

display:flex;
align-items:center;

gap:16px;

}

.bahagian-badge{

width:42px;
height:42px;

border-radius:14px;

display:flex;
align-items:center;
justify-content:center;

background:
linear-gradient(
135deg,
#1570EF,
#175CD3
);

color:white;

font-weight:700;

font-size:18px;

}

.bahagian-left h3{

font-size:22px;
font-weight:700;

margin:0;

color:#0F172A;

}

.bahagian-left p{

margin:4px 0 0 0;

font-size:14px;

color:#64748B;

}

.bahagian-icon{

width:42px;
height:42px;

border-radius:12px;

display:flex;
align-items:center;
justify-content:center;

background:#F8FAFC;

position:relative;

}

.plus-icon,
.minus-icon{

position:absolute;

transition:0.25s;

color:#2563EB;

}

.plus-icon{

opacity:0;
transform:scale(0.7);

}

.harga-card{
    background:#ffffff;

    border:1px solid #e2e8f0;
    border-radius:32px;

    padding:60px;

    box-shadow:
    0 20px 50px rgba(15,23,42,.04);

    overflow:hidden;
}

.harga-card h2{
    font-size:42px;
    font-weight:700;
    text-align: center;
    margin:0 0 32px 0;

    color:#0f172a;

    letter-spacing:-1px;
}

.harga-item{
    display:flex-start;
    justify-content:space-between;
    align-items:center;
    width: 70%;
    padding:22px 26px;
    margin:0 auto 14px auto;
    background:#f1f5f9; /* grey lebih pekat */

    border:1px solid #cbd5e1;

    border-radius:20px;

    box-shadow:
    0 4px 12px rgba(15,23,42,0.04),
    0 12px 24px rgba(15,23,42,0.06);

    transition:.25s ease;
}

.harga-item:hover{
    transform:translateY(-2px);

    border-color:#dbeafe;

    box-shadow:
    0 12px 30px rgba(37,99,235,.08);
}

.harga-item span{
    font-size:30px;
    font-weight:600;

    color:#334155;
}

.harga-item strong{
    font-size:28px;
    font-weight:800;

    color:#2563eb;
}

.bahagian-header.collapsed .plus-icon{

opacity:1;
transform:scale(1);

}

.bahagian-header.collapsed .minus-icon{

opacity:0;
transform:scale(0.7);

}

.site-canvas{
    width:1800px !important;
    margin:50px auto !important; /* asal 100px */
    left:auto !important;
    transform:none !important;
    box-shadow:
0 4px 12px rgba(15,23,42,0.04),
0 12px 24px rgba(15,23,42,0.06);
}

.payment-wrapper{
    

    display:grid !important;
    grid-template-columns:800px 1fr !important;
}