/* Somiti Manager v4.2 PRO FINAL - frontend layout fix
   Old PHP/database/admin code preserved. This file only fixes frontend dashboard/payment layout. */

.sm-portal, .sm-portal * { box-sizing: border-box; }
.sm-portal { font-family: Inter, Arial, sans-serif; color:#06183a; }

/* Main member app layout */
.sm-member-app.sm-user-window { max-width: 1180px; margin: 24px auto; padding: 0 14px; }
.sm-member-app .sm-app-shell {
    display: grid !important;
    grid-template-columns: 230px minmax(0, 1fr) !important;
    gap: 16px !important;
    align-items: stretch !important;
    width: 100% !important;
    min-height: 560px;
    background: #f4f7fc;
    border: 1px solid #d9e6f7;
    border-radius: 14px;
    padding: 14px;
    overflow: visible !important;
}
.sm-member-app .sm-app-sidebar {
    width: 100% !important;
    min-width: 0 !important;
    position: static !important;
    background:#fff;
    border:1px solid #d8e5f6;
    border-radius:12px;
    padding:18px 12px;
    display:flex;
    flex-direction:column;
    box-shadow:0 12px 26px rgba(15,23,42,.05);
}
.sm-member-app .sm-app-content {
    min-width: 0 !important;
    width: 100% !important;
    background:#fff;
    border:1px solid #d8e5f6;
    border-radius:12px;
    padding:20px;
    box-shadow:0 12px 26px rgba(15,23,42,.05);
    overflow: hidden;
}

/* Profile/sidebar */
.sm-member-app .sm-app-profile { text-align:center; padding-bottom:16px; border-bottom:1px dashed #cbd5e1; margin-bottom:14px; }
.sm-member-app .sm-app-profile img, .sm-member-app .sm-big-avatar { width:72px !important; height:72px !important; border-radius:50%; object-fit:cover; margin:0 auto 10px; display:flex; align-items:center; justify-content:center; }
.sm-member-app .sm-app-profile h3 { font-size:14px; margin:7px 0 7px; color:#06183a; font-weight:700; }
.sm-member-app .sm-member-badge { display:inline-block; font-size:10px; color:#0f2a5f; background:#f8fbff; border:1px solid #cfe0ff; border-radius:7px; padding:4px 8px; font-weight:800; }
.sm-member-app .sm-tab-nav { display:flex !important; flex-direction:column !important; gap:8px; margin:0 0 14px; }
.sm-member-app .sm-tab-nav button {
    width:100% !important; text-align:left; border:0; border-radius:8px; padding:11px 12px;
    color:#0f2a5f; background:transparent; font-size:13px; font-weight:800; cursor:pointer;
}
.sm-member-app .sm-tab-nav button.active, .sm-member-app .sm-tab-nav button:hover { background:linear-gradient(135deg,#5b55f3,#7c3aed); color:#fff; box-shadow:0 8px 18px rgba(91,85,243,.22); }
.sm-member-app .sm-logout { width:100%; margin-top:auto; border:0; border-radius:9px; padding:11px 12px; background:#ef4444!important; color:#fff!important; font-weight:900; cursor:pointer; }

/* Tabs */
.sm-member-app .sm-tab-panel { display:none !important; width:100% !important; min-width:0 !important; }
.sm-member-app .sm-tab-panel.active { display:block !important; }
.sm-member-app .sm-dash-title, .sm-member-app .sm-profile-title { display:flex; align-items:center; justify-content:space-between; gap:14px; margin:0 0 16px; }
.sm-member-app .sm-dash-title h2, .sm-member-app .sm-profile-title h3 { margin:0; font-size:24px; line-height:1.25; }
.sm-member-app .sm-dash-title span, .sm-member-app .sm-profile-title span { background:#673de6; color:#fff; border-radius:999px; padding:8px 13px; font-weight:900; }

/* Dashboard cards - prevents overlapping */
.sm-member-app .sm-front-cards {
    display:grid !important;
    grid-template-columns: repeat(4, minmax(150px, 1fr)) !important;
    gap:14px !important;
    width:100% !important;
    margin:0 !important;
    align-items:stretch !important;
}
.sm-member-app .sm-front-cards > div {
    width:auto !important; min-width:0 !important; max-width:none !important;
    position:static !important; float:none !important; clear:none !important;
    background:#fff; border:1px solid #dfe8f6; border-radius:12px; padding:18px 16px;
    box-shadow:0 10px 24px rgba(15,23,42,.06); overflow:hidden;
}
.sm-member-app .sm-front-cards small { display:block; color:#65758f; font-size:11px; font-weight:900; text-transform:uppercase; letter-spacing:.35px; margin-bottom:9px; white-space:normal; }
.sm-member-app .sm-front-cards b { display:block; color:#06183a; font-size:22px; line-height:1.25; word-break:break-word; white-space:normal; }

/* Payment page */
.sm-member-app .sm-payment-window { display:grid !important; grid-template-columns:minmax(280px, .9fr) minmax(0, 1.1fr) !important; gap:16px !important; align-items:start !important; }
.sm-member-app .sm-payment-form { display:grid !important; grid-template-columns:1fr 1fr !important; gap:12px !important; background:#fff; }
.sm-member-app .sm-payment-form label { display:flex; flex-direction:column; gap:6px; font-weight:800; color:#172033; }
.sm-member-app .sm-payment-form input,
.sm-member-app .sm-payment-form select,
.sm-member-app .sm-payment-form textarea { width:100%; max-width:100%; border:1px solid #cbd5e1; border-radius:10px; padding:10px 12px; background:#fff; }
.sm-member-app .sm-payment-form textarea { min-height:78px; }
.sm-member-app .sm-payment-form button { grid-column:1/-1; border:0; border-radius:10px; padding:11px 15px; background:#4f46e5; color:#fff; font-weight:900; cursor:pointer; }
.sm-member-app .sm-payment-preview { min-width:0; overflow-x:auto; background:#fff; border:1px solid #dfe8f6; border-radius:14px; padding:16px; }
.sm-member-app .sm-payment-preview table { width:100%; min-width:660px; border-collapse:collapse; }
.sm-member-app .sm-payment-preview th,
.sm-member-app .sm-payment-preview td { padding:10px; border-bottom:1px solid #e5e7eb; text-align:left; vertical-align:middle; }
.sm-member-app .sm-payment-preview th { background:#f8fafc; font-weight:900; }
.sm-member-app .button { display:inline-block; border-radius:8px; padding:7px 10px; background:#eef2ff; color:#4338ca; text-decoration:none; font-weight:800; border:1px solid #c7d2fe; }

/* Status badges */
.sm-status { display:inline-block; border-radius:999px; padding:5px 9px; font-size:11px; font-weight:900; }
.sm-status-approved { background:#dcfce7; color:#166534; }
.sm-status-pending { background:#fef3c7; color:#92400e; }
.sm-status-rejected { background:#fee2e2; color:#991b1b; }

/* Receipt print popup/page */
.sm-receipt-pro { margin:16px auto; }
.sm-print-receipt-btn { display:inline-block; margin:10px 0; border:0; border-radius:9px; padding:10px 14px; background:#111827; color:#fff; font-weight:900; cursor:pointer; }

@media (max-width: 1050px) {
    .sm-member-app .sm-front-cards { grid-template-columns: repeat(2, minmax(150px, 1fr)) !important; }
    .sm-member-app .sm-payment-window { grid-template-columns:1fr !important; }
}
@media (max-width: 760px) {
    .sm-member-app .sm-app-shell { grid-template-columns:1fr !important; }
    .sm-member-app .sm-app-content { padding:14px; }
    .sm-member-app .sm-payment-form { grid-template-columns:1fr !important; }
}
@media (max-width: 480px) {
    .sm-member-app .sm-front-cards { grid-template-columns:1fr !important; }
    .sm-member-app .sm-dash-title, .sm-member-app .sm-profile-title { align-items:flex-start; flex-direction:column; }
}

/* v4.3 Payment History section fix */
.sm-tab-nav button[data-tab="history"]{display:block;}
.sm-history-card{background:#fff;border:1px solid #dbe7fb;border-radius:16px;padding:18px;box-shadow:0 14px 35px rgba(15,23,42,.06);overflow-x:auto;}
.sm-history-table{min-width:720px;}
.sm-history-table .button,.sm-receipt-popup{background:#4f46e5!important;color:#fff!important;border:0!important;border-radius:8px!important;padding:7px 12px!important;text-decoration:none!important;display:inline-block;line-height:1.2!important;}
@media print{.sm-member-app .sm-app-shell,.sm-member-app .sm-front-notice,.sm-print-receipt-btn{display:none!important}.sm-portal.sm-user-window{box-shadow:none!important;border:0!important;background:#fff!important}}


/* ===== v4.5 Next Upgrade: Payment History Auto-Fit + Clean Receipt Popup ===== */
.sm-history-card{width:100%;overflow-x:auto;background:#fff;border-radius:14px;padding:14px;box-shadow:0 10px 28px rgba(15,23,42,.06);}
.sm-history-card .sm-history-table,
.sm-history-table,
.sm-payment-preview table{width:100%!important;max-width:100%;border-collapse:collapse!important;font-size:12px!important;table-layout:auto!important;}
.sm-history-card .sm-history-table th,
.sm-history-card .sm-history-table td,
.sm-history-table th,.sm-history-table td,
.sm-payment-preview table th,.sm-payment-preview table td{padding:7px 8px!important;white-space:nowrap!important;line-height:1.25!important;vertical-align:middle!important;}
.sm-history-table td,.sm-payment-preview table td{overflow:hidden!important;text-overflow:ellipsis!important;}
.sm-history-table th,.sm-payment-preview table th{font-size:11px!important;text-transform:uppercase;letter-spacing:.025em;color:#475569;}
.sm-history-table .button,.sm-payment-preview .button{font-size:11px!important;padding:4px 8px!important;min-height:unset!important;border-radius:7px!important;}
.sm-payment-preview{overflow-x:auto!important;}
.sm-receipt-popup{white-space:nowrap!important;}
@media(max-width:768px){.sm-history-table,.sm-payment-preview table{font-size:10.5px!important}.sm-history-table th,.sm-history-table td,.sm-payment-preview table th,.sm-payment-preview table td{padding:5px 6px!important}.sm-history-card{padding:8px!important}}
@media print{body>*:not(.sm-clean-receipt-page){display:none!important}.sm-clean-receipt-page{display:block!important}.sm-clean-receipt-actions,.sm-print-receipt-btn{display:none!important}}

/* v4.6 requested cleanup: compact frontend payment tables */
.sm-member-app .sm-payment-preview table,
.sm-member-app .sm-history-table {
    width: 100%;
    font-size: 11px !important;
    table-layout: auto;
}
.sm-member-app .sm-payment-preview th,
.sm-member-app .sm-payment-preview td,
.sm-member-app .sm-history-table th,
.sm-member-app .sm-history-table td {
    padding: 5px 6px !important;
    white-space: nowrap;
    vertical-align: middle;
}
.sm-member-app .sm-payment-preview td,
.sm-member-app .sm-history-table td {
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 140px;
}
.sm-member-app .sm-history-table .button,
.sm-member-app .sm-payment-preview .button {
    font-size: 10px !important;
    padding: 2px 7px !important;
    line-height: 1.6 !important;
    min-height: auto !important;
}
@media (max-width: 768px){
    .sm-member-app .sm-payment-preview,
    .sm-member-app .sm-history-card { overflow-x: auto; }
    .sm-member-app .sm-payment-preview table,
    .sm-member-app .sm-history-table { font-size: 10px !important; min-width: 620px; }
}


/* v6.2 frontend role section fixes */
.sm-member-ops-form input,
.sm-member-ops-form select,
.sm-member-ops-form textarea{
    pointer-events:auto!important;
    user-select:auto!important;
    position:relative!important;
    z-index:5!important;
    background:#fff!important;
    color:#0f172a!important;
    opacity:1!important;
}
.sm-member-ops-form .sm-money-input{
    -moz-appearance:textfield;
    appearance:textfield;
}
.sm-member-ops-form .sm-money-input::-webkit-outer-spin-button,
.sm-member-ops-form .sm-money-input::-webkit-inner-spin-button{
    opacity:1!important;
    pointer-events:auto!important;
}
.sm-profile-title > div > p,
.sm-profile-title > span{
    display:none!important;
}
.sm-profile-title{
    min-height:auto!important;
    padding:16px 18px!important;
    display:block!important;
}
.sm-profile-title h3{
    margin:0!important;
}


/* v6.3 collect payment input hard fix */
.sm-member-ops-form,
.sm-member-ops-form label,
.sm-member-ops-form input,
.sm-member-ops-form select,
.sm-member-ops-form textarea{
    transform:none!important;
    filter:none!important;
}
.sm-member-ops-form input[name="amount"]{
    pointer-events:auto!important;
    user-select:text!important;
    -webkit-user-select:text!important;
    cursor:text!important;
    z-index:999!important;
    position:relative!important;
    background:#fff!important;
    color:#111827!important;
    caret-color:#111827!important;
}
.sm-member-ops-form label:before,
.sm-member-ops-form label:after{
    display:none!important;
    content:none!important;
    pointer-events:none!important;
}


/* v6.4 amount input global unlock */
input[name="amount"],
input.sm-money-input,
.sm-payment-form input[name="amount"],
.sm-accounting-form input[name="amount"],
.sm-member-ops-form input[name="amount"],
.sm-form input[name="amount"],
.sm-form-modal input[name="amount"]{
    pointer-events:auto!important;
    user-select:text!important;
    -webkit-user-select:text!important;
    cursor:text!important;
    position:relative!important;
    z-index:9999!important;
    background:#fff!important;
    color:#0f172a!important;
    caret-color:#0f172a!important;
    opacity:1!important;
    visibility:visible!important;
    transform:none!important;
    filter:none!important;
}
label:has(input[name="amount"]):before,
label:has(input[name="amount"]):after{
    display:none!important;
    pointer-events:none!important;
    content:none!important;
}
.sm-front-accounting-groups{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.sm-front-group-card{background:#fff;border:1px solid #d8e4f4;border-radius:16px;padding:18px;box-shadow:0 10px 26px rgba(15,23,42,.06);}
.sm-front-group-card h3{margin:0 0 12px;font-size:18px;color:#0f172a;}
.sm-front-group-card p{display:flex;justify-content:space-between;gap:12px;margin:8px 0;padding:9px 10px;border-radius:12px;background:#f8fafc;}
.sm-front-group-card span{font-weight:800;color:#64748b;}
.sm-front-group-card b{font-weight:900;color:#0f172a;}
@media(max-width:768px){.sm-front-accounting-groups{grid-template-columns:1fr;}}


/* v6.5 frontend backend-like access sections */
.sm-access-note{
    margin-top:14px;
    padding:12px 14px;
    border-radius:14px;
    background:#eef2ff;
    color:#1e1b4b;
    border:1px solid #c7d2fe;
    font-weight:800;
}
.sm-tab-panel[data-panel="somiti_dash_ops"].active,
.sm-tab-panel[data-panel="accounting_view_ops"].active,
.sm-tab-panel[data-panel="due_list_ops"].active{
    display:block!important;
    visibility:visible!important;
    opacity:1!important;
}
.sm-front-grouped-cards{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px!important;
}
.sm-front-accounting-groups{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:16px!important;
}
.sm-front-group-card{
    background:#fff!important;
    border:1px solid #d8e4f4!important;
    border-radius:18px!important;
    padding:18px!important;
    box-shadow:0 10px 26px rgba(15,23,42,.06)!important;
    border-top:4px solid #4f46e5!important;
}
.sm-front-group-card h3{
    margin:0 0 14px!important;
    font-size:19px!important;
    font-weight:900!important;
    color:#061633!important;
}
.sm-front-group-card p{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:10px!important;
    margin:8px 0!important;
    padding:10px 12px!important;
    background:#f8fafc!important;
    border:1px solid #edf2f7!important;
    border-radius:12px!important;
}
.sm-front-group-card span{font-weight:900!important;color:#64748b!important;}
.sm-front-group-card b{font-weight:950!important;color:#0f172a!important;font-size:16px!important;}
.sm-history-card table{width:100%!important;}
@media(max-width:900px){
    .sm-front-grouped-cards,.sm-front-accounting-groups{grid-template-columns:1fr!important;}
}


/* v7.3 frontend login only + forced credential change */
.sm-auth-grid-login-only{
    max-width:900px;
    margin:0 auto;
    grid-template-columns:1fr 1fr!important;
}
.sm-login-only-page .sm-auth-card,
.sm-force-change-page .sm-auth-card{
    border-radius:18px;
}
.sm-auth-hint{
    margin-top:12px;
    background:#fff7ed;
    border:1px solid #fed7aa;
    color:#7c2d12;
    border-radius:12px;
    padding:10px 12px;
    font-weight:700;
}
@media(max-width:768px){.sm-auth-grid-login-only{grid-template-columns:1fr!important;}}


/* v7.4 Professional Member Login */
.sm-login-pro-page{
    max-width:1100px!important;
    margin:30px auto!important;
    padding:0 16px!important;
    font-family:Inter, Arial, sans-serif!important;
}
.sm-login-notice{
    max-width:980px;
    margin:0 auto 14px!important;
    border-radius:14px!important;
}
.sm-login-pro-card{
    max-width:980px;
    margin:0 auto;
    min-height:560px;
    background:#fff;
    border:1px solid #dbe7fb;
    border-radius:28px;
    overflow:hidden;
    display:grid;
    grid-template-columns:1.05fr .95fr;
    box-shadow:0 26px 70px rgba(46,61,112,.16);
}
.sm-login-form-side{
    padding:44px 48px;
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
}
.sm-login-brand{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:30px;
}
.sm-login-logo{
    width:52px;
    height:52px;
    border-radius:18px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#7648ff,#4b28d8);
    color:#fff;
    font-weight:900;
    box-shadow:0 12px 24px rgba(91,54,220,.28);
}
.sm-login-brand h2{
    margin:0!important;
    font-size:28px!important;
    line-height:1.15!important;
    color:#08152f!important;
    font-weight:900!important;
}
.sm-login-brand p{
    margin:6px 0 0!important;
    color:#64748b!important;
    font-size:14px!important;
}
.sm-pro-login-form{
    display:grid!important;
    gap:18px!important;
}
.sm-pro-login-form label{
    display:block!important;
    font-weight:800!important;
    color:#20304d!important;
    font-size:13px!important;
}
.sm-pro-login-form label > span{
    display:block!important;
    margin-bottom:8px!important;
}
.sm-input-icon{
    display:flex!important;
    align-items:center!important;
    gap:10px!important;
    background:#f7f9ff!important;
    border:1px solid #d7e2f5!important;
    border-radius:999px!important;
    padding:0 16px!important;
    height:54px!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8)!important;
    transition:.16s ease!important;
}
.sm-input-icon:focus-within{
    border-color:#7c3aed!important;
    box-shadow:0 0 0 4px rgba(124,58,237,.12)!important;
    background:#fff!important;
}
.sm-input-icon span{
    color:#6d43ee!important;
    font-size:16px!important;
    width:22px!important;
    text-align:center!important;
}
.sm-input-icon input{
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    outline:0!important;
    padding:0!important;
    min-height:52px!important;
    width:100%!important;
    color:#0f172a!important;
    font-weight:700!important;
}
.sm-login-row{
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:12px!important;
    font-size:13px!important;
    color:#64748b!important;
}
.sm-login-row a{
    color:#6d43ee!important;
    text-decoration:none!important;
    font-weight:800!important;
}
.sm-remember{
    display:flex!important;
    align-items:center!important;
    gap:7px!important;
    margin:0!important;
    font-size:13px!important;
    color:#64748b!important;
}
.sm-remember input{
    width:auto!important;
    min-height:auto!important;
}
.sm-pro-login-form button,
.sm-pro-reset button,
.sm-force-change-page .sm-auth-form button{
    border:0!important;
    min-height:52px!important;
    border-radius:999px!important;
    background:linear-gradient(90deg,#7c3aed,#4f46e5)!important;
    color:#fff!important;
    font-weight:900!important;
    letter-spacing:.03em!important;
    cursor:pointer!important;
    box-shadow:0 14px 28px rgba(79,70,229,.28)!important;
}
.sm-temp-register-box{
    margin-top:28px;
    padding:18px 20px;
    border:1px solid #d9e2ef;
    border-radius:18px;
    background:#fff;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
}
.sm-temp-register-box h3{
    margin:0 0 6px!important;
    color:#0f172a!important;
    font-size:17px!important;
    font-weight:900!important;
    text-transform:uppercase!important;
}
.sm-temp-register-box p{
    margin:0!important;
    color:#64748b!important;
    font-size:13px!important;
    line-height:1.5!important;
}
.sm-phone-icon{
    width:54px;
    height:68px;
    border:2px solid #22c55e;
    border-radius:10px;
    flex:0 0 auto;
    position:relative;
}
.sm-phone-icon:before{
    content:"";
    position:absolute;
    left:50%;
    top:6px;
    width:14px;
    height:2px;
    background:#22c55e;
    transform:translateX(-50%);
    border-radius:4px;
}
.sm-phone-icon:after{
    content:"";
    position:absolute;
    left:50%;
    bottom:6px;
    width:7px;
    height:7px;
    border:1px solid #22c55e;
    border-radius:50%;
    transform:translateX(-50%);
}
.sm-login-welcome-side{
    position:relative;
    padding:56px 44px;
    background:linear-gradient(155deg,#a855f7 0%,#6d28d9 44%,#312eeb 100%);
    color:#fff;
    display:flex;
    flex-direction:column;
    justify-content:center;
    text-align:center;
    overflow:hidden;
}
.sm-login-welcome-side:before{
    content:"";
    position:absolute;
    width:280px;
    height:280px;
    right:-130px;
    top:-90px;
    border-radius:50%;
    background:rgba(255,255,255,.13);
}
.sm-login-welcome-side:after{
    content:"";
    position:absolute;
    width:220px;
    height:220px;
    left:-120px;
    bottom:-80px;
    border-radius:50%;
    background:rgba(255,255,255,.10);
}
.sm-login-welcome-side h2{
    position:relative;
    z-index:1;
    margin:0 0 16px!important;
    color:#fff!important;
    font-size:34px!important;
    font-weight:900!important;
}
.sm-login-welcome-side p{
    position:relative;
    z-index:1;
    color:rgba(255,255,255,.78)!important;
    font-size:15px!important;
    line-height:1.7!important;
    max-width:330px;
    margin:0 auto 26px!important;
}
.sm-welcome-points{
    position:relative;
    z-index:1;
    display:grid;
    gap:10px;
    max-width:270px;
    margin:0 auto;
}
.sm-welcome-points span{
    border:1px solid rgba(255,255,255,.22);
    background:rgba(255,255,255,.12);
    border-radius:999px;
    padding:10px 14px;
    font-weight:800;
    color:#fff;
    font-size:13px;
}
.sm-pro-reset{
    max-width:980px!important;
    margin:18px auto 0!important;
    border-radius:22px!important;
    box-shadow:0 18px 45px rgba(46,61,112,.10)!important;
    border:1px solid #dbe7fb!important;
}
@media(max-width:900px){
    .sm-login-pro-card{grid-template-columns:1fr;}
    .sm-login-welcome-side{min-height:280px;padding:42px 28px;}
    .sm-login-form-side{padding:34px 24px;}
}
@media(max-width:560px){
    .sm-login-brand{align-items:flex-start;}
    .sm-login-brand h2{font-size:24px!important;}
    .sm-login-row{align-items:flex-start;flex-direction:column;}
    .sm-temp-register-box{align-items:flex-start;}
}


/* v7.5 Forgot password popup */
.sm-pro-reset{display:none!important;}
.sm-forgot-modal{
    position:fixed;
    inset:0;
    z-index:999999;
    display:none;
    align-items:center;
    justify-content:center;
    padding:18px;
}
.sm-forgot-modal.active{display:flex!important;}
.sm-forgot-backdrop{
    position:absolute;
    inset:0;
    background:rgba(15,23,42,.58);
    backdrop-filter:blur(4px);
}
.sm-forgot-box{
    position:relative;
    width:min(460px, 94vw);
    background:#fff;
    border:1px solid #dbe7fb;
    border-radius:24px;
    padding:30px;
    box-shadow:0 28px 80px rgba(15,23,42,.28);
    animation:smForgotPop .18s ease-out;
}
@keyframes smForgotPop{
    from{transform:translateY(14px) scale(.97);opacity:0;}
    to{transform:translateY(0) scale(1);opacity:1;}
}
.sm-forgot-x{
    position:absolute;
    right:14px;
    top:12px;
    width:34px;
    height:34px;
    border:0;
    border-radius:50%;
    background:#f1f5f9;
    color:#0f172a;
    font-size:22px;
    line-height:1;
    cursor:pointer;
    font-weight:900;
}
.sm-forgot-icon{
    width:58px;
    height:58px;
    border-radius:18px;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:14px;
    background:linear-gradient(135deg,#ede9fe,#dbeafe);
    font-size:26px;
}
.sm-forgot-box h3{
    margin:0 0 8px!important;
    font-size:24px!important;
    font-weight:900!important;
    color:#08152f!important;
}
.sm-forgot-box p{
    margin:0 0 18px!important;
    color:#64748b!important;
    line-height:1.6!important;
}
.sm-forgot-box .sm-auth-form{
    display:grid!important;
    gap:14px!important;
}
.sm-forgot-box input{
    width:100%!important;
    min-height:48px!important;
    border:1px solid #d7e2f5!important;
    border-radius:12px!important;
    padding:10px 13px!important;
    background:#f8fbff!important;
}
.sm-forgot-box button[type="submit"]{
    border:0!important;
    min-height:50px!important;
    border-radius:999px!important;
    background:linear-gradient(90deg,#7c3aed,#4f46e5)!important;
    color:#fff!important;
    font-weight:900!important;
    cursor:pointer!important;
    box-shadow:0 14px 28px rgba(79,70,229,.24)!important;
}
body.sm-forgot-opened{overflow:hidden!important;}

/* v7.6 Mobile responsive frontend dashboard */
@media (max-width: 782px) {
    body:has(.sm-member-app) {
        padding-bottom: 92px !important;
        background:#f8fbff !important;
    }
    .sm-member-app, .sm-user-window, .sm-portal {
        width:100% !important;
        max-width:100% !important;
        margin:0 !important;
        padding:0 !important;
    }
    .sm-app-shell {
        display:block !important;
        width:100% !important;
        max-width:100% !important;
        border:0 !important;
        border-radius:0 !important;
        box-shadow:none !important;
        background:#f8fbff !important;
    }
    .sm-app-sidebar {
        width:100% !important;
        max-width:100% !important;
        min-height:auto !important;
        position:relative !important;
        border:0 !important;
        border-radius:0 !important;
        box-shadow:none !important;
        background:#fff !important;
        padding:22px 18px 14px !important;
        margin:0 !important;
        border-bottom:1px solid #e5edf7 !important;
    }
    .sm-app-profile {
        display:flex !important;
        align-items:center !important;
        gap:12px !important;
        text-align:left !important;
        padding:0 !important;
        margin:0 !important;
    }
    .sm-app-profile img, .sm-big-avatar {
        width:50px !important;
        height:50px !important;
        min-width:50px !important;
        border-radius:50% !important;
        font-size:20px !important;
        margin:0 !important;
        box-shadow:0 8px 18px rgba(79,70,229,.18) !important;
    }
    .sm-app-profile h3 {
        margin:0 0 4px !important;
        font-size:17px !important;
        line-height:1.2 !important;
        font-weight:900 !important;
    }
    .sm-member-badge {
        display:inline-flex !important;
        margin:0 !important;
        font-size:11px !important;
        padding:3px 8px !important;
        border-radius:999px !important;
        background:#eef2ff !important;
        color:#334155 !important;
    }
    .sm-logout {
        position:absolute !important;
        right:18px !important;
        top:32px !important;
        width:44px !important;
        height:44px !important;
        min-height:44px !important;
        padding:0 !important;
        border-radius:50% !important;
        font-size:0 !important;
        background:#fff1f2 !important;
        border:1px solid #fecdd3 !important;
        box-shadow:0 12px 24px rgba(244,63,94,.16) !important;
    }
    .sm-logout:before {
        content:"↪" !important;
        font-size:24px !important;
        color:#ef4444 !important;
        font-weight:900 !important;
    }
    .sm-tab-nav {
        position:fixed !important;
        left:0 !important;
        right:0 !important;
        bottom:0 !important;
        z-index:99999 !important;
        display:grid !important;
        grid-template-columns:repeat(5, 1fr) !important;
        gap:0 !important;
        background:rgba(255,255,255,.96) !important;
        backdrop-filter:blur(12px) !important;
        border-top:1px solid #e5edf7 !important;
        box-shadow:0 -12px 36px rgba(15,23,42,.12) !important;
        padding:8px 8px 10px !important;
        margin:0 !important;
        overflow-x:auto !important;
        white-space:nowrap !important;
    }
    .sm-tab-nav button {
        display:flex !important;
        flex-direction:column !important;
        align-items:center !important;
        justify-content:center !important;
        gap:4px !important;
        min-width:68px !important;
        min-height:58px !important;
        padding:6px 4px !important;
        border:0 !important;
        border-radius:14px !important;
        background:transparent !important;
        color:#64748b !important;
        font-size:11px !important;
        font-weight:800 !important;
        box-shadow:none !important;
    }
    .sm-tab-nav button:before {
        content:"📊" !important;
        font-size:20px !important;
        line-height:1 !important;
    }
    .sm-tab-nav button[data-tab="payment"]:before,
    .sm-tab-nav button[data-tab="collect_ops"]:before { content:"💳" !important; }
    .sm-tab-nav button[data-tab="history"]:before { content:"📜" !important; }
    .sm-tab-nav button[data-tab="profile"]:before,
    .sm-tab-nav button[data-tab="bank"]:before,
    .sm-tab-nav button[data-tab="security"]:before { content:"👤" !important; }
    .sm-tab-nav button[data-tab="book_ops"]:before,
    .sm-tab-nav button[data-tab="accounting_view_ops"]:before { content:"📒" !important; }
    .sm-tab-nav button[data-tab="approve_ops"]:before { content:"✅" !important; }
    .sm-tab-nav button[data-tab="due_list_ops"]:before { content:"🧾" !important; }
    .sm-tab-nav button.active {
        color:#4f46e5 !important;
        background:#eef2ff !important;
    }
    .sm-app-content {
        width:100% !important;
        max-width:100% !important;
        padding:18px 14px 105px !important;
        margin:0 !important;
        background:#f8fbff !important;
    }
    .sm-tab-panel {
        border-radius:0 !important;
        padding:0 !important;
        box-shadow:none !important;
        background:transparent !important;
    }
    .sm-dash-title,
    .sm-profile-title {
        display:flex !important;
        align-items:center !important;
        justify-content:space-between !important;
        padding:0 2px 14px !important;
        margin:0 !important;
        background:transparent !important;
        border:0 !important;
    }
    .sm-dash-title h2,
    .sm-profile-title h3 {
        font-size:24px !important;
        font-weight:950 !important;
        margin:0 !important;
        color:#0f172a !important;
    }
    .sm-dash-title span {
        border-radius:999px !important;
        padding:8px 14px !important;
        font-size:13px !important;
        font-weight:900 !important;
        background:#eef2ff !important;
        color:#4f46e5 !important;
    }
    .sm-front-cards {
        display:grid !important;
        grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
        gap:12px !important;
        width:100% !important;
    }
    .sm-front-cards > div {
        min-height:112px !important;
        padding:16px 14px !important;
        border-radius:16px !important;
        background:#fff !important;
        border:1px solid #dbe7fb !important;
        box-shadow:0 12px 28px rgba(15,23,42,.06) !important;
        position:relative !important;
        overflow:hidden !important;
    }
    .sm-front-cards > div:after {
        content:"" !important;
        position:absolute !important;
        left:0 !important;
        right:0 !important;
        bottom:0 !important;
        height:4px !important;
        background:linear-gradient(90deg,#6366f1,#8b5cf6) !important;
    }
    .sm-front-cards > div:nth-child(3n):after {
        background:linear-gradient(90deg,#10b981,#14b8a6) !important;
    }
    .sm-front-cards > div:nth-child(4n):after {
        background:linear-gradient(90deg,#f59e0b,#f97316) !important;
    }
    .sm-front-cards small {
        font-size:11px !important;
        font-weight:900 !important;
        color:#64748b !important;
        letter-spacing:.04em !important;
    }
    .sm-front-cards b {
        display:block !important;
        margin-top:10px !important;
        font-size:22px !important;
        font-weight:950 !important;
        color:#0f172a !important;
        line-height:1.2 !important;
        word-break:break-word !important;
    }
    .sm-payment-window, .sm-profile-modern, .sm-front-accounting-groups, .sm-auth-grid, .sm-payment-form {
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:14px !important;
        width:100% !important;
    }
    .sm-payment-form, .sm-history-card, .sm-doc-card, .sm-profile-form-card, .sm-front-group-card {
        border-radius:16px !important;
        background:#fff !important;
        border:1px solid #dbe7fb !important;
        box-shadow:0 12px 28px rgba(15,23,42,.06) !important;
        padding:16px !important;
        overflow:auto !important;
    }
    .sm-payment-form input, .sm-payment-form select, .sm-payment-form textarea,
    .sm-edit-form input, .sm-edit-form select, .sm-edit-form textarea {
        min-height:44px !important;
        border-radius:12px !important;
        font-size:14px !important;
    }
    .sm-history-table, .sm-history-card table, .sm-table {
        font-size:12px !important;
        min-width:650px !important;
    }
    .sm-history-card {
        overflow-x:auto !important;
    }
}
@media (max-width:420px) {
    .sm-front-cards { gap:10px !important; }
    .sm-front-cards > div {
        min-height:102px !important;
        padding:14px 12px !important;
    }
    .sm-front-cards b { font-size:19px !important; }
    .sm-tab-nav button {
        min-width:62px !important;
        font-size:10px !important;
    }
}

/* v7.8 FINAL mobile app view fix */
@media (max-width:782px){
 html,body{width:100%!important;max-width:100%!important;overflow-x:hidden!important;background:#f6f9ff!important}
 body:has(.sm-member-app){padding-bottom:92px!important}
 .sm-member-app,.sm-user-window,.sm-portal,.sm-app-shell{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;border:0!important;border-radius:0!important;box-shadow:none!important;overflow:visible!important;background:#f6f9ff!important}
 .sm-app-sidebar{width:100%!important;max-width:100%!important;min-height:0!important;height:auto!important;position:relative!important;margin:0!important;padding:18px 22px 16px!important;border:0!important;border-radius:0!important;box-shadow:none!important;background:#fff!important;border-bottom:1px solid #e5edf7!important;overflow:visible!important}
 .sm-app-sidebar:before{content:"User Dashboard";display:block;font-size:30px;line-height:1.1;color:#0f172a;font-weight:950;margin:0 0 22px;letter-spacing:-.03em}
 .sm-app-profile{display:flex!important;align-items:center!important;gap:13px!important;text-align:left!important;margin:0!important;padding:0!important;border:0!important}
 .sm-app-profile img,.sm-big-avatar{width:52px!important;height:52px!important;min-width:52px!important;margin:0!important;border-radius:50%!important;font-size:20px!important;display:flex!important;align-items:center!important;justify-content:center!important;box-shadow:0 10px 22px rgba(79,70,229,.20)!important}
 .sm-app-profile h3{margin:0 0 4px!important;font-size:18px!important;line-height:1.2!important;color:#0f172a!important;font-weight:950!important}
 .sm-app-profile h3:after{content:" ✓";display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:6px;border-radius:50%;background:#1683ff;color:#fff;font-size:10px;vertical-align:middle}
 .sm-member-badge{display:block!important;margin:0!important;padding:0!important;border:0!important;background:transparent!important;color:#64748b!important;font-size:13px!important;font-weight:900!important}
 .sm-member-badge:before{content:"ID: "}
 .sm-logout{position:absolute!important;right:24px!important;bottom:22px!important;width:46px!important;height:46px!important;min-height:46px!important;padding:0!important;margin:0!important;border-radius:50%!important;font-size:0!important;background:#fff!important;border:0!important;box-shadow:0 14px 28px rgba(239,68,68,.16)!important}
 .sm-logout:before{content:"↪"!important;display:flex!important;align-items:center!important;justify-content:center!important;width:46px!important;height:46px!important;border-radius:50%!important;color:#ef4444!important;background:#fff1f2!important;font-size:24px!important;font-weight:900!important}
 .sm-app-content{width:100%!important;max-width:100%!important;margin:0!important;padding:24px 22px 112px!important;background:#f6f9ff!important;overflow:visible!important}
 .sm-tab-panel{background:transparent!important;border:0!important;box-shadow:none!important;padding:0!important;margin:0!important;border-radius:0!important;overflow:visible!important}
 .sm-dash-title,.sm-profile-title{display:flex!important;align-items:center!important;justify-content:space-between!important;margin:0 0 18px!important;padding:0!important;background:transparent!important;border:0!important}
 .sm-dash-title h2,.sm-profile-title h3{margin:0!important;font-size:24px!important;line-height:1.2!important;color:#0f172a!important;font-weight:950!important}
 .sm-dash-title span{font-size:13px!important;font-weight:900!important;padding:8px 14px!important;border-radius:999px!important;background:#fff!important;color:#334155!important;border:1px solid #dbe7fb!important;box-shadow:0 8px 18px rgba(15,23,42,.05)!important}
 .sm-front-cards{display:grid!important;grid-template-columns:1fr!important;gap:18px!important;width:100%!important;margin:0!important}
 .sm-front-cards>div{width:100%!important;min-height:124px!important;padding:26px 28px!important;border-radius:18px!important;background:#fff!important;border:1px solid #dbe7fb!important;box-shadow:0 14px 32px rgba(15,23,42,.07)!important;position:relative!important;overflow:hidden!important}
 .sm-front-cards>div:after{content:""!important;position:absolute!important;left:0!important;right:0!important;bottom:0!important;height:4px!important;background:linear-gradient(90deg,#6366f1,#8b5cf6)!important}
 .sm-front-cards>div:nth-child(3n):after{background:linear-gradient(90deg,#10b981,#14b8a6)!important}
 .sm-front-cards>div:nth-child(4n):after{background:linear-gradient(90deg,#f59e0b,#f97316)!important}
 .sm-front-cards small{display:block!important;color:#64748b!important;font-size:13px!important;font-weight:950!important;letter-spacing:.07em!important;text-transform:uppercase!important;margin:0 0 14px!important}
 .sm-front-cards b{display:block!important;color:#0f172a!important;font-size:30px!important;line-height:1.15!important;font-weight:950!important;letter-spacing:-.03em!important;word-break:break-word!important}
 .sm-app-sidebar .sm-tab-nav,.sm-tab-nav{position:fixed!important;left:0!important;right:0!important;bottom:0!important;z-index:999999!important;width:100%!important;max-width:100%!important;height:76px!important;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-around!important;gap:0!important;padding:7px 8px 8px!important;margin:0!important;background:rgba(255,255,255,.98)!important;backdrop-filter:blur(14px)!important;border-top:1px solid #e5edf7!important;box-shadow:0 -14px 38px rgba(15,23,42,.14)!important;overflow-x:auto!important;overflow-y:hidden!important;white-space:nowrap!important}
 .sm-tab-nav button{flex:0 0 72px!important;width:72px!important;max-width:72px!important;height:62px!important;min-height:62px!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:4px!important;padding:5px 2px!important;margin:0!important;border:0!important;border-radius:16px!important;background:transparent!important;box-shadow:none!important;color:#64748b!important;font-size:10px!important;font-weight:900!important;line-height:1.15!important;text-align:center!important}
 .sm-tab-nav button.active{background:#eef2ff!important;color:#4f46e5!important}
 .sm-tab-nav button:before{content:"📊"!important;display:block!important;font-size:20px!important;line-height:1!important;margin:0!important}
 .sm-tab-nav button[data-tab="payment"]:before,.sm-tab-nav button[data-tab="collect_ops"]:before{content:"💳"!important}
 .sm-tab-nav button[data-tab="history"]:before{content:"📜"!important}
 .sm-tab-nav button[data-tab="profile"]:before,.sm-tab-nav button[data-tab="bank"]:before,.sm-tab-nav button[data-tab="security"]:before{content:"👤"!important}
 .sm-tab-nav button[data-tab="book_ops"]:before,.sm-tab-nav button[data-tab="accounting_view_ops"]:before{content:"📒"!important}
 .sm-tab-nav button[data-tab="approve_ops"]:before{content:"✅"!important}
 .sm-tab-nav button[data-tab="due_list_ops"]:before{content:"🧾"!important}
 .sm-payment-window,.sm-profile-modern,.sm-front-accounting-groups,.sm-payment-form{display:grid!important;grid-template-columns:1fr!important;gap:14px!important;width:100%!important}
 .sm-payment-form,.sm-history-card,.sm-doc-card,.sm-profile-form-card,.sm-front-group-card{border-radius:18px!important;background:#fff!important;border:1px solid #dbe7fb!important;box-shadow:0 14px 32px rgba(15,23,42,.07)!important;padding:18px!important;overflow:auto!important}
 .sm-history-card table,.sm-history-table,.sm-table{min-width:650px!important;font-size:12px!important}
}
@media (max-width:420px){
 .sm-app-sidebar{padding:18px 18px 14px!important}
 .sm-app-sidebar:before{font-size:28px!important}
 .sm-app-content{padding:22px 16px 108px!important}
 .sm-front-cards>div{min-height:116px!important;padding:23px 24px!important}
 .sm-front-cards b{font-size:28px!important}
 .sm-tab-nav button{flex-basis:68px!important;width:68px!important;max-width:68px!important;font-size:10px!important}
}

/* v7.8.1 frontend member profile refinements */
.sm-member-app .sm-app-profile h3:after{content:none!important;display:none!important;}
.sm-member-app .sm-active-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:16px!important;height:16px!important;margin-right:6px!important;border-radius:50%!important;background:#16a34a!important;color:#fff!important;font-size:10px!important;font-weight:900!important;vertical-align:middle!important;}
.sm-member-app .sm-member-role-line{margin-top:3px!important;color:#64748b!important;font-size:13px!important;font-weight:800!important;line-height:1.2!important;text-transform:capitalize!important;}

/* v7.8.5 due status active icon colors */
.sm-member-app .sm-active-icon.sm-active-green{background:#16a34a!important;color:#fff!important;}
.sm-member-app .sm-active-icon.sm-active-yellow{background:#f59e0b!important;color:#fff!important;}
.sm-member-app .sm-active-icon.sm-active-red{background:#dc2626!important;color:#fff!important;}

/* v7.8.6 frontend dashboard/payment popup improvements */
.sm-front-card-button{border:1px solid #dbeafe;background:#fff;border-radius:14px;padding:14px;text-align:left;box-shadow:0 8px 24px rgba(15,23,42,.06);cursor:pointer;display:flex;flex-direction:column;gap:6px;color:inherit;font:inherit;min-height:86px}
.sm-front-card-button:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(15,23,42,.10)}
.sm-front-card-button small{font-size:11px;font-weight:800;letter-spacing:.04em;color:#64748b;text-transform:uppercase}
.sm-front-card-button b{font-size:22px;color:#0f172a;line-height:1.1}
.sm-front-card-button em{font-size:10px;color:#64748b;font-style:normal;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sm-mini-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:99999;display:none;align-items:center;justify-content:center;padding:16px}
.sm-mini-modal.active{display:flex}
.sm-mini-modal-box{background:#fff;border-radius:18px;padding:18px;max-width:850px;width:100%;max-height:86vh;overflow:auto;box-shadow:0 25px 80px rgba(0,0,0,.25);position:relative}
.sm-mini-close{position:absolute;right:12px;top:10px;border:0;background:#0f172a;color:#fff;border-radius:50%;width:30px;height:30px;font-size:20px;line-height:26px;cursor:pointer}
.sm-inline-resubmit{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.sm-inline-resubmit input,.sm-inline-resubmit select{max-width:115px;min-height:30px}
.sm-profile-password-box{margin-top:20px;border:1px solid #e5e7eb;border-radius:14px;padding:14px;background:#f8fafc}
@media print{.sm-app-sidebar,.sm-tab-nav,.sm-mini-close,.sm-open-mini-modal,.sm-dash-title,.sm-profile-title button{display:none!important}.sm-mini-modal.active{position:static;background:#fff;display:block}.sm-mini-modal-box{box-shadow:none;max-height:none}}

/* v7.9.2 inbox, due status and follow-up */
.sm-inbox-top{margin-left:auto;margin-right:12px;border:0;background:#f1f5ff;color:#4f46e5;border-radius:16px;width:48px;height:48px;font-size:22px;position:relative;cursor:pointer;font-weight:900}
.sm-inbox-top em,.sm-inbox-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-style:normal;margin-left:6px}
.sm-inbox-top em{position:absolute;top:-5px;right:-5px;margin:0}
.sm-inbox-list{display:grid;gap:12px}.sm-inbox-item{border:1px solid #dbeafe;background:#f8fbff;border-radius:16px;padding:14px}.sm-inbox-item div{display:flex;justify-content:space-between;gap:10px}.sm-inbox-item span{background:#e0e7ff;color:#3730a3;border-radius:999px;padding:4px 10px;font-weight:800;font-size:12px}.sm-inbox-item p{margin:10px 0 0;color:#0f172a}.sm-inbox-empty{border:1px dashed #cbd5e1;border-radius:16px;padding:18px;color:#64748b;text-align:center}
.sm-due-status-table .sm-due-row-paid{background:#ecfdf5!important}.sm-due-status-table .sm-due-row-due{background:#fff7ed!important}.sm-due-status-table .sm-due-row-advance{background:#eff6ff!important}.sm-status-paid{background:#bbf7d0!important;color:#065f46!important}.sm-status-due{background:#fed7aa!important;color:#9a3412!important}.sm-status-advance{background:#bfdbfe!important;color:#1e40af!important}.sm-followup-open{border-radius:10px!important;font-weight:800!important}.sm-mini-modal-box textarea{width:100%;min-height:130px}

/* v7.9.4 inbox/followup compact message + whatsapp */
.sm-inbox-item.sm-inbox-open{width:100%;text-align:left;cursor:pointer;border:1px solid #dbeafe;background:#f8fbff;border-radius:16px;padding:14px;display:block;color:inherit;font:inherit}
.sm-inbox-item.sm-inbox-open:hover{background:#eef6ff;box-shadow:0 10px 24px rgba(15,23,42,.08)}
.sm-inbox-item.sm-inbox-unread{border-color:#818cf8;background:#eef2ff}
.sm-inbox-full-message{white-space:pre-wrap;line-height:1.65;background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:14px;color:#0f172a;max-height:62vh;overflow:auto}
.sm-wa-button{background:#22c55e!important;border-color:#16a34a!important;color:#fff!important;font-weight:800!important;border-radius:10px!important;margin-left:6px!important}


/* v8.1.8 Professional Frontend Profile + Payment UI redesign */
.sm-member-app .sm-app-content{
    background:linear-gradient(180deg,#f8fbff 0%,#ffffff 55%)!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"],
.sm-member-app .sm-tab-panel[data-panel="payment"]{
    max-width:980px!important;
    margin:0 auto!important;
}
.sm-member-app .sm-profile-title{
    background:linear-gradient(135deg,#eef4ff,#ffffff)!important;
    border:1px solid #dbeafe!important;
    border-radius:20px!important;
    padding:18px 22px!important;
    margin-bottom:18px!important;
    box-shadow:0 14px 34px rgba(15,23,42,.06)!important;
}
.sm-member-app .sm-profile-title h3{
    font-size:24px!important;
    font-weight:950!important;
    color:#0f172a!important;
}
.sm-member-app .sm-profile-title h3:before{
    content:""!important;
    display:inline-block!important;
    width:10px!important;
    height:28px!important;
    border-radius:999px!important;
    background:linear-gradient(180deg,#4f46e5,#06b6d4)!important;
    vertical-align:middle!important;
    margin-right:10px!important;
}
.sm-member-app .sm-profile-modern{
    display:grid!important;
    grid-template-columns:180px 180px minmax(0,1fr)!important;
    gap:18px!important;
    align-items:stretch!important;
    width:100%!important;
}
.sm-member-app .sm-doc-card,
.sm-member-app .sm-profile-fields,
.sm-member-app .sm-bank-nominee-inside-profile,
.sm-member-app .sm-profile-password-box,
.sm-member-app .sm-payment-form{
    background:#ffffff!important;
    border:1px solid #dbe7fb!important;
    border-radius:22px!important;
    box-shadow:0 16px 42px rgba(15,23,42,.07)!important;
}
.sm-member-app .sm-doc-card{
    padding:16px!important;
    display:flex!important;
    flex-direction:column!important;
    gap:13px!important;
    justify-content:space-between!important;
    min-height:210px!important;
}
.sm-member-app .sm-doc-preview{
    min-height:128px!important;
    border:1px dashed #bcd4ff!important;
    border-radius:18px!important;
    background:linear-gradient(135deg,#f4f7ff,#eef6ff)!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    overflow:hidden!important;
}
.sm-member-app .sm-doc-preview img{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    border-radius:16px!important;
}
.sm-member-app .sm-doc-icon{
    width:58px!important;
    height:58px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    border-radius:20px!important;
    background:#e0e7ff!important;
    font-size:30px!important;
}
.sm-member-app .sm-file-button,
.sm-member-app .sm-edit-form button[type="submit"],
.sm-member-app .sm-payment-form button{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:46px!important;
    border:0!important;
    border-radius:14px!important;
    background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;
    color:#fff!important;
    font-size:13px!important;
    font-weight:950!important;
    letter-spacing:.01em!important;
    cursor:pointer!important;
    box-shadow:0 14px 26px rgba(79,70,229,.22)!important;
    padding:12px 18px!important;
    text-decoration:none!important;
}
.sm-member-app .sm-file-button input{display:none!important;}
.sm-member-app .sm-profile-fields{
    padding:18px!important;
    min-width:0!important;
}
.sm-member-app .sm-form-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:14px 16px!important;
    align-items:start!important;
}
.sm-member-app .sm-form-grid label,
.sm-member-app .sm-payment-form label{
    display:flex!important;
    flex-direction:column!important;
    gap:7px!important;
    margin:0!important;
    color:#24324b!important;
    font-size:12px!important;
    line-height:1.25!important;
    font-weight:900!important;
    letter-spacing:.01em!important;
}
.sm-member-app .sm-form-grid label.wide{grid-column:1/-1!important;}
.sm-member-app .sm-form-grid input,
.sm-member-app .sm-form-grid select,
.sm-member-app .sm-form-grid textarea,
.sm-member-app .sm-payment-form input,
.sm-member-app .sm-payment-form select,
.sm-member-app .sm-payment-form textarea,
.sm-member-app .sm-profile-password-box input{
    width:100%!important;
    max-width:100%!important;
    min-height:46px!important;
    border:1px solid #cfe0f7!important;
    border-radius:14px!important;
    background:#fbfdff!important;
    color:#0f172a!important;
    font-size:14px!important;
    font-weight:650!important;
    line-height:1.3!important;
    padding:11px 13px!important;
    outline:none!important;
    box-shadow:none!important;
    box-sizing:border-box!important;
}
.sm-member-app .sm-form-grid input:focus,
.sm-member-app .sm-form-grid textarea:focus,
.sm-member-app .sm-payment-form input:focus,
.sm-member-app .sm-payment-form textarea:focus,
.sm-member-app .sm-payment-form select:focus{
    border-color:#6366f1!important;
    background:#fff!important;
    box-shadow:0 0 0 4px rgba(99,102,241,.12)!important;
}
.sm-member-app .sm-form-grid textarea,
.sm-member-app .sm-payment-form textarea{min-height:92px!important;resize:vertical!important;}
.sm-member-app .sm-bank-nominee-inside-profile,
.sm-member-app .sm-profile-password-box{
    padding:20px!important;
    margin-top:18px!important;
    width:100%!important;
    max-width:none!important;
    box-sizing:border-box!important;
}
.sm-member-app .sm-bank-nominee-inside-profile h3,
.sm-member-app .sm-profile-password-box h3{
    margin:0 0 6px!important;
    color:#0f172a!important;
    font-size:20px!important;
    font-weight:950!important;
}
.sm-member-app .sm-bank-nominee-inside-profile h3:before{content:"🏦";margin-right:8px;}
.sm-member-app .sm-profile-password-box h3:before{content:"🔐";margin-right:8px;}
.sm-member-app .sm-bank-nominee-inside-profile p,
.sm-member-app .sm-profile-password-box p{
    margin:0 0 16px!important;
    color:#64748b!important;
    font-size:13px!important;
    font-weight:700!important;
}
.sm-member-app .sm-edit-form > button[type="submit"]{
    margin-top:16px!important;
    min-width:170px!important;
}
/* Payment Submit card */
.sm-member-app .sm-payment-window{
    display:block!important;
    width:100%!important;
}
.sm-member-app .sm-payment-form{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:16px!important;
    padding:22px!important;
    width:100%!important;
    max-width:760px!important;
    margin:0!important;
    position:relative!important;
    overflow:hidden!important;
}
.sm-member-app .sm-payment-form:before{
    content:"Payment Request"!important;
    grid-column:1/-1!important;
    display:flex!important;
    align-items:center!important;
    min-height:46px!important;
    padding:0 0 14px!important;
    margin:0 0 4px!important;
    border-bottom:1px solid #e6eefb!important;
    color:#0f172a!important;
    font-size:18px!important;
    font-weight:950!important;
}
.sm-member-app .sm-payment-form:after{
    content:"Fill your amount and reference, then submit for admin approval."!important;
    grid-column:1/-1!important;
    display:block!important;
    order:-1!important;
    color:#64748b!important;
    font-size:13px!important;
    font-weight:700!important;
    margin-bottom:-2px!important;
}
.sm-member-app .sm-payment-form label:nth-of-type(3),
.sm-member-app .sm-payment-form label:nth-of-type(4){grid-column:auto!important;}
.sm-member-app .sm-payment-form textarea{min-height:82px!important;}
.sm-member-app .sm-payment-form button{
    grid-column:1/-1!important;
    width:100%!important;
    margin-top:2px!important;
}
.sm-member-app .sm-payment-form button:before{content:"✓";margin-right:8px;font-size:16px;}
/* Standalone payment shortcode */
.sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:16px!important;
    background:#fff!important;
    border:1px solid #dbe7fb!important;
    border-radius:22px!important;
    box-shadow:0 16px 42px rgba(15,23,42,.07)!important;
    padding:22px!important;
    max-width:760px!important;
}
.sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form label{
    display:flex!important;flex-direction:column!important;gap:7px!important;font-size:12px!important;font-weight:900!important;color:#24324b!important;
}
.sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form input,
.sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form select,
.sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form textarea{
    min-height:46px!important;border:1px solid #cfe0f7!important;border-radius:14px!important;background:#fbfdff!important;font-size:14px!important;padding:11px 13px!important;box-sizing:border-box!important;
}
.sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form button{grid-column:1/-1!important;border:0!important;border-radius:14px!important;background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;color:#fff!important;font-weight:950!important;min-height:46px!important;}
@media(max-width:980px){
    .sm-member-app .sm-profile-modern{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
    .sm-member-app .sm-profile-fields{grid-column:1/-1!important;}
}
@media(max-width:720px){
    .sm-member-app .sm-profile-modern,
    .sm-member-app .sm-form-grid,
    .sm-member-app .sm-payment-form,
    .sm-portal.sm-user-window:not(.sm-member-app) .sm-payment-form{grid-template-columns:1fr!important;}
    .sm-member-app .sm-doc-card{min-height:auto!important;}
    .sm-member-app .sm-doc-preview{min-height:150px!important;}
    .sm-member-app .sm-profile-title h3{font-size:21px!important;}
}

/* v8.1.9 Profile UI hard fix - prevent squeezed fields */
.sm-member-app .sm-tab-panel[data-panel="profile"]{
    max-width:100%!important;
    width:100%!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-profile-modern{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(240px,1fr))!important;
    gap:18px!important;
    align-items:stretch!important;
    width:100%!important;
    max-width:100%!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-profile-fields{
    grid-column:1/-1!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:20px!important;
    overflow:visible!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-form-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(220px,1fr))!important;
    gap:16px!important;
    width:100%!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-form-grid label{
    min-width:0!important;
    width:100%!important;
    overflow:visible!important;
    white-space:normal!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] input,
.sm-member-app .sm-tab-panel[data-panel="profile"] textarea,
.sm-member-app .sm-tab-panel[data-panel="profile"] select{
    display:block!important;
    width:100%!important;
    min-width:0!important;
    max-width:100%!important;
    box-sizing:border-box!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-doc-card{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-bank-nominee-inside-profile,
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-profile-password-box{
    width:100%!important;
    max-width:100%!important;
    clear:both!important;
    overflow:visible!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] > button[type="submit"],
.sm-member-app .sm-edit-form > .sm-tab-panel[data-panel="profile"] > button[type="submit"]{
    display:inline-flex!important;
    width:auto!important;
    margin:18px 0!important;
}
@media(max-width:820px){
    .sm-member-app .sm-tab-panel[data-panel="profile"] .sm-profile-modern,
    .sm-member-app .sm-tab-panel[data-panel="profile"] .sm-form-grid{
        grid-template-columns:1fr!important;
    }
}

/* v8.1.10 Profile design like reference screenshot */
.sm-member-app .sm-tab-panel[data-panel="profile"]{
    background:#fff!important;
    border:1px solid #d7e4f7!important;
    border-radius:8px!important;
    padding:28px!important;
    box-shadow:none!important;
    max-width:100%!important;
}
.sm-member-app .sm-profile-settings-title{
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    padding:0!important;
    margin:0 0 22px!important;
}
.sm-member-app .sm-profile-settings-title h3{
    font-size:26px!important;
    line-height:1.2!important;
    margin:0!important;
    color:#0b1b35!important;
}
.sm-member-app .sm-profile-settings-title h3:before{display:none!important;content:none!important;}
.sm-member-app .sm-profile-settings-title p{display:none!important;}
.sm-member-app .sm-profile-settings-layout{
    display:grid!important;
    grid-template-columns:170px minmax(0,1fr)!important;
    gap:28px!important;
    align-items:start!important;
    width:100%!important;
    margin:0!important;
}
.sm-member-app .sm-profile-photo-panel{
    min-height:0!important;
    padding:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    gap:12px!important;
}
.sm-member-app .sm-profile-avatar-preview{
    width:160px!important;
    height:160px!important;
    min-height:160px!important;
    border-radius:18px!important;
    border:2px solid #fff!important;
    background:#f1f5f9!important;
    box-shadow:0 12px 30px rgba(15,23,42,.08)!important;
}
.sm-member-app .sm-doc-avatar-letter{
    font-size:48px!important;
    line-height:1!important;
    font-weight:950!important;
    color:#cbd5e1!important;
}
.sm-member-app .sm-profile-photo-panel .sm-file-button{
    width:160px!important;
    min-height:38px!important;
    border-radius:8px!important;
    font-size:12px!important;
    padding:9px 12px!important;
}
.sm-member-app .sm-profile-main-card{
    border:0!important;
    box-shadow:none!important;
    padding:0!important;
    background:transparent!important;
    width:100%!important;
}
.sm-member-app .sm-profile-main-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:18px 20px!important;
    width:100%!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] .sm-form-grid label{
    color:#50617c!important;
    font-size:11px!important;
    font-weight:900!important;
    text-transform:none!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] input,
.sm-member-app .sm-tab-panel[data-panel="profile"] textarea,
.sm-member-app .sm-tab-panel[data-panel="profile"] select{
    border-radius:6px!important;
    border:1px solid #cbd9ec!important;
    background:#f8fbff!important;
    min-height:36px!important;
    padding:8px 10px!important;
    font-size:14px!important;
    font-weight:650!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] textarea{min-height:64px!important;}
.sm-member-app .sm-inline-file-row{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:14px!important;
    padding:12px!important;
    border:1px dashed #d6e2f3!important;
    border-radius:8px!important;
    background:#fbfdff!important;
}
.sm-member-app .sm-inline-file-action{
    display:flex!important;
    align-items:center!important;
    gap:12px!important;
}
.sm-member-app .sm-inline-file-action a{
    font-size:12px!important;
    font-weight:800!important;
    color:#2563eb!important;
    text-decoration:none!important;
}
.sm-member-app .sm-small-file-button{
    min-height:34px!important;
    border-radius:8px!important;
    padding:8px 12px!important;
    box-shadow:none!important;
}
.sm-member-app .sm-section-divider{
    display:flex!important;
    align-items:center!important;
    gap:14px!important;
    margin:28px 0 18px!important;
    border-top:1px dashed #d7e2f2!important;
    padding-top:18px!important;
}
.sm-member-app .sm-section-divider span{
    color:#53657f!important;
    font-size:13px!important;
    font-weight:950!important;
    text-transform:uppercase!important;
    letter-spacing:.02em!important;
}
.sm-member-app .sm-clean-section{
    border:0!important;
    box-shadow:none!important;
    background:transparent!important;
    padding:0!important;
    margin:0!important;
}
.sm-member-app .sm-clean-section h3,
.sm-member-app .sm-clean-section h3:before{display:none!important;content:none!important;}
.sm-member-app .sm-clean-section p{margin:0 0 12px!important;color:#64748b!important;font-size:13px!important;}
.sm-member-app .sm-clean-section .sm-form-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:16px 20px!important;
}
.sm-member-app .sm-profile-save-btn{
    display:flex!important;
    width:100%!important;
    margin:28px 0 0!important;
    border-radius:7px!important;
    min-height:40px!important;
    box-shadow:none!important;
    background:#9b95f4!important;
}
.sm-member-app .sm-profile-password-clean{
    max-width:520px!important;
}
.sm-member-app .sm-profile-password-clean label{
    display:flex!important;
    flex-direction:column!important;
    gap:7px!important;
    font-size:12px!important;
    color:#50617c!important;
    font-weight:900!important;
}
.sm-member-app .sm-profile-password-clean button{
    margin-top:12px!important;
    border-radius:7px!important;
    min-height:40px!important;
    box-shadow:none!important;
}
@media(max-width:900px){
    .sm-member-app .sm-profile-settings-layout{grid-template-columns:1fr!important;}
    .sm-member-app .sm-profile-photo-panel{align-items:flex-start!important;}
    .sm-member-app .sm-profile-main-grid,
    .sm-member-app .sm-clean-section .sm-form-grid{grid-template-columns:1fr!important;}
}
@media(max-width:520px){
    .sm-member-app .sm-tab-panel[data-panel="profile"]{padding:18px!important;}
    .sm-member-app .sm-inline-file-row{flex-direction:column!important;align-items:flex-start!important;}
}


/* v8.1.11 Profile full-width layout fix - remove empty right side */
.sm-member-app .sm-edit-form{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
}
.sm-member-app .sm-edit-form > .sm-tab-panel[data-panel="profile"]{
    display:block!important;
    grid-column:1/-1!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"]{
    width:100%!important;
    max-width:none!important;
    overflow:hidden!important;
}
.sm-member-app .sm-profile-settings-layout{
    width:100%!important;
    max-width:100%!important;
    grid-template-columns:minmax(160px,180px) minmax(0,1fr)!important;
}
.sm-member-app .sm-profile-main-card,
.sm-member-app .sm-profile-main-grid,
.sm-member-app .sm-bank-nominee-inside-profile,
.sm-member-app .sm-clean-section,
.sm-member-app .sm-clean-section .sm-form-grid{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
}
.sm-member-app .sm-profile-main-grid,
.sm-member-app .sm-clean-section .sm-form-grid{
    grid-template-columns:repeat(2,minmax(240px,1fr))!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] label.wide,
.sm-member-app .sm-profile-main-grid .wide,
.sm-member-app .sm-clean-section .sm-form-grid .wide{
    grid-column:1/-1!important;
}
.sm-member-app .sm-tab-panel[data-panel="profile"] input,
.sm-member-app .sm-tab-panel[data-panel="profile"] textarea,
.sm-member-app .sm-tab-panel[data-panel="profile"] select{
    width:100%!important;
    max-width:100%!important;
}
@media(max-width:900px){
    .sm-member-app .sm-profile-settings-layout{
        grid-template-columns:1fr!important;
    }
    .sm-member-app .sm-profile-main-grid,
    .sm-member-app .sm-clean-section .sm-form-grid{
        grid-template-columns:1fr!important;
    }
}


/* v8.1.13 Member Dashboard premium UI + Profile spacing */
.sm-member-app .sm-member-dashboard-cards{
    grid-template-columns:repeat(auto-fit,minmax(205px,1fr))!important;
    gap:16px!important;
}
.sm-member-app .sm-member-dashboard-cards .sm-dash-metric,
.sm-member-app .sm-member-dashboard-cards .sm-front-card-button{
    position:relative!important;
    display:block!important;
    text-align:left!important;
    min-height:136px!important;
    padding:24px 22px!important;
    border:1px solid #dbe8fb!important;
    border-radius:22px!important;
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)!important;
    box-shadow:0 18px 42px rgba(15,23,42,.08)!important;
    overflow:hidden!important;
    cursor:default!important;
}
.sm-member-app .sm-member-dashboard-cards .sm-front-card-button{cursor:pointer!important;width:100%!important;}
.sm-member-app .sm-member-dashboard-cards .sm-dash-metric:before,
.sm-member-app .sm-member-dashboard-cards .sm-front-card-button:before{
    content:""!important;
    position:absolute!important;
    inset:0 auto 0 0!important;
    width:5px!important;
    background:linear-gradient(180deg,#4f46e5,#06b6d4)!important;
}
.sm-member-app .sm-member-dashboard-cards .sm-due:before{background:linear-gradient(180deg,#f97316,#ef4444)!important;}
.sm-member-app .sm-member-dashboard-cards .sm-paid:before,
.sm-member-app .sm-member-dashboard-cards .sm-saving:before{background:linear-gradient(180deg,#10b981,#22c55e)!important;}
.sm-member-app .sm-member-dashboard-cards .sm-invest:before{background:linear-gradient(180deg,#7c3aed,#2563eb)!important;}
.sm-member-app .sm-member-dashboard-cards .sm-card-icon{
    position:absolute!important;
    right:18px!important;
    top:18px!important;
    width:42px!important;
    height:42px!important;
    border-radius:16px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    color:#4f46e5!important;
    background:#eef2ff!important;
    font-size:18px!important;
    font-weight:950!important;
}
.sm-member-app .sm-member-dashboard-cards small{font-size:12px!important;color:#64748b!important;margin:0 0 16px!important;letter-spacing:.08em!important;}
.sm-member-app .sm-member-dashboard-cards b{font-size:clamp(24px,3vw,34px)!important;font-weight:950!important;color:#0f172a!important;}
.sm-member-app .sm-member-dashboard-cards em{display:block!important;margin-top:8px!important;font-size:11px!important;font-style:normal!important;color:#64748b!important;font-weight:800!important;}
.sm-member-app .sm-dash-title{
    background:linear-gradient(135deg,#fff,#f5f8ff)!important;
    border:1px solid #dbe8fb!important;
    border-radius:22px!important;
    padding:18px 20px!important;
    box-shadow:0 12px 30px rgba(15,23,42,.05)!important;
}
.sm-member-app .sm-dash-title h2{font-size:28px!important;font-weight:950!important;letter-spacing:-.03em!important;}
.sm-member-app .sm-tab-panel[data-panel="profile"]{max-width:100%!important;}
.sm-member-app .sm-profile-modern,
.sm-member-app .sm-profile-settings-layout{max-width:100%!important;}
@media(max-width:760px){
    .sm-member-app .sm-member-dashboard-cards{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;}
    .sm-member-app .sm-member-dashboard-cards .sm-dash-metric,
    .sm-member-app .sm-member-dashboard-cards .sm-front-card-button{min-height:116px!important;padding:20px 16px!important;border-radius:18px!important;}
    .sm-member-app .sm-member-dashboard-cards .sm-card-icon{width:34px!important;height:34px!important;right:12px!important;top:12px!important;}
    .sm-member-app .sm-member-dashboard-cards b{font-size:22px!important;}
}
@media(max-width:430px){.sm-member-app .sm-member-dashboard-cards{grid-template-columns:1fr!important;}}

/* v8.1.15 Profile final layout fix */
.sm-member-app .sm-tab-panel:not(.active){display:none!important;}
.sm-member-app .sm-tab-panel[data-panel="profile"]{max-width:none!important;width:100%!important;}
.sm-member-app .sm-profile-settings-title{display:flex!important;}
.sm-member-app .sm-tab-panel:not([data-panel="profile"]) .sm-profile-settings-title{display:none!important;}
.sm-member-app .sm-profile-v815{display:block!important;width:100%!important;max-width:100%!important;}
.sm-member-app .sm-profile-info-card{width:100%!important;background:#fff!important;border:1px solid #dbe7fb!important;border-radius:22px!important;padding:22px!important;box-shadow:0 16px 42px rgba(15,23,42,.06)!important;box-sizing:border-box!important;}
.sm-member-app .sm-section-heading{display:flex!important;align-items:center!important;gap:12px!important;margin:6px 0 14px!important;padding-top:4px!important;}
.sm-member-app .sm-section-heading:not(:first-child){margin-top:24px!important;padding-top:20px!important;border-top:1px dashed #d7e2f2!important;}
.sm-member-app .sm-section-heading span{font-size:14px!important;font-weight:950!important;color:#334155!important;text-transform:uppercase!important;letter-spacing:.03em!important;}
.sm-member-app .sm-profile-main-grid{display:grid!important;grid-template-columns:repeat(2,minmax(220px,1fr))!important;gap:16px 18px!important;width:100%!important;}
.sm-member-app .sm-profile-main-grid label.wide{grid-column:1/-1!important;}
.sm-member-app .sm-profile-main-grid input,
.sm-member-app .sm-profile-main-grid textarea{width:100%!important;max-width:100%!important;box-sizing:border-box!important;}
.sm-member-app .sm-verification-heading{margin:24px 0 14px!important;}
.sm-member-app .sm-verification-grid{display:grid!important;grid-template-columns:repeat(2,minmax(220px,1fr))!important;gap:18px!important;width:100%!important;align-items:stretch!important;}
.sm-member-app .sm-verification-grid .sm-doc-card{width:100%!important;min-height:260px!important;box-sizing:border-box!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:space-between!important;text-align:center!important;background:#fff!important;border:1px solid #dbe7fb!important;border-radius:22px!important;padding:18px!important;box-shadow:0 16px 42px rgba(15,23,42,.06)!important;}
.sm-member-app .sm-verification-grid .sm-doc-preview{width:100%!important;max-width:210px!important;height:150px!important;min-height:150px!important;border-radius:18px!important;margin:0 auto!important;}
.sm-member-app .sm-verification-grid .sm-doc-preview img{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:16px!important;}
.sm-member-app .sm-verification-grid strong{font-size:15px!important;font-weight:950!important;color:#0f172a!important;margin:4px 0!important;}
.sm-member-app .sm-profile-actions-row{display:flex!important;gap:14px!important;flex-wrap:wrap!important;margin-top:22px!important;align-items:center!important;}
.sm-member-app .sm-profile-actions-row .sm-profile-save-btn,
.sm-member-app .sm-profile-actions-row .sm-profile-reset-btn{width:auto!important;min-width:180px!important;margin:0!important;min-height:44px!important;border-radius:12px!important;}
.sm-member-app .sm-profile-reset-btn{background:linear-gradient(135deg,#0ea5e9,#2563eb)!important;color:#fff!important;border:0!important;font-weight:950!important;box-shadow:0 14px 26px rgba(37,99,235,.18)!important;cursor:pointer!important;padding:12px 18px!important;}
.sm-member-app .sm-password-modal-box label{display:flex!important;flex-direction:column!important;gap:8px!important;font-weight:900!important;color:#334155!important;}
.sm-member-app .sm-password-modal-box input{width:100%!important;border:1px solid #cfe0f7!important;border-radius:12px!important;min-height:44px!important;padding:10px 12px!important;box-sizing:border-box!important;}
.sm-member-app .sm-password-modal-box button[type="submit"]{margin-top:14px!important;width:100%!important;min-height:44px!important;border-radius:12px!important;background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;color:#fff!important;border:0!important;font-weight:950!important;}
@media(max-width:760px){
    .sm-member-app .sm-profile-info-card{padding:16px!important;border-radius:18px!important;}
    .sm-member-app .sm-profile-main-grid,
    .sm-member-app .sm-verification-grid{grid-template-columns:1fr!important;}
    .sm-member-app .sm-profile-actions-row{flex-direction:column!important;align-items:stretch!important;}
    .sm-member-app .sm-profile-actions-row .sm-profile-save-btn,
    .sm-member-app .sm-profile-actions-row .sm-profile-reset-btn{width:100%!important;}
}

/* v8.1.16 Premium collapsible sidebar + icon-only mobile navigation */
.sm-member-app .sm-app-shell{
    transition:all .28s ease!important;
}
.sm-member-app .sm-app-sidebar{
    position:relative!important;
    transition:width .28s ease, min-width .28s ease, box-shadow .28s ease!important;
    overflow:hidden!important;
}
.sm-sidebar-toggle{
    width:38px!important;
    height:38px!important;
    border:0!important;
    border-radius:14px!important;
    background:linear-gradient(135deg,#5b55f3,#7c3aed)!important;
    color:#fff!important;
    font-size:18px!important;
    font-weight:900!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    margin:0 0 14px auto!important;
    cursor:pointer!important;
    box-shadow:0 12px 22px rgba(91,85,243,.24)!important;
    transition:transform .2s ease, box-shadow .2s ease!important;
}
.sm-sidebar-toggle:hover{transform:translateY(-2px)!important;box-shadow:0 16px 28px rgba(91,85,243,.32)!important;}
.sm-member-app.sm-sidebar-collapsed .sm-app-shell{grid-template-columns:88px minmax(0,1fr)!important;}
.sm-member-app.sm-sidebar-collapsed .sm-app-sidebar{width:88px!important;min-width:88px!important;padding:14px 10px!important;}
.sm-member-app.sm-sidebar-collapsed .sm-sidebar-toggle{margin-left:auto!important;margin-right:auto!important;}
.sm-member-app.sm-sidebar-collapsed .sm-app-profile h3,
.sm-member-app.sm-sidebar-collapsed .sm-member-badge,
.sm-member-app.sm-sidebar-collapsed .sm-member-role-line,
.sm-member-app.sm-sidebar-collapsed .sm-logout{display:none!important;}
.sm-member-app.sm-sidebar-collapsed .sm-app-profile{padding-bottom:10px!important;margin-bottom:10px!important;}
.sm-member-app.sm-sidebar-collapsed .sm-app-profile img,
.sm-member-app.sm-sidebar-collapsed .sm-big-avatar{width:52px!important;height:52px!important;margin:0 auto!important;font-size:24px!important;}
.sm-member-app.sm-sidebar-collapsed .sm-tab-nav button{
    width:54px!important;min-height:52px!important;padding:0!important;margin:0 auto!important;
    font-size:0!important;justify-content:center!important;align-items:center!important;border-radius:16px!important;
}
.sm-member-app.sm-sidebar-collapsed .sm-tab-nav button:before{font-size:22px!important;margin:0!important;}
.sm-member-app.sm-sidebar-collapsed .sm-inbox-count{position:absolute!important;top:4px!important;right:5px!important;font-size:10px!important;}
.sm-member-app .sm-tab-panel.active{animation:smFadeSlide .22s ease both!important;}
@keyframes smFadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.sm-member-app .sm-dash-metric,.sm-member-app .sm-profile-modern,.sm-member-app .sm-payment-window,.sm-member-app .sm-mini-modal-box{transition:transform .22s ease, box-shadow .22s ease!important;}
.sm-member-app .sm-dash-metric:hover,.sm-member-app .sm-payment-window:hover{transform:translateY(-2px)!important;box-shadow:0 18px 38px rgba(15,23,42,.10)!important;}
.sm-tab-nav button[data-tab="dash"]:before{content:"🏠"!important;}
.sm-tab-nav button[data-tab="payment"]:before{content:"💳"!important;}
.sm-tab-nav button[data-tab="history"]:before{content:"📜"!important;}
.sm-tab-nav button[data-tab="withdrawal"]:before{content:"💸"!important;}
.sm-tab-nav button[data-tab="collect_ops"]:before{content:"➕"!important;}
.sm-tab-nav button[data-tab="book_ops"]:before{content:"📒"!important;}
.sm-tab-nav button[data-tab="approve_ops"]:before{content:"✅"!important;}
.sm-tab-nav button[data-tab="somiti_dash_ops"]:before{content:"📊"!important;}
.sm-tab-nav button[data-tab="accounting_view_ops"]:before{content:"🧾"!important;}
.sm-tab-nav button[data-tab="due_list_ops"]:before{content:"⚠️"!important;}
.sm-tab-nav button[data-tab="report_ops"]:before{content:"📈"!important;}
.sm-tab-nav button[data-tab="inbox"]:before{content:"🔔"!important;}
.sm-tab-nav button[data-tab="profile"]:before{content:"👤"!important;}
@media (max-width: 782px){
    .sm-member-app .sm-app-shell{display:block!important;padding-bottom:88px!important;}
    .sm-member-app .sm-app-sidebar{width:auto!important;min-width:0!important;position:static!important;overflow:visible!important;padding:0!important;background:transparent!important;border:0!important;box-shadow:none!important;}
    .sm-member-app .sm-app-profile,.sm-member-app .sm-sidebar-toggle,.sm-member-app .sm-logout{display:none!important;}
    .sm-member-app .sm-tab-nav{
        position:fixed!important;left:0!important;right:0!important;bottom:0!important;z-index:999999!important;
        height:72px!important;padding:8px 8px 10px!important;display:flex!important;flex-direction:row!important;
        align-items:center!important;justify-content:flex-start!important;gap:8px!important;overflow-x:auto!important;overflow-y:hidden!important;
        background:rgba(255,255,255,.96)!important;backdrop-filter:blur(16px)!important;border-top:1px solid #dbe7f7!important;
        box-shadow:0 -16px 40px rgba(15,23,42,.14)!important;white-space:nowrap!important;
    }
    .sm-member-app .sm-tab-nav button{
        position:relative!important;flex:0 0 56px!important;width:56px!important;height:56px!important;min-height:56px!important;
        padding:0!important;margin:0!important;border-radius:18px!important;font-size:0!important;line-height:0!important;
        display:flex!important;align-items:center!important;justify-content:center!important;background:#f8fbff!important;color:#475569!important;
        box-shadow:0 8px 20px rgba(15,23,42,.06)!important;border:1px solid #e2eaf7!important;
    }
    .sm-member-app .sm-tab-nav button:before{display:block!important;font-size:23px!important;line-height:1!important;margin:0!important;}
    .sm-member-app .sm-tab-nav button.active{background:linear-gradient(135deg,#5b55f3,#7c3aed)!important;color:#fff!important;transform:translateY(-6px)!important;box-shadow:0 16px 28px rgba(91,85,243,.30)!important;}
    .sm-member-app .sm-inbox-count{position:absolute!important;top:1px!important;right:0!important;min-width:18px!important;height:18px!important;font-size:10px!important;line-height:18px!important;border-radius:999px!important;background:#ef4444!important;color:#fff!important;}
    .sm-member-app .sm-app-content{width:100%!important;padding:0!important;margin:0!important;}
}

/* v8.1.17 CRITICAL FIX: Profile panel must stay hidden unless My Profile tab is active */
.sm-member-app .sm-edit-form > .sm-tab-panel[data-panel="profile"],
.sm-member-app .sm-tab-panel[data-panel="profile"]{
    display:none!important;
}
.sm-member-app .sm-edit-form > .sm-tab-panel[data-panel="profile"].active,
.sm-member-app .sm-tab-panel[data-panel="profile"].active{
    display:block!important;
}

/* ===== v8.1.19 Dark mode + premium hover + loading skeleton ===== */
.sm-member-app{--sm-bg:#f4f7fc;--sm-surface:#ffffff;--sm-surface-2:#f8fbff;--sm-border:#d8e5f6;--sm-text:#06183a;--sm-muted:#65758f;--sm-primary:#6d5dfc;--sm-primary-2:#7c3aed;--sm-shadow:0 14px 34px rgba(15,23,42,.08);--sm-soft-shadow:0 10px 24px rgba(15,23,42,.06)}
.sm-member-app.sm-dark-mode{--sm-bg:#0b1220;--sm-surface:#111827;--sm-surface-2:#172033;--sm-border:#27364f;--sm-text:#e5eefc;--sm-muted:#9fb0ca;--sm-primary:#8b5cf6;--sm-primary-2:#22d3ee;--sm-shadow:0 18px 46px rgba(0,0,0,.36);--sm-soft-shadow:0 12px 30px rgba(0,0,0,.28)}
.sm-member-app .sm-app-shell{background:var(--sm-bg)!important;border-color:var(--sm-border)!important;transition:background .25s ease,border-color .25s ease!important;}
.sm-member-app .sm-app-sidebar,.sm-member-app .sm-app-content,
.sm-member-app .sm-front-cards>div,.sm-member-app .sm-history-card,.sm-member-app .sm-payment-preview,
.sm-member-app .sm-payment-window,.sm-member-app .sm-profile-modern,.sm-member-app .sm-member-ops-form,
.sm-member-app .sm-dash-metric,.sm-member-app .sm-modern-card,.sm-member-app .sm-mini-card,
.sm-member-app .sm-section-card,.sm-member-app .sm-profile-full-card{
    background:var(--sm-surface)!important;border-color:var(--sm-border)!important;color:var(--sm-text)!important;box-shadow:var(--sm-soft-shadow)!important;transition:transform .22s ease,box-shadow .22s ease,background .25s ease,border-color .25s ease,color .25s ease!important;
}
.sm-member-app :is(h1,h2,h3,h4,b,strong,label,.sm-tab-nav button,.sm-front-cards b,.sm-dash-title h2,.sm-profile-title h3){color:var(--sm-text)!important;}
.sm-member-app :is(small,p,.description,.sm-muted,.sm-front-cards small){color:var(--sm-muted)!important;}
.sm-member-app input,.sm-member-app select,.sm-member-app textarea{
    background:var(--sm-surface-2)!important;color:var(--sm-text)!important;border-color:var(--sm-border)!important;transition:border-color .2s ease,box-shadow .2s ease,background .25s ease,color .25s ease!important;
}
.sm-member-app input:focus,.sm-member-app select:focus,.sm-member-app textarea:focus{outline:none!important;border-color:var(--sm-primary)!important;box-shadow:0 0 0 4px rgba(109,93,252,.14)!important;}
.sm-member-app .sm-dash-title,.sm-member-app .sm-profile-title,.sm-member-app .sm-page-title,.sm-member-app .sm-card-title{
    background:var(--sm-surface)!important;border-color:var(--sm-border)!important;color:var(--sm-text)!important;box-shadow:var(--sm-soft-shadow)!important;
}
.sm-member-app .sm-tab-nav button{transition:transform .2s ease,background .2s ease,box-shadow .2s ease,color .2s ease!important;}
.sm-member-app .sm-tab-nav button:hover{transform:translateX(4px)!important;}
.sm-member-app.sm-sidebar-collapsed .sm-tab-nav button:hover{transform:translateY(-2px)!important;}
.sm-member-app :is(.sm-front-cards>div,.sm-dash-metric,.sm-modern-card,.sm-member-ops-form,.sm-payment-window,.sm-history-card,.sm-profile-full-card):hover{transform:translateY(-3px)!important;box-shadow:var(--sm-shadow)!important;}
.sm-member-app button,.sm-member-app .button,.sm-member-app input[type="submit"]{transition:transform .18s ease,box-shadow .18s ease,filter .18s ease!important;}
.sm-member-app button:hover,.sm-member-app .button:hover,.sm-member-app input[type="submit"]:hover{transform:translateY(-1px)!important;filter:brightness(1.03)!important;}
.sm-member-app .sm-dark-toggle{
    width:100%;border:1px solid var(--sm-border)!important;border-radius:12px!important;padding:10px 11px!important;margin:8px 0 12px!important;
    background:var(--sm-surface-2)!important;color:var(--sm-text)!important;font-weight:900!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;
}
.sm-member-app.sm-sidebar-collapsed .sm-dark-toggle{width:54px!important;height:52px!important;padding:0!important;margin:6px auto!important;font-size:0!important;}
.sm-member-app.sm-sidebar-collapsed .sm-dark-toggle:before{content:"🌙";font-size:21px!important;}
.sm-member-app.sm-dark-mode .sm-dark-toggle:before{content:"☀️";font-size:18px!important;}
.sm-member-app.sm-dark-mode .sm-dark-toggle{background:#1f2937!important;}
.sm-member-app.sm-dark-mode .sm-tab-nav button:not(.active){background:transparent!important;color:var(--sm-muted)!important;}
.sm-member-app.sm-dark-mode .sm-tab-nav button.active{background:linear-gradient(135deg,var(--sm-primary),var(--sm-primary-2))!important;color:#fff!important;}
.sm-member-app.sm-dark-mode table,.sm-member-app.sm-dark-mode th,.sm-member-app.sm-dark-mode td{color:var(--sm-text)!important;border-color:var(--sm-border)!important;}
.sm-member-app.sm-dark-mode th{background:#172033!important;}
.sm-member-app.sm-dark-mode .sm-status-approved{background:#064e3b!important;color:#bbf7d0!important;}
.sm-member-app.sm-dark-mode .sm-status-pending{background:#78350f!important;color:#fde68a!important;}
.sm-member-app.sm-dark-mode .sm-status-rejected{background:#7f1d1d!important;color:#fecaca!important;}
@keyframes smSkeletonShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.sm-member-app .sm-skeleton-line,.sm-member-app.sm-is-loading .sm-tab-panel.active .sm-loading-placeholder{
    display:block!important;border-radius:10px!important;min-height:16px!important;background:linear-gradient(90deg,rgba(148,163,184,.16) 25%,rgba(148,163,184,.34) 37%,rgba(148,163,184,.16) 63%)!important;background-size:400% 100%!important;animation:smSkeletonShimmer 1.15s ease infinite!important;
}
.sm-member-app.sm-is-loading .sm-tab-panel.active{position:relative!important;}
.sm-member-app.sm-is-loading .sm-tab-panel.active:before{
    content:"";position:absolute;inset:0;z-index:40;border-radius:16px;background:linear-gradient(90deg,rgba(148,163,184,.10),rgba(148,163,184,.22),rgba(148,163,184,.10));background-size:300% 100%;animation:smSkeletonShimmer 1.05s ease infinite;pointer-events:none;
}
.sm-member-app.sm-is-loading .sm-tab-panel.active:after{
    content:"Loading...";position:absolute;left:50%;top:24px;transform:translateX(-50%);z-index:41;background:var(--sm-surface);border:1px solid var(--sm-border);border-radius:999px;padding:8px 14px;color:var(--sm-muted);font-size:12px;font-weight:900;box-shadow:var(--sm-soft-shadow);pointer-events:none;
}
.sm-member-app form.sm-submitting{position:relative!important;opacity:.72!important;pointer-events:none!important;}
.sm-member-app form.sm-submitting:after{content:"Submitting...";position:absolute;inset:auto 14px 14px auto;background:var(--sm-text);color:var(--sm-surface);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900;box-shadow:var(--sm-shadow);}
@media(max-width:782px){
    .sm-member-app .sm-dark-toggle{position:fixed!important;right:12px!important;bottom:82px!important;z-index:999999!important;width:48px!important;height:48px!important;border-radius:50%!important;padding:0!important;font-size:0!important;box-shadow:var(--sm-shadow)!important;}
    .sm-member-app .sm-dark-toggle:before{content:"🌙";font-size:21px!important;}
    .sm-member-app.sm-dark-mode .sm-dark-toggle:before{content:"☀️";font-size:18px!important;}
    .sm-member-app.sm-dark-mode .sm-tab-nav{background:rgba(17,24,39,.94)!important;border-color:var(--sm-border)!important;}
}

/* ===== v8.1.20 Unified Frontend UI + Dark Contrast Fix ===== */
.sm-member-app{
  --sm-page-max:1120px;
  --sm-radius:16px;
  --sm-gap:14px;
  font-size:14px!important;
}
.sm-member-app, .sm-member-app *{box-sizing:border-box!important;}
.sm-member-app .sm-app-content{max-width:var(--sm-page-max)!important;margin:0 auto!important;}
.sm-member-app .sm-tab-panel{width:100%!important;max-width:100%!important;padding:14px!important;}
.sm-member-app .sm-tab-panel:not(.active){display:none!important;}
.sm-member-app .sm-tab-panel.active{display:block!important;}

/* One consistent page header */
.sm-member-app :is(.sm-dash-title,.sm-profile-title,.sm-page-title,.sm-section-heading){
  width:100%!important;min-height:58px!important;border-radius:var(--sm-radius)!important;padding:15px 18px!important;margin:0 0 16px!important;
  display:flex!important;align-items:center!important;gap:10px!important;border:1px solid var(--sm-border)!important;background:var(--sm-surface)!important;color:var(--sm-text)!important;
}
.sm-member-app :is(.sm-dash-title h2,.sm-profile-title h3,.sm-page-title h2,.sm-section-heading h2){font-size:22px!important;line-height:1.15!important;margin:0!important;color:var(--sm-text)!important;}

/* Unified card surfaces across all frontend pages */
.sm-member-app :is(.sm-payment-window,.sm-member-ops-form,.sm-history-card,.sm-user-window,.sm-front-group-card,.sm-front-cards>div,.sm-dash-metric,.sm-profile-v815,.sm-profile-info-card,.sm-doc-card,.sm-nid-upload-panel,.sm-section-card,.sm-modern-card,.sm-mini-card,.sm-payment-preview,.sm-front-accounting-groups,.sm-receipt-popup){
  background:var(--sm-surface)!important;color:var(--sm-text)!important;border:1px solid var(--sm-border)!important;border-radius:var(--sm-radius)!important;box-shadow:var(--sm-soft-shadow)!important;
}
.sm-member-app :is(.sm-payment-window,.sm-member-ops-form,.sm-history-card,.sm-user-window,.sm-profile-v815,.sm-profile-info-card){
  max-width:900px!important;width:100%!important;margin:0 0 16px!important;padding:22px!important;
}
.sm-member-app :is(.sm-payment-window,.sm-member-ops-form){margin-left:auto!important;margin-right:auto!important;}
.sm-member-app :is(.sm-payment-window,.sm-member-ops-form) > p:first-child{margin-top:0!important;color:var(--sm-muted)!important;font-size:13px!important;font-weight:700!important;}
.sm-member-app :is(.sm-payment-window,.sm-member-ops-form) h2,
.sm-member-app :is(.sm-payment-window,.sm-member-ops-form) h3{font-size:18px!important;margin:0 0 16px!important;color:var(--sm-text)!important;}

/* Dashboard metrics, compact and readable */
.sm-member-app .sm-member-dashboard-cards,
.sm-member-app .sm-front-cards,
.sm-member-app .sm-front-grouped-cards{
  display:grid!important;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important;gap:14px!important;align-items:stretch!important;width:100%!important;margin-bottom:16px!important;
}
.sm-member-app .sm-dash-metric,
.sm-member-app .sm-front-cards>div{
  min-height:118px!important;padding:18px!important;overflow:hidden!important;
}
.sm-member-app .sm-dash-metric small,
.sm-member-app .sm-front-cards small,
.sm-member-app .sm-dash-metric .label{font-size:11px!important;letter-spacing:.06em!important;text-transform:uppercase!important;color:var(--sm-muted)!important;font-weight:900!important;}
.sm-member-app .sm-dash-metric b,
.sm-member-app .sm-front-cards b,
.sm-member-app .sm-dash-metric .value{font-size:23px!important;line-height:1.18!important;word-break:break-word!important;color:var(--sm-text)!important;font-weight:900!important;}

/* Fund/accounting cards: fix label overflow */
.sm-member-app .sm-front-group-card{padding:18px!important;min-width:0!important;overflow:hidden!important;}
.sm-member-app .sm-front-group-card h3{font-size:18px!important;line-height:1.2!important;margin:0 0 12px!important;color:var(--sm-text)!important;}
.sm-member-app .sm-front-card-button{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:10px!important;padding:10px 12px!important;margin:8px 0!important;border-radius:12px!important;background:var(--sm-surface-2)!important;color:var(--sm-text)!important;border:1px solid var(--sm-border)!important;overflow:hidden!important;}
.sm-member-app .sm-front-card-button span:first-child{font-size:17px!important;font-weight:800!important;color:var(--sm-muted)!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;min-width:0!important;}
.sm-member-app .sm-front-card-button span:last-child{font-size:14px!important;font-weight:900!important;color:var(--sm-text)!important;white-space:nowrap!important;}

/* Unified form grid and form controls */
.sm-member-app .sm-form-grid,
.sm-member-app .sm-profile-main-grid{
  display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px 16px!important;width:100%!important;
}
.sm-member-app label{display:block!important;margin:0 0 6px!important;color:var(--sm-text)!important;font-size:12px!important;font-weight:900!important;}
.sm-member-app :is(input[type="text"],input[type="email"],input[type="number"],input[type="date"],input[type="password"],select,textarea){
  width:100%!important;max-width:100%!important;min-height:44px!important;border-radius:12px!important;padding:11px 13px!important;font-size:13px!important;font-weight:700!important;background:var(--sm-surface-2)!important;color:var(--sm-text)!important;border:1px solid var(--sm-border)!important;
}
.sm-member-app textarea{min-height:84px!important;resize:vertical!important;}
.sm-member-app ::placeholder{color:var(--sm-muted)!important;opacity:.75!important;}
.sm-member-app :is(button,.button,input[type="submit"]){border-radius:12px!important;font-size:13px!important;font-weight:900!important;}

/* Tables: one readable style for light and dark */
.sm-member-app table{width:100%!important;border-collapse:separate!important;border-spacing:0!important;background:var(--sm-surface)!important;color:var(--sm-text)!important;border:1px solid var(--sm-border)!important;border-radius:14px!important;overflow:hidden!important;}
.sm-member-app thead th,.sm-member-app th{background:var(--sm-surface-2)!important;color:var(--sm-text)!important;font-size:11px!important;letter-spacing:.04em!important;text-transform:uppercase!important;font-weight:900!important;padding:11px 10px!important;border-bottom:1px solid var(--sm-border)!important;}
.sm-member-app tbody td,.sm-member-app td{color:var(--sm-text)!important;font-size:12px!important;font-weight:700!important;padding:10px!important;border-bottom:1px solid var(--sm-border)!important;}
.sm-member-app tbody tr{background:var(--sm-surface)!important;}
.sm-member-app tbody tr:nth-child(even){background:var(--sm-surface-2)!important;}
.sm-member-app .sm-due-row-due{background:rgba(251,146,60,.13)!important;}
.sm-member-app .sm-due-row-advance{background:rgba(59,130,246,.13)!important;}
.sm-member-app .sm-due-row-paid{background:rgba(34,197,94,.12)!important;}

/* Dark mode: force proper contrast, no white cards with white text */
.sm-member-app.sm-dark-mode{background:#0b1220!important;color:#e5eefc!important;}
.sm-member-app.sm-dark-mode :is(.sm-app-shell,.sm-app-content,.sm-app-sidebar){background:#0b1220!important;color:#e5eefc!important;border-color:#26364f!important;}
.sm-member-app.sm-dark-mode :is(.sm-dash-title,.sm-profile-title,.sm-page-title,.sm-section-heading,.sm-payment-window,.sm-member-ops-form,.sm-history-card,.sm-user-window,.sm-front-group-card,.sm-front-cards>div,.sm-dash-metric,.sm-profile-v815,.sm-profile-info-card,.sm-doc-card,.sm-nid-upload-panel,.sm-section-card,.sm-modern-card,.sm-mini-card,.sm-payment-preview,.sm-front-accounting-groups,.sm-receipt-popup){
  background:#111827!important;color:#e5eefc!important;border-color:#2a3a56!important;box-shadow:0 16px 42px rgba(0,0,0,.32)!important;
}
.sm-member-app.sm-dark-mode :is(.sm-front-card-button,input,select,textarea,table,thead th,th){background:#172033!important;color:#e5eefc!important;border-color:#2a3a56!important;}
.sm-member-app.sm-dark-mode :is(h1,h2,h3,h4,h5,h6,b,strong,label,td,th,.value,.sm-front-card-button span:last-child){color:#e5eefc!important;}
.sm-member-app.sm-dark-mode :is(p,small,.description,.sm-muted,.sm-front-card-button span:first-child,.sm-dash-metric small){color:#a8b8d4!important;}
.sm-member-app.sm-dark-mode tbody tr{background:#111827!important;}
.sm-member-app.sm-dark-mode tbody tr:nth-child(even){background:#152033!important;}
.sm-member-app.sm-dark-mode .sm-due-row-due{background:rgba(251,146,60,.18)!important;}
.sm-member-app.sm-dark-mode .sm-due-row-advance{background:rgba(59,130,246,.18)!important;}
.sm-member-app.sm-dark-mode .sm-due-row-paid{background:rgba(34,197,94,.16)!important;}
.sm-member-app.sm-dark-mode .sm-tab-nav button:not(.active){color:#c7d2e8!important;background:transparent!important;}
.sm-member-app.sm-dark-mode .sm-tab-nav button.active{color:#fff!important;}

/* Remove huge blank look by keeping content width balanced */
.sm-member-app .sm-payment-window + .sm-history-card,
.sm-member-app .sm-member-ops-form + .sm-history-card{max-width:900px!important;margin-left:auto!important;margin-right:auto!important;}

@media(max-width:980px){
  .sm-member-app .sm-form-grid,.sm-member-app .sm-profile-main-grid{grid-template-columns:1fr!important;}
  .sm-member-app .sm-member-dashboard-cards,.sm-member-app .sm-front-cards,.sm-member-app .sm-front-grouped-cards{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .sm-member-app .sm-tab-panel{padding:10px!important;}
}
@media(max-width:560px){
  .sm-member-app .sm-member-dashboard-cards,.sm-member-app .sm-front-cards,.sm-member-app .sm-front-grouped-cards{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important;}
  .sm-member-app .sm-dash-metric,.sm-member-app .sm-front-cards>div{min-height:96px!important;padding:12px!important;}
  .sm-member-app .sm-dash-metric b,.sm-member-app .sm-front-cards b{font-size:18px!important;}
  .sm-member-app :is(.sm-payment-window,.sm-member-ops-form,.sm-history-card,.sm-user-window,.sm-profile-v815,.sm-profile-info-card){padding:14px!important;}
  .sm-member-app :is(.sm-dash-title h2,.sm-profile-title h3,.sm-page-title h2,.sm-section-heading h2){font-size:20px!important;}
}


/* v8.1.21 Clean UI Fix: simple dashboard typography and accounting labels */
.sm-member-app .sm-front-group-card p,
.sm-member-app .sm-front-card-button,
.sm-member-app .sm-dash-metric,
.sm-member-app .sm-front-cards > div{
    box-shadow:none!important;
}
.sm-member-app .sm-front-group-card h3,
.sm-member-app .sm-front-group-card span,
.sm-member-app .sm-front-group-card b,
.sm-member-app .sm-front-card-button span,
.sm-member-app .sm-front-cards small,
.sm-member-app .sm-front-cards b,
.sm-member-app .sm-dash-metric .label,
.sm-member-app .sm-dash-metric .value,
.sm-member-app .sm-member-dashboard-cards b,
.sm-member-app .sm-member-dashboard-cards small{
    font-weight:500!important;
}
.sm-member-app .sm-front-group-card h3{font-size:17px!important;}
.sm-member-app .sm-front-group-card span,
.sm-member-app .sm-front-card-button span:first-child{font-size:14px!important;color:var(--sm-muted,#64748b)!important;}
.sm-member-app .sm-front-group-card b,
.sm-member-app .sm-front-card-button span:last-child{font-size:14px!important;color:var(--sm-text,#0f172a)!important;}
.sm-member-app .sm-front-cards small,
.sm-member-app .sm-dash-metric .label{font-size:11px!important;font-weight:500!important;color:var(--sm-muted,#64748b)!important;}
.sm-member-app .sm-front-cards b,
.sm-member-app .sm-dash-metric .value,
.sm-member-app .sm-member-dashboard-cards b{font-size:20px!important;font-weight:500!important;color:var(--sm-text,#0f172a)!important;letter-spacing:0!important;}
.sm-member-app .sm-dash-title h2,
.sm-member-app .sm-profile-title h3,
.sm-member-app .sm-page-title h2{font-weight:600!important;}
.sm-member-app.sm-dark-mode .sm-front-group-card,
.sm-member-app.sm-dark-mode .sm-front-cards>div,
.sm-member-app.sm-dark-mode .sm-dash-metric,
.sm-member-app.sm-dark-mode .sm-front-card-button{background:#111827!important;border-color:#2a3a56!important;}
.sm-member-app.sm-dark-mode .sm-front-group-card h3,
.sm-member-app.sm-dark-mode .sm-front-group-card b,
.sm-member-app.sm-dark-mode .sm-front-card-button span:last-child,
.sm-member-app.sm-dark-mode .sm-front-cards b,
.sm-member-app.sm-dark-mode .sm-dash-metric .value,
.sm-member-app.sm-dark-mode .sm-member-dashboard-cards b{color:#f8fafc!important;}
.sm-member-app.sm-dark-mode .sm-front-group-card span,
.sm-member-app.sm-dark-mode .sm-front-card-button span:first-child,
.sm-member-app.sm-dark-mode .sm-front-cards small,
.sm-member-app.sm-dark-mode .sm-dash-metric .label{color:#cbd5e1!important;}


/* v8.6.12 frontend popup close + approved payment table alignment fix */
.sm-member-app .sm-mini-modal.active{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:18px!important;
}
.sm-member-app .sm-mini-modal-box{
  position:relative!important;
  max-height:82vh!important;
  overflow:auto!important;
  padding-top:52px!important;
}
.sm-member-app .sm-mini-close{
  position:sticky!important;
  top:0!important;
  float:right!important;
  z-index:100000!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  margin-top:-42px!important;
  margin-right:0!important;
}
.sm-member-app .sm-mini-modal-box h3,
.sm-member-app .sm-mini-modal-box h4{
  margin-top:0!important;
}
.sm-member-app .sm-history-card{overflow-x:auto!important;}
.sm-member-app .sm-history-table{
  width:100%!important;
  min-width:850px!important;
  table-layout:fixed!important;
  border-collapse:collapse!important;
}
.sm-member-app .sm-history-table th:nth-child(1), .sm-member-app .sm-history-table td:nth-child(1){width:145px!important;}
.sm-member-app .sm-history-table th:nth-child(2), .sm-member-app .sm-history-table td:nth-child(2){width:90px!important;}
.sm-member-app .sm-history-table th:nth-child(3), .sm-member-app .sm-history-table td:nth-child(3){width:110px!important;text-align:right!important;}
.sm-member-app .sm-history-table th:nth-child(4), .sm-member-app .sm-history-table td:nth-child(4){width:135px!important;}
.sm-member-app .sm-history-table th:nth-child(5), .sm-member-app .sm-history-table td:nth-child(5){width:95px!important;}
.sm-member-app .sm-history-table th:nth-child(6), .sm-member-app .sm-history-table td:nth-child(6){width:170px!important;}
.sm-member-app .sm-history-table th:nth-child(7), .sm-member-app .sm-history-table td:nth-child(7){width:120px!important;text-align:center!important;}
.sm-member-app .sm-history-table .sm-receipt-popup{
  min-width:92px!important;
  text-align:center!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  white-space:nowrap!important;
}
@media(max-width:768px){
  .sm-member-app .sm-mini-modal{align-items:flex-start!important;overflow:auto!important;}
  .sm-member-app .sm-mini-modal-box{max-height:90vh!important;width:96vw!important;}
}

/* v8.6.13 final frontend popup close fix */
.sm-member-app .sm-mini-modal.active{
  position:fixed!important;
  inset:0!important;
  z-index:2147483000!important;
  display:flex!important;
  align-items:flex-start!important;
  justify-content:center!important;
  padding:42px 16px 22px!important;
  overflow:auto!important;
  background:rgba(15,23,42,.62)!important;
}
.sm-member-app .sm-mini-modal-box{
  position:relative!important;
  width:min(980px,96vw)!important;
  max-width:96vw!important;
  max-height:none!important;
  min-height:120px!important;
  overflow:visible!important;
  padding:58px 18px 20px!important;
  background:#fff!important;
  border-radius:18px!important;
  box-shadow:0 28px 90px rgba(0,0,0,.32)!important;
}
.sm-member-app .sm-mini-modal-box::before{
  content:"";
  position:sticky!important;
  top:0!important;
  display:block!important;
  height:0!important;
  z-index:2147483001!important;
}
.sm-member-app .sm-mini-close{
  position:fixed!important;
  top:18px!important;
  right:22px!important;
  z-index:2147483647!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
  padding:0!important;
  border:2px solid #fff!important;
  border-radius:999px!important;
  background:#ef4444!important;
  color:#fff!important;
  font-size:28px!important;
  line-height:1!important;
  font-weight:900!important;
  cursor:pointer!important;
  box-shadow:0 12px 32px rgba(239,68,68,.42)!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}
.sm-member-app .sm-mini-close:hover{background:#dc2626!important;transform:scale(1.04)!important;}
.sm-member-app .sm-mini-modal-box h3,
.sm-member-app .sm-mini-modal-box h4{margin:0 0 14px!important;}
.sm-member-app .sm-mini-modal-box .sm-history-table{
  table-layout:fixed!important;
  width:100%!important;
  min-width:720px!important;
}
.sm-member-app .sm-mini-modal-box{overflow-x:auto!important;}
body.sm-mini-modal-open{overflow:hidden!important;}
@media(max-width:768px){
  .sm-member-app .sm-mini-modal.active{padding:54px 8px 14px!important;}
  .sm-member-app .sm-mini-close{top:10px!important;right:10px!important;width:42px!important;height:42px!important;}
  .sm-member-app .sm-mini-modal-box{width:98vw!important;max-width:98vw!important;padding:52px 10px 14px!important;}
}

/* v8.6.15 Loan card: approved withdrawal is shown separately and does not reduce Total Paid/Deposit */
.sm-member-dashboard-cards .sm-loan{border-left-color:#f59e0b!important;}
.sm-member-dashboard-cards .sm-loan .sm-card-icon{background:#fff7ed;color:#b45309;}
