
body { margin:0; font-family: 'Segoe UI', sans-serif; background:#eaf2fb; }
.mobile-frame {
max-width:430px;
margin:auto;
min-height:100vh;
background:#f4f8fc;
position:relative;
overflow:hidden;
}
.app-bg{
    top:-20;
    padding:0;
}
.top-bar {
display:flex;
justify-content:space-between;
padding:10px;
align-items:center;
background:linear-gradient(180deg,#0f5ea8,#0072ff);
color:white;
}

.logo { font-weight:bold; }

.banner { margin:15px; border-radius:0px; overflow:hidden; }
.banner-slide {
background:linear-gradient(90deg,#0f5ea8,#00c6ff);
color:white;
display:flex;
align-items:center;
justify-content:center;
height:120px;
font-weight:bold;
}

.quick-menu {
display:flex;
justify-content:space-around;
margin:15px;
background:white;
padding:15px;
border-radius:20px;
box-shadow:0 5px 15px rgba(0,0,0,0.08);
}

.quick-item {
display:flex;
flex-direction:column;
align-items:center;
font-size:14px;
}

.primary-btn {
width:90%;
margin:20px auto;
display:block;
padding:15px;
border:none;
border-radius:30px;
background:linear-gradient(90deg,#0f5ea8,#0072ff);
color:white;
font-weight:bold;
}

.header-gradient {
background:linear-gradient(180deg,#0f5ea8,#0072ff);
color:white;
padding:10px 0px;
border-bottom-left-radius:0px;
border-bottom-right-radius:0px;
}

.account-card {
background:linear-gradient(90deg,#0f5ea8,#00c6ff);
margin: -40px 15px 15px 15px;
padding:20px;
border-radius:20px;
color:white;
}

.saldo-row {
display:flex;
justify-content:space-between;
align-items:center;
}

.mutasi-link { margin-top:10px; font-size:14px; }

.promo-card {
background:white;
padding:15px;
border-radius:15px;
/*box-shadow:0 5px 15px rgba(0,0,0,0.08);*/
}

.menu-grid {
display:grid;
grid-template-columns:repeat(4,1fr);
gap:15px;
margin:15px;
}

.menu-item {
background:solid white;
color:white;
padding:8px 8px;
border-radius:0px;
text-align:center;
box-shadow:0 5px 15px rgba(0,0,0,0.08);
display:flex;
flex-direction:column;
align-items:center;
}

.nfc-card {
background:white;
margin:15px;
padding:20px;
border-radius:20px;
box-shadow:0 5px 15px rgba(0,0,0,0.08);
text-align:center;
}

.bottom-nav {
position:fixed;
bottom:0;
max-width:430px;
width:100%;
background:#0f5ea8;
color:white;
display:flex;
justify-content:space-around;
padding:10px 0;
}

.bottom-nav div {
display:flex;
flex-direction:column;
align-items:center;
font-size:12px;
}

.qr-btn {
background:#00c6ff;
width:60px;
height:60px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
margin-top:-30px;
font-size:50px;
color:white;
}

/*///////*/

