:root{
  --navy:#12385b;
  --navy-2:#0b2945;
  --navy-3:#183f64;
  --blue:#1f6fb2;
  --blue-soft:#eaf3fb;
  --cyan:#2ba7c9;
  --green:#2d9b72;
  --green-soft:#eaf7f1;
  --amber:#d99524;
  --amber-soft:#fff6e6;
  --red:#cf4d58;
  --red-soft:#fdecef;
  --ink:#1c2b3a;
  --muted:#6b7b8d;
  --line:#dfe6ed;
  --surface:#ffffff;
  --surface-2:#f6f8fb;
  --shadow:0 8px 30px rgba(26,50,77,.08);
  --shadow-sm:0 3px 12px rgba(26,50,77,.07);
  --radius:14px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,"Segoe UI",Roboto,Arial,sans-serif;background:#eef2f6;color:var(--ink);font-size:14px;line-height:1.5}
a{color:inherit}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.icon{width:20px;height:20px;display:inline-block;flex:0 0 auto}
.app-shell{min-height:100vh;display:flex}
.sidebar{position:fixed;inset:0 auto 0 0;width:270px;background:linear-gradient(180deg,var(--navy-2) 0%,#0d3151 58%,#102d47 100%);color:#fff;z-index:40;display:flex;flex-direction:column;box-shadow:12px 0 35px rgba(14,39,61,.12)}
.brand{height:82px;display:flex;align-items:center;gap:13px;padding:0 23px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#4fc3df,#1c75b8);display:grid;place-items:center;font-weight:800;letter-spacing:.5px;box-shadow:0 8px 20px rgba(21,144,191,.28)}
.brand-copy{display:flex;flex-direction:column;min-width:0}
.brand-copy strong{font-size:17px;letter-spacing:.3px}
.brand-copy span{font-size:10px;text-transform:uppercase;letter-spacing:1.1px;color:#a9c0d2;white-space:nowrap}
.sidebar-section-label{font-size:10px;font-weight:700;letter-spacing:1.4px;color:#7fa0b9;padding:25px 25px 10px}
.sidebar-nav{padding:0 14px;display:flex;flex-direction:column;gap:5px}
.nav-link{position:relative;display:flex;align-items:center;gap:13px;padding:11px 13px;border-radius:10px;text-decoration:none;color:#c5d5e2;font-weight:600;transition:.2s ease}
.nav-link:hover{background:rgba(255,255,255,.07);color:#fff;transform:translateX(2px)}
.nav-link.active{background:linear-gradient(90deg,rgba(52,147,202,.28),rgba(37,107,164,.16));color:#fff;box-shadow:inset 0 0 0 1px rgba(110,196,232,.13)}
.nav-link.active .icon{color:#63c7e2}
.nav-indicator{position:absolute;right:10px;width:5px;height:5px;background:#66cee7;border-radius:50%;box-shadow:0 0 0 4px rgba(102,206,231,.12)}
.sidebar-status{margin:auto 17px 17px;padding:14px;border-radius:12px;background:rgba(255,255,255,.06);display:flex;align-items:center;gap:11px;border:1px solid rgba(255,255,255,.06)}
.status-dot{width:10px;height:10px;border-radius:50%;background:#42d392;box-shadow:0 0 0 5px rgba(66,211,146,.12)}
.sidebar-status div:last-child{display:flex;flex-direction:column}
.sidebar-status strong{font-size:12px}
.sidebar-status span{font-size:11px;color:#9fb6c8}
.sidebar-footer{padding:0 22px 20px;display:flex;flex-direction:column;color:#8fa9bc;font-size:10px}
.sidebar-footer small{opacity:.75}
.main-panel{margin-left:270px;min-width:0;min-height:100vh;width:calc(100% - 270px);display:flex;flex-direction:column}
.topbar{height:82px;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 30px;position:sticky;top:0;z-index:25}
.topbar-left,.topbar-right{display:flex;align-items:center}
.topbar-left{gap:13px}
.topbar-right{gap:14px}
.page-heading h1{margin:0;font-size:22px;line-height:1.15;font-weight:750;letter-spacing:-.3px;color:#173552}
.page-heading p{margin:4px 0 0;color:var(--muted);font-size:12px}
.icon-btn{width:38px;height:38px;border:none;border-radius:10px;background:#f3f6f9;color:#38546d;display:grid;place-items:center;transition:.2s}
.icon-btn:hover{background:#e9f0f6;color:var(--blue)}
.mobile-menu{display:none}
.topbar-date{display:flex;align-items:center;gap:8px;color:#5c7084;font-size:12px;border-right:1px solid var(--line);padding-right:16px}
.topbar-date .icon{width:17px;height:17px}
.notification-btn{position:relative}
.notification-dot{position:absolute;right:8px;top:8px;width:7px;height:7px;background:var(--red);border:2px solid #f3f6f9;border-radius:50%}
.user-menu{display:flex;align-items:center;gap:10px;padding-left:2px}
.avatar{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--navy),#2d7cb8);color:#fff;display:grid;place-items:center;font-weight:800}
.user-copy{display:flex;flex-direction:column;min-width:135px}
.user-copy strong{font-size:12px;color:#233c54}
.user-copy span{font-size:10px;color:#8795a3}
.logout-link{display:flex;color:#7b8c9b;text-decoration:none;padding:7px;border-radius:8px}
.logout-link:hover{background:var(--red-soft);color:var(--red)}
.content{padding:26px 30px 34px;flex:1}
.app-footer{display:flex;justify-content:space-between;gap:15px;padding:18px 30px;border-top:1px solid var(--line);background:#f9fbfd;color:#81909e;font-size:11px}
.page-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.actions-left,.actions-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{border:1px solid transparent;border-radius:9px;padding:9px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:12px;text-decoration:none;line-height:1.2;transition:.18s ease;white-space:nowrap}
.btn .icon{width:17px;height:17px}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:#0c2f4e}
.btn-secondary{background:#fff;border-color:var(--line);color:#36516a}
.btn-secondary:hover{border-color:#b8c8d6;background:#f8fafc}
.btn-success{background:var(--green);color:#fff}
.btn-warning{background:var(--amber);color:#fff}
.btn-danger{background:var(--red);color:#fff}
.btn-info{background:var(--blue);color:#fff}
.btn-ghost{background:transparent;color:var(--blue);padding:7px 8px}
.btn-sm{padding:7px 10px;font-size:11px;border-radius:8px}
.btn-icon{width:34px;height:34px;padding:0}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:17px;margin-bottom:20px}
.kpi-card{background:var(--surface);border:1px solid #e2e8ef;border-radius:var(--radius);padding:19px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.kpi-card::after{content:"";position:absolute;right:-28px;bottom:-34px;width:105px;height:105px;border-radius:50%;background:var(--kpi-soft,#edf4fa)}
.kpi-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;position:relative;z-index:1}
.kpi-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--kpi-soft,#edf4fa);color:var(--kpi-color,var(--blue))}
.kpi-icon .icon{width:21px;height:21px}
.kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:.65px;color:#738496;font-weight:750;margin-bottom:7px}
.kpi-value{font-size:29px;font-weight:800;line-height:1;color:#173552;letter-spacing:-.7px}
.kpi-footer{position:relative;z-index:1;margin-top:14px;display:flex;align-items:center;justify-content:space-between;color:#8493a1;font-size:10px}
.kpi-trend{display:inline-flex;align-items:center;gap:5px;font-weight:700;color:var(--kpi-color,var(--blue))}
.kpi-blue{--kpi-soft:#e9f3fb;--kpi-color:#2374b3}
.kpi-green{--kpi-soft:#e9f7f1;--kpi-color:#2d9b72}
.kpi-red{--kpi-soft:#fdecef;--kpi-color:#cf4d58}
.kpi-amber{--kpi-soft:#fff4df;--kpi-color:#d28b1d}
.grid-2{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(300px,.9fr);gap:18px;margin-bottom:20px}
.grid-2-equal{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:20px}
.panel{background:var(--surface);border:1px solid #e1e8ee;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.panel-header{padding:17px 19px;border-bottom:1px solid #e6ebf0;display:flex;align-items:center;justify-content:space-between;gap:15px}
.panel-title{display:flex;flex-direction:column}
.panel-title h2{font-size:14px;margin:0;color:#1f3b55;font-weight:800}
.panel-title p{font-size:10px;color:#8493a1;margin:3px 0 0}
.panel-actions{display:flex;gap:8px;align-items:center}
.panel-body{padding:18px 19px}
.panel-body.flush{padding:0}
.chart-wrap{height:285px;position:relative}
.chart-placeholder{height:100%;display:grid;place-items:center;color:#91a0ad;background:linear-gradient(#fff,#fbfcfe)}
.status-list{display:flex;flex-direction:column}
.status-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-bottom:1px solid #edf1f4}
.status-row:last-child{border-bottom:0}
.status-row-left{display:flex;align-items:center;gap:11px}
.status-symbol{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#edf3f8;color:#46637b}
.status-symbol .icon{width:17px;height:17px}
.status-copy{display:flex;flex-direction:column}
.status-copy strong{font-size:12px;color:#2a4258}
.status-copy span{font-size:10px;color:#8a98a5}
.status-value{font-size:12px;font-weight:800;color:#294760}
.system-health{display:flex;align-items:center;gap:14px;padding:15px;border-radius:12px;background:#f6f9fb;border:1px solid #e6edf2;margin-bottom:15px}
.health-ring{width:55px;height:55px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--green) var(--progress,75%),#dfe8ee 0);position:relative}
.health-ring::before{content:"";position:absolute;width:43px;height:43px;border-radius:50%;background:#fff}
.health-ring strong{position:relative;font-size:11px;color:#31516b}
.health-copy strong{display:block;font-size:12px;color:#28445d}
.health-copy span{font-size:10px;color:#8192a0}
.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.search-control{position:relative;min-width:260px;max-width:420px;flex:1}
.search-control .icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:#8b99a6}
.search-control input{width:100%;height:39px;padding:8px 12px 8px 36px;background:#fff;border:1px solid var(--line);border-radius:9px;color:var(--ink);outline:none}
.search-control input:focus{border-color:#78a9ce;box-shadow:0 0 0 3px rgba(42,116,174,.09)}
.filter-select{height:39px;border:1px solid var(--line);border-radius:9px;background:#fff;padding:0 32px 0 10px;color:#53687c;font-size:12px}
.table-responsive{width:100%;overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;min-width:800px}
.data-table th{padding:11px 14px;background:#f5f8fa;border-bottom:1px solid #dfe7ed;text-align:left;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:#6f8090;font-weight:800;white-space:nowrap}
.data-table td{padding:13px 14px;border-bottom:1px solid #edf1f4;vertical-align:middle;color:#405669;font-size:12px}
.data-table tbody tr:hover{background:#fafcfd}
.data-table tbody tr:last-child td{border-bottom:0}
.cell-title{display:flex;align-items:center;gap:10px}
.customer-avatar{width:34px;height:34px;border-radius:10px;background:#edf3f8;color:#2a668f;display:grid;place-items:center;font-size:11px;font-weight:800}
.cell-copy{display:flex;flex-direction:column}
.cell-copy strong{color:#253f55;font-size:12px}
.cell-copy span{color:#8795a3;font-size:10px}
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 8px;font-size:9px;font-weight:800;letter-spacing:.25px;text-transform:uppercase;white-space:nowrap}
.badge::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.badge-success{background:var(--green-soft);color:#25815f}
.badge-danger{background:var(--red-soft);color:#bc3e4a}
.badge-warning{background:var(--amber-soft);color:#b2700c}
.badge-info{background:var(--blue-soft);color:#226ba3}
.badge-neutral{background:#edf1f5;color:#667887}
.action-group{display:flex;gap:5px;align-items:center;justify-content:flex-end}
.empty-state{padding:55px 20px;text-align:center;color:#7f8f9d}
.empty-state .icon{width:44px;height:44px;margin-bottom:10px;color:#9db0bf}
.empty-state h3{margin:0 0 5px;color:#405b71;font-size:14px}
.empty-state p{margin:0 0 15px;font-size:11px}
.form-panel{max-width:920px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:11px;font-weight:750;color:#425a70}
.form-label .required{color:var(--red)}
.form-control{width:100%;height:42px;border:1px solid #dbe3e9;border-radius:9px;background:#fff;padding:9px 11px;outline:none;color:#243e55;transition:.18s}
textarea.form-control{height:auto;min-height:100px;resize:vertical}
.form-control:focus{border-color:#7da9c9;box-shadow:0 0 0 3px rgba(31,111,178,.08)}
.form-control:disabled{background:#f2f5f7;color:#768895}
.form-help{font-size:9px;color:#8a98a5}
.form-footer{display:flex;justify-content:flex-end;gap:9px;padding-top:19px;margin-top:20px;border-top:1px solid #e8edf1}
.info-banner{display:flex;align-items:flex-start;gap:11px;padding:13px 14px;background:#edf6fc;border:1px solid #d8eaf6;border-radius:10px;color:#315e7e;font-size:11px;margin-bottom:18px}
.info-banner .icon{width:18px;height:18px;margin-top:1px}
.alert{position:relative;border-radius:10px;padding:12px 42px 12px 14px;margin-bottom:18px;font-size:11px;font-weight:650;transition:.35s;box-shadow:var(--shadow-sm)}
.alert-success{background:var(--green-soft);color:#25775a;border:1px solid #cfeadd}
.alert-error,.alert-danger{background:var(--red-soft);color:#ae3845;border:1px solid #f2ccd1}
.alert-warning{background:var(--amber-soft);color:#9f6513;border:1px solid #f3dfb7}
.alert-info{background:var(--blue-soft);color:#25638f;border:1px solid #cfe4f3}
.alert-close{position:absolute;right:11px;top:50%;transform:translateY(-50%);border:0;background:transparent;color:inherit;font-size:18px}
.alert-hide{opacity:0;transform:translateY(-7px)}
.summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:18px;overflow:hidden}
.summary-item{padding:15px 17px;border-right:1px solid var(--line)}
.summary-item:last-child{border-right:0}
.summary-item span{display:block;font-size:9px;color:#8392a0;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.summary-item strong{display:block;font-size:17px;margin-top:3px;color:#28445c}
.progress{height:7px;background:#e8eef3;border-radius:999px;overflow:hidden}
.progress-bar{height:100%;background:var(--green);border-radius:999px}
.detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.detail-card{padding:14px;border:1px solid #e2e9ef;border-radius:11px;background:#fafcfd}
.detail-card span{font-size:9px;text-transform:uppercase;letter-spacing:.45px;color:#82909d;font-weight:700}
.detail-card strong{display:block;margin-top:5px;font-size:13px;color:#29465f}
.login-page{min-height:100vh;display:grid;grid-template-columns:minmax(360px,1.05fr) minmax(420px,.95fr);background:#f2f6f9}
.login-visual{position:relative;overflow:hidden;background:linear-gradient(140deg,#0c2943,#144c76 70%,#1e6e99);color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between}
.login-visual::before,.login-visual::after{content:"";position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.12)}
.login-visual::before{width:520px;height:520px;right:-230px;top:-210px}
.login-visual::after{width:360px;height:360px;left:-180px;bottom:-170px}
.login-brand{position:relative;display:flex;align-items:center;gap:13px}
.login-brand .brand-mark{width:48px;height:48px}
.login-message{position:relative;max-width:560px}
.login-message h1{font-size:44px;line-height:1.08;margin:0 0 16px;letter-spacing:-1.2px}
.login-message p{font-size:14px;color:#c5d8e6;max-width:470px}
.login-feature-list{position:relative;display:flex;gap:22px;flex-wrap:wrap;color:#c1d5e3;font-size:11px}
.login-feature{display:flex;align-items:center;gap:7px}
.login-feature::before{content:"✓";display:grid;place-items:center;width:19px;height:19px;border-radius:50%;background:rgba(83,211,166,.16);color:#64dfb3;font-weight:800}
.login-form-side{display:grid;place-items:center;padding:40px}
.login-card{width:min(420px,100%);background:#fff;border:1px solid #e2e8ee;border-radius:18px;padding:32px;box-shadow:0 18px 50px rgba(31,55,76,.1)}
.login-card h2{margin:0;color:#1c3b55;font-size:24px}
.login-card>p{margin:6px 0 23px;color:#8493a1;font-size:11px}
.login-card .form-group{margin-bottom:14px}
.login-submit{width:100%;height:43px;margin-top:5px}
.login-foot{margin-top:20px;text-align:center;color:#8b99a5;font-size:9px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(10,26,40,.45);z-index:35}
.mini-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.mini-stat{border:1px solid var(--line);border-radius:10px;padding:13px;background:#fafcfd}
.mini-stat span{font-size:9px;color:#8694a1;text-transform:uppercase;letter-spacing:.4px}
.mini-stat strong{display:block;font-size:17px;color:#2b4961;margin-top:3px}
.timeline{display:flex;flex-direction:column}
.timeline-item{display:grid;grid-template-columns:16px 1fr;gap:10px;padding-bottom:15px}
.timeline-marker{width:9px;height:9px;background:var(--blue);border-radius:50%;margin-top:4px;position:relative}
.timeline-marker::after{content:"";position:absolute;width:1px;height:35px;background:#dbe5ec;left:4px;top:10px}
.timeline-item:last-child .timeline-marker::after{display:none}
.timeline-copy strong{font-size:11px;color:#314c63;display:block}
.timeline-copy span{font-size:9px;color:#8a98a5}
@media (max-width:1200px){
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-2{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:980px){
  .sidebar{transform:translateX(-100%);transition:.25s ease}
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open .sidebar-overlay{display:block}
  .main-panel{margin-left:0;width:100%}
  .mobile-menu{display:grid}
  .topbar{padding:0 18px}
  .content{padding:20px 18px 28px}
  .app-footer{padding:16px 18px}
  .topbar-date{display:none}
  .login-page{grid-template-columns:1fr}
  .login-visual{display:none}
  .login-form-side{min-height:100vh}
}
@media (max-width:700px){
  .topbar{height:72px}
  .page-heading h1{font-size:18px}
  .page-heading p{display:none}
  .user-copy{display:none}
  .user-menu{gap:4px}
  .kpi-grid,.grid-2-equal,.form-grid,.summary-strip,.detail-grid{grid-template-columns:1fr}
  .summary-item{border-right:0;border-bottom:1px solid var(--line)}
  .summary-item:last-child{border-bottom:0}
  .content{padding:16px 12px 25px}
  .panel-header,.panel-body{padding-left:14px;padding-right:14px}
  .app-footer{flex-direction:column;padding:14px 12px}
  .search-control{min-width:100%}
  .page-actions,.actions-left,.actions-right{width:100%}
  .actions-right .btn,.actions-left .btn{flex:1}
  .form-footer{flex-direction:column-reverse}
  .form-footer .btn{width:100%}
}

/* ===== ERP Mobile Refresh 2.1 ===== */
body{
  background:
    radial-gradient(circle at top left, rgba(31,111,178,.08), transparent 28%),
    radial-gradient(circle at top right, rgba(43,167,201,.10), transparent 22%),
    #eef2f6;
}
.app-shell{position:relative}
.main-panel{background:transparent}
.topbar{
  position:sticky;
  top:0;
  z-index:25;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  background:rgba(248,250,252,.82);
  border-bottom:1px solid rgba(223,230,237,.75);
  box-shadow:0 8px 22px rgba(18,56,91,.05);
}
.eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:#5583a8;margin-bottom:4px}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,#2ba7c9,#1f6fb2);box-shadow:0 0 0 5px rgba(43,167,201,.08)}
.page-heading h1{letter-spacing:-.2px}
.page-actions,.summary-strip,.panel,.kpi-card,.info-banner,.alert,.login-card,.mini-stat,.detail-card{box-shadow:0 10px 28px rgba(21,49,76,.06)}
.page-actions{
  position:sticky;
  top:88px;
  z-index:18;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(223,230,237,.95);
}
.panel{overflow:hidden}
.panel-header{background:linear-gradient(180deg,rgba(249,251,253,.95),rgba(255,255,255,.96))}
.panel-title p{max-width:760px}
.kpi-card{
  position:relative;
  overflow:hidden;
  border-radius:18px;
}
.kpi-card::after{
  content:"";
  position:absolute;
  width:120px;
  height:120px;
  right:-40px;
  bottom:-40px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
}
.btn{
  border-radius:12px;
  min-height:40px;
  font-weight:700;
}
.btn-sm{min-height:34px}
.btn-icon{min-width:34px}
.search-control, .filter-select{min-height:42px;border-radius:12px}
.form-control{border-radius:12px;min-height:44px}
.form-footer{gap:12px}
.status-row,.detail-card,.mini-stat{border-radius:12px}
.status-row{border:1px solid #e7edf2;background:#fbfcfd}
.table-toolbar{gap:10px;align-items:stretch}
.table-responsive{border-radius:14px}
.data-table thead th{background:#f9fbfc}
.data-table td{font-size:12px}
.action-group{flex-wrap:wrap;row-gap:6px}
.user-menu{padding:6px 8px 6px 6px;background:rgba(255,255,255,.7);border:1px solid rgba(223,230,237,.9);border-radius:999px}
.notification-btn{background:rgba(255,255,255,.75);border:1px solid rgba(223,230,237,.9)}
.mobile-bottom-nav{display:none}

/* Optional mobile card table mode */
.data-table.table-mobile-cards td[data-label]{position:relative}

/* Better mobile experience */
@media (max-width:980px){
  .content{padding-bottom:88px}
  .page-actions{top:80px}
}
@media (max-width:700px){
  body{font-size:13px}
  .content{padding:14px 12px 92px}
  .topbar{height:auto;min-height:72px;padding:12px}
  .topbar-left,.topbar-right{align-items:flex-start}
  .page-heading h1{font-size:19px;line-height:1.15}
  .page-actions{
    top:74px;
    padding:12px;
    border-radius:16px;
  }
  .actions-left,.actions-right{display:grid;grid-template-columns:1fr;gap:8px}
  .actions-right .btn,.actions-left .btn{width:100%;justify-content:center}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:10px}
  .kpi-card{padding:14px}
  .kpi-value{font-size:24px}
  .kpi-footer{gap:8px;align-items:flex-start;flex-direction:column}
  .summary-strip{
    grid-template-columns:repeat(2,minmax(0,1fr));
    border-radius:16px;
    overflow:hidden;
  }
  .summary-item{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .summary-item:nth-child(2n){border-right:0}
  .summary-item:nth-last-child(-n+2){border-bottom:0}
  .summary-item strong{font-size:16px}
  .table-toolbar{display:grid;grid-template-columns:1fr;gap:8px}
  .search-control{min-width:100%;width:100%}
  .filter-select{width:100%}
  .action-group{justify-content:stretch}
  .action-group .btn,.action-group form{flex:1 1 calc(50% - 4px)}
  .action-group form .btn{width:100%}
  .mobile-bottom-nav{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:2px;
    padding:8px 8px calc(8px + env(safe-area-inset-bottom));
    background:rgba(10,26,40,.92);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    z-index:34;
    box-shadow:0 -10px 24px rgba(7,18,29,.18);
  }
  .mobile-nav-link{
    color:#a9bed0;
    text-decoration:none;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    border-radius:14px;
    padding:8px 4px;
    font-size:9px;
    font-weight:700;
    letter-spacing:.2px;
  }
  .mobile-nav-link .icon{width:18px;height:18px}
  .mobile-nav-link.active{background:rgba(255,255,255,.09);color:#fff}
  .mobile-nav-link.active .icon{color:#61cae4}

  /* Transform tables into stacked cards for phone */
  .table-responsive{overflow:visible;border:0;background:transparent}
  .data-table.table-mobile-cards,
  .data-table.table-mobile-cards thead,
  .data-table.table-mobile-cards tbody,
  .data-table.table-mobile-cards th,
  .data-table.table-mobile-cards td,
  .data-table.table-mobile-cards tr{display:block;width:100%}
  .data-table.table-mobile-cards thead{display:none}
  .data-table.table-mobile-cards tbody{display:grid;gap:10px}
  .data-table.table-mobile-cards tr{
    background:#fff;
    border:1px solid #e4ebf1;
    border-radius:16px;
    box-shadow:0 8px 22px rgba(18,56,91,.06);
    padding:6px 0;
  }
  .data-table.table-mobile-cards td{
    border-bottom:1px dashed #edf1f4;
    padding:10px 14px;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    text-align:right;
  }
  .data-table.table-mobile-cards td:last-child{border-bottom:0}
  .data-table.table-mobile-cards td::before{
    content:attr(data-label);
    color:#7f8f9d;
    font-size:10px;
    font-weight:800;
    letter-spacing:.55px;
    text-transform:uppercase;
    text-align:left;
    flex:0 0 38%;
  }
  .data-table.table-mobile-cards td .cell-title{justify-content:flex-end;width:100%}
  .data-table.table-mobile-cards td .cell-copy{align-items:flex-end;text-align:right}
  .data-table.table-mobile-cards td .badge{margin-left:auto}
  .data-table.table-mobile-cards td .action-group{width:100%;justify-content:flex-end}
  .data-table.table-mobile-cards td .action-group .btn,
  .data-table.table-mobile-cards td .action-group form{flex:1 1 100%}
  .data-table.table-mobile-cards td .action-group .btn{justify-content:center}

  .login-card{padding:24px 18px;border-radius:18px}
  .login-form-side{padding:18px}
  .app-footer{padding-bottom:80px}
}
@media (max-width:420px){
  .kpi-grid{grid-template-columns:1fr}
  .summary-strip{grid-template-columns:1fr}
  .summary-item{border-right:0}
  .summary-item:nth-last-child(-n+2){border-bottom:1px solid var(--line)}
  .summary-item:last-child{border-bottom:0}
  .data-table.table-mobile-cards td{flex-direction:column;align-items:flex-start;text-align:left}
  .data-table.table-mobile-cards td::before{flex:0 0 auto}
  .data-table.table-mobile-cards td .cell-title,
  .data-table.table-mobile-cards td .cell-copy{align-items:flex-start;text-align:left}
  .data-table.table-mobile-cards td .badge{margin-left:0}
  .data-table.table-mobile-cards td .action-group{justify-content:stretch}
}
@media print{
  .mobile-bottom-nav,.sidebar,.sidebar-overlay,.mobile-menu,.notification-btn,.page-actions{display:none !important}
  .main-panel{margin-left:0;width:100%}
  .topbar{position:static;box-shadow:none;background:#fff}
  .content{padding:0}
}

/* ===== Customer Price & Phone UX 2.2 ===== */
html{-webkit-text-size-adjust:100%}
button,a,.btn,.nav-link,.mobile-nav-link{touch-action:manipulation}
input,select,textarea{accent-color:var(--blue)}
.price-text{color:#15658d;font-size:12px;white-space:nowrap}
.currency-input{
  display:flex;
  align-items:center;
  border:1px solid #cfd9e2;
  background:#fff;
  border-radius:12px;
  overflow:hidden;
  min-height:44px;
  transition:border-color .18s,box-shadow .18s;
}
.currency-input:focus-within{border-color:#6ba9d4;box-shadow:0 0 0 4px rgba(31,111,178,.10)}
.currency-input>span{align-self:stretch;display:grid;place-items:center;padding:0 14px;background:#f2f6f9;color:#46647c;font-weight:800;border-right:1px solid #dce5ec}
.currency-input .form-control{border:0!important;box-shadow:none!important;border-radius:0;min-width:0;font-size:16px;font-weight:800;color:#173e5d}
.currency-input-lg{min-height:58px;border-radius:15px}
.currency-input-lg>span{font-size:16px;padding:0 18px}
.currency-input-lg .form-control{font-size:23px}
.price-summary-card{display:flex;align-items:center;gap:14px;padding:17px;border-radius:16px;background:linear-gradient(135deg,#0e3d63,#176c9d);color:#fff;margin-bottom:20px;box-shadow:0 14px 30px rgba(15,72,108,.20)}
.price-summary-icon{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.13);flex:0 0 auto}
.price-summary-copy{display:flex;flex-direction:column;min-width:0;flex:1}
.price-summary-copy span{font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:#bfe5f4;font-weight:800}
.price-summary-copy strong{font-size:25px;line-height:1.15;margin:3px 0}
.price-summary-copy small{font-size:10px;color:#c9e1ec}
.price-summary-card .badge{background:rgba(255,255,255,.13);color:#fff;border-color:rgba(255,255,255,.16)}
.text-button{border:0;background:transparent;color:var(--blue);padding:7px 0 0;font-size:11px;font-weight:800;text-align:left}
.text-button:hover{text-decoration:underline}
.compact-form-panel{max-width:620px;margin:0 auto}
.price-editor-hero{text-align:center;border:1px solid #dce8f0;background:linear-gradient(180deg,#f7fbfe,#edf6fb);border-radius:17px;padding:22px 16px;margin-bottom:20px}
.price-editor-hero span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#678398;font-weight:800}
.price-editor-hero strong{display:block;font-size:31px;line-height:1.2;color:#0f4f78;margin:6px 0}
.price-editor-hero small{color:#708698;font-size:11px}
.btn-full{width:100%;margin-top:10px}
.mobile-fab{display:none}

@media (hover:none){
  .btn:hover,.nav-link:hover{transform:none;box-shadow:none}
  .btn:active,.mobile-nav-link:active{transform:scale(.97);opacity:.9}
}
@media (max-width:700px){
  .panel{border-radius:17px}
  .panel-header{padding-top:15px;padding-bottom:15px}
  .panel-title h2{font-size:15px}
  .btn{min-height:44px;font-size:12px}
  .btn-sm{min-height:40px}
  .form-control{font-size:16px} /* mencegah zoom otomatis iPhone */
  .price-summary-card{align-items:flex-start;padding:15px;flex-wrap:wrap}
  .price-summary-copy strong{font-size:23px}
  .price-summary-card .badge{margin-left:60px}
  .price-editor-hero{padding:24px 14px}
  .price-editor-hero strong{font-size:29px}
  .mobile-fab{
    position:fixed;
    right:16px;
    bottom:84px;
    z-index:33;
    display:flex;
    align-items:center;
    gap:7px;
    padding:12px 16px;
    border-radius:999px;
    background:linear-gradient(135deg,#1d78b6,#1ea4c1);
    color:#fff;
    font-weight:800;
    font-size:12px;
    text-decoration:none;
    box-shadow:0 14px 30px rgba(24,111,159,.32);
  }
  .mobile-fab .icon{width:18px;height:18px}
  .data-table.table-mobile-cards td[data-label="Harga/Bulan"]{background:#f7fbfd}
  .data-table.table-mobile-cards td[data-label="Harga/Bulan"] .price-text{font-size:15px}
  .compact-form-panel .form-footer{position:sticky;bottom:76px;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);padding:12px;margin:18px -14px -14px;border-top:1px solid var(--line);z-index:5}
}
@media (max-width:420px){
  .price-summary-card .badge{margin-left:0}
  .mobile-fab span{display:none}
  .mobile-fab{width:50px;height:50px;padding:0;justify-content:center}
}

/* ===== Period Reports & Sidebar Submenu 2.3 ===== */
.sidebar-nav{overflow-y:auto;overscroll-behavior:contain;padding-bottom:8px}
.nav-group{display:flex;flex-direction:column}
.nav-parent{width:100%;border:0;background:transparent;text-align:left;font-family:inherit}
.nav-parent>span:nth-of-type(1){flex:1}
.submenu-chevron{display:grid;place-items:center;margin-left:auto;transition:transform .2s ease;color:#7fa7c2}
.submenu-chevron .icon{width:15px;height:15px}
.nav-group.open .submenu-chevron{transform:rotate(90deg)}
.nav-submenu{display:grid;grid-template-rows:0fr;opacity:.2;transition:grid-template-rows .22s ease,opacity .22s ease}
.nav-submenu>*{overflow:hidden}
.nav-group.open .nav-submenu{grid-template-rows:1fr;opacity:1}
.nav-submenu::before{content:"";display:block;overflow:hidden}
.nav-sublink{position:relative;display:flex;align-items:center;gap:10px;margin:2px 5px 2px 27px;padding:9px 10px;border-radius:9px;color:#9fb8ca;text-decoration:none;font-size:11px;font-weight:700;transition:.18s ease}
.nav-sublink:hover{color:#fff;background:rgba(255,255,255,.055)}
.nav-sublink.active{color:#fff;background:rgba(64,168,214,.13)}
.submenu-dot{width:6px;height:6px;border:1.5px solid currentColor;border-radius:50%;flex:0 0 auto}
.nav-sublink.active .submenu-dot{background:#62cbe5;border-color:#62cbe5;box-shadow:0 0 0 4px rgba(98,203,229,.10)}

.period-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:16px}
.period-tab{display:flex;align-items:center;justify-content:center;gap:9px;min-height:48px;padding:10px 13px;background:rgba(255,255,255,.78);border:1px solid #dce5ec;border-radius:13px;text-decoration:none;color:#557086;font-size:11px;font-weight:800;box-shadow:0 4px 14px rgba(18,56,91,.04);transition:.18s ease}
.period-tab .icon{width:18px;height:18px}
.period-tab:hover{border-color:#a9c8dc;color:#1f6f9e;transform:translateY(-1px)}
.period-tab.active{background:linear-gradient(135deg,#12385b,#176e9b);border-color:transparent;color:#fff;box-shadow:0 12px 25px rgba(18,73,111,.20)}
.period-filter-panel{margin-bottom:16px}
.period-filter-form{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}
.period-filter-form>.form-group{min-width:210px;flex:1}
.period-filter-form>.form-group .form-control{min-height:44px}
.period-filter-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.period-heading-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:17px 19px;margin-bottom:17px;border-radius:15px;background:linear-gradient(135deg,#f7fbfe,#edf5fa);border:1px solid #dce8f0}
.period-heading-card>div{display:flex;flex-direction:column}
.period-heading-card>div>span{font-size:9px;font-weight:850;letter-spacing:1.1px;color:#6e8a9e}
.period-heading-card>div>strong{font-size:20px;color:#123f60;margin:2px 0}
.period-heading-card>div>small{font-size:10px;color:#7d909e}
.period-money{font-size:21px;white-space:nowrap}
.period-chart-list{display:flex;flex-direction:column;gap:10px;max-height:420px;overflow:auto;padding-right:4px}
.period-chart-row{display:grid;grid-template-columns:92px minmax(100px,1fr) 105px;align-items:center;gap:10px}
.period-chart-label{font-size:10px;color:#60788c;font-weight:750;white-space:nowrap}
.period-chart-track{height:10px;background:#eaf0f4;border-radius:999px;overflow:hidden}
.period-chart-bar{height:100%;min-width:0;background:linear-gradient(90deg,#1f6fb2,#2ba7c9);border-radius:999px;box-shadow:0 3px 8px rgba(31,111,178,.18)}
.period-chart-row strong{text-align:right;font-size:10px;color:#31526b;white-space:nowrap}
.payment-method-list{display:flex;flex-direction:column;gap:13px}
.payment-method-row{display:flex;gap:12px;align-items:flex-start;padding:13px;border:1px solid #e4ebf0;background:#fafcfd;border-radius:13px}
.payment-method-icon{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:#eaf3fb;color:#1f6fb2;flex:0 0 auto}
.payment-method-icon .icon{width:18px;height:18px}
.payment-method-copy{min-width:0;flex:1}
.payment-method-copy>div:first-child{display:flex;justify-content:space-between;gap:10px;margin-bottom:7px}
.payment-method-copy strong{font-size:11px;color:#304b61}
.payment-method-copy span{font-size:10px;font-weight:800;color:#1f6fb2}
.payment-method-copy small{display:block;margin-top:6px;font-size:10px;color:#73889a;font-weight:700;text-align:right}
.compact-empty{padding:35px 15px}

@media (max-width:700px){
  .sidebar-nav{padding-bottom:90px}
  .nav-sublink{min-height:42px;margin-left:24px;font-size:12px}
  .period-tabs{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;overflow-x:auto;padding-bottom:2px}
  .period-tab{min-width:72px;min-height:55px;flex-direction:column;gap:3px;padding:7px 4px;border-radius:13px;font-size:9px}
  .period-tab .icon{width:17px;height:17px}
  .period-filter-form{display:grid;grid-template-columns:1fr;gap:10px}
  .period-filter-form>.form-group{min-width:0;width:100%}
  .period-filter-actions{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:8px}
  .period-filter-actions .btn{width:100%;min-width:0}
  .period-filter-actions .btn:first-child{grid-column:1/-1}
  .period-heading-card{align-items:flex-start;padding:15px;flex-direction:column}
  .period-heading-card>div>strong{font-size:18px}
  .period-kpi-grid{grid-template-columns:1fr 1fr}
  .period-money{font-size:18px!important}
  .period-chart-list{max-height:340px}
  .period-chart-row{grid-template-columns:58px minmax(60px,1fr) 83px;gap:7px}
  .period-chart-label,.period-chart-row strong{font-size:8.5px}
}
@media (max-width:420px){
  .period-kpi-grid{grid-template-columns:1fr}
  .period-filter-actions{grid-template-columns:1fr}
  .period-filter-actions .btn:first-child{grid-column:auto}
  .period-chart-row{grid-template-columns:52px minmax(45px,1fr) 78px}
}
@media print{
  .period-tabs,.period-filter-panel{display:none!important}
  .period-chart-list{max-height:none;overflow:visible}
}
/* Stable submenu animation override */
.nav-submenu{display:flex;flex-direction:column;max-height:0;overflow:hidden;opacity:.2;transition:max-height .24s ease,opacity .2s ease}
.nav-submenu::before{display:none}
.nav-group.open .nav-submenu{max-height:280px;opacity:1}

/* ===== WhatsApp Reminder H-1 2.4 ===== */
.notification-btn{position:relative;text-decoration:none}
.notification-count{position:absolute;top:-5px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#df3d45;color:#fff;border:2px solid #fff;display:grid;place-items:center;font-size:8px;font-weight:900;line-height:1}
.toggle-field{display:flex;align-items:flex-start;gap:11px;min-height:52px;padding:12px 13px;border:1px solid #dce5ec;background:#f8fbfd;border-radius:13px;cursor:pointer}
.toggle-field input{width:18px;height:18px;margin-top:2px;accent-color:#1f7fbc;flex:0 0 auto}
.toggle-field span{display:flex;flex-direction:column;gap:3px}
.toggle-field strong{font-size:11px;color:#294a62}
.toggle-field small{font-size:10px;color:#72899a;line-height:1.45}
.reminder-dashboard-panel{margin-bottom:18px;border-color:#f1d48d;box-shadow:0 10px 26px rgba(174,119,16,.08)}
.reminder-dashboard-panel>.panel-header{background:linear-gradient(135deg,#fffaf0,#fff4d8)}
.reminder-dashboard-panel .panel-title h2{display:flex;align-items:center;gap:8px;color:#7d5310}
.reminder-dashboard-panel .panel-title h2 .icon{color:#1f9d68}
.reminder-customer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.reminder-customer-card{border:1px solid #e3e9ed;background:#fff;border-radius:15px;padding:14px;box-shadow:0 5px 15px rgba(23,61,88,.045)}
.reminder-card-top{display:flex;align-items:center;gap:9px;margin-bottom:13px}
.reminder-card-copy{display:flex;flex-direction:column;min-width:0;flex:1}
.reminder-card-copy strong{font-size:11px;color:#29495f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reminder-card-copy span{font-size:9.5px;color:#7a8d9b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reminder-card-detail{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 0;border-top:1px dashed #e7edf1}
.reminder-card-detail span{font-size:9px;color:#8193a1;text-transform:uppercase;letter-spacing:.5px;font-weight:800}
.reminder-card-detail strong{font-size:10.5px;color:#35546a;text-align:right}
.reminder-card-actions{display:flex;align-items:center;gap:7px;margin-top:10px;min-height:40px}
.reminder-card-actions form{margin:0;flex:1}
.reminder-card-actions form .btn{width:100%}
.sent-note{display:flex;align-items:center;gap:6px;color:#26845f;font-size:10px;font-weight:800;flex:1}
.sent-note .icon{width:16px;height:16px}
.reminder-more{text-align:center;padding-top:14px}
.reminder-more a{font-size:11px;font-weight:800;color:#1f6fb2;text-decoration:none}
.reminder-empty{padding:24px 10px}
.reminder-toolbar{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:14px 15px;border:1px solid #e3e9ed;background:#f8fbfd;border-radius:14px;margin-bottom:15px}
.reminder-toolbar>div{display:flex;flex-direction:column;gap:3px}
.reminder-toolbar strong{font-size:12px;color:#315169}
.reminder-toolbar span{font-size:10px;color:#7890a0}
.reminder-toolbar form{margin:0}
.table-note{display:block;margin-top:5px;font-size:9px;color:#7c8e9b}
.cron-card{display:grid;grid-template-columns:minmax(180px,.8fr) minmax(260px,1.2fr);align-items:center;gap:18px;padding:16px;border:1px solid #dce7ee;border-radius:15px;background:linear-gradient(135deg,#f9fcfe,#edf6fb)}
.cron-card>div{display:flex;flex-direction:column;gap:3px}
.cron-card span{font-size:9px;letter-spacing:.9px;text-transform:uppercase;font-weight:850;color:#6d8799}
.cron-card strong{font-size:13px;color:#264b65}
.cron-card small{font-size:10px;color:#71889a}
.cron-card code,.info-banner code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;background:rgba(18,56,91,.08);padding:2px 5px;border-radius:5px}

@media (max-width:1000px){
  .reminder-customer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:700px){
  .reminder-dashboard-panel .panel-header{align-items:flex-start}
  .reminder-dashboard-panel .panel-actions{width:100%;justify-content:space-between}
  .reminder-customer-grid{grid-template-columns:1fr}
  .reminder-toolbar{align-items:stretch;flex-direction:column}
  .reminder-toolbar .btn{width:100%}
  .cron-card{grid-template-columns:1fr;gap:12px}
  .notification-count{top:-3px;right:-3px}
}

/* Dashboard reminder H-1 v2.2 */
.dashboard-reminder-strip{display:flex;align-items:center;gap:14px;margin:0 0 18px;padding:14px 16px;border:1px solid #dfe8ee;border-radius:16px;background:#fff;box-shadow:0 7px 20px rgba(28,64,91,.06)}
.dashboard-reminder-strip.has-reminder{border-color:#efc66c;background:linear-gradient(135deg,#fff9e9,#fff3ce);box-shadow:0 10px 28px rgba(184,119,0,.12)}
.dashboard-reminder-strip.no-reminder{border-color:#bfe4d4;background:linear-gradient(135deg,#f5fffa,#effbf5)}
.dashboard-reminder-strip-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;flex:0 0 auto;background:#fff;color:#1e8d63;box-shadow:0 5px 14px rgba(20,70,50,.08)}
.dashboard-reminder-strip.has-reminder .dashboard-reminder-strip-icon{color:#a76900}
.dashboard-reminder-strip-icon .icon{width:23px;height:23px}
.dashboard-reminder-strip-copy{min-width:0;display:flex;flex-direction:column;gap:3px;flex:1}
.dashboard-reminder-strip-copy strong{font-size:15px;color:#18364c}
.dashboard-reminder-strip-copy span{font-size:13px;line-height:1.45;color:#607585}
.upcoming-reminder-block{margin-top:16px;border-top:1px solid #e7edf1;padding-top:16px}
.upcoming-reminder-heading{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}
.upcoming-reminder-heading strong{font-size:14px;color:#203e54}
.upcoming-reminder-heading span{font-size:12px;color:#718492}
.upcoming-reminder-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.upcoming-reminder-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px 12px;border:1px solid #e3eaee;border-radius:13px;background:#fff;text-decoration:none;color:inherit;transition:.18s ease}
.upcoming-reminder-item:hover{border-color:#a9c9da;transform:translateY(-1px);box-shadow:0 6px 15px rgba(30,70,95,.07)}
.upcoming-reminder-item>div:nth-child(2){min-width:0;display:flex;flex-direction:column;gap:2px}
.upcoming-reminder-item>div:nth-child(2) strong{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.upcoming-reminder-item>div:nth-child(2) span{font-size:11px;color:#768895;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.upcoming-reminder-date{text-align:right;display:flex;flex-direction:column;gap:2px}
.upcoming-reminder-date strong{font-size:11px;color:#a36900}
.upcoming-reminder-date span{font-size:11px;color:#70828f}
@media(max-width:760px){.dashboard-reminder-strip{align-items:flex-start;flex-wrap:wrap}.dashboard-reminder-strip .btn{width:100%;justify-content:center}.upcoming-reminder-list{grid-template-columns:1fr}}

/* ===== QRIS BCA Payment 2.5 ===== */
.qris-admin-summary>.panel-header{background:linear-gradient(135deg,#f2f8fd,#eaf4fb)}
.qris-admin-summary .panel-title h2{display:flex;align-items:center;gap:8px;color:#174d77}
.qris-admin-grid{display:grid;grid-template-columns:minmax(220px,.65fr) minmax(300px,1.35fr);gap:20px;align-items:start}
.qris-preview-card{min-height:245px;border:1px solid #dbe6ee;background:#f8fbfd;border-radius:17px;padding:14px;display:grid;place-items:center;overflow:hidden}
.qris-preview-card.large{min-height:310px}
.qris-preview-card img{display:block;max-width:100%;width:auto;max-height:390px;object-fit:contain;border-radius:10px;background:#fff}
.qris-preview-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:30px 15px;color:#718695}
.qris-preview-empty .icon{width:44px;height:44px;color:#2b75a8}
.qris-preview-empty strong{font-size:13px;color:#31546c}
.qris-preview-empty span{font-size:10px;line-height:1.5}
.qris-config-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.qris-config-details .qris-warning{grid-column:1/-1}
.qris-warning{border-color:#f0d28a!important;background:#fff8e7!important;color:#73510e!important}
.qris-settings-grid{display:grid;grid-template-columns:minmax(240px,.7fr) minmax(340px,1.3fr);gap:22px;align-items:start}
.qris-settings-preview{min-width:0}
.input-with-suffix{display:flex;align-items:stretch}
.input-with-suffix .form-control{border-radius:11px 0 0 11px}
.input-with-suffix>span{display:flex;align-items:center;padding:0 13px;border:1px solid #d6e1e9;border-left:0;background:#edf3f7;border-radius:0 11px 11px 0;font-size:10px;font-weight:850;color:#526d81}
.panel-title h2>.icon{width:19px;height:19px}
@media(max-width:900px){.qris-admin-grid,.qris-settings-grid{grid-template-columns:1fr}.qris-config-details{grid-template-columns:1fr}.qris-config-details .qris-warning{grid-column:auto}}
@media(max-width:700px){.qris-preview-card.large{min-height:240px}.qris-admin-grid{gap:14px}.qris-settings-grid{gap:16px}}

/* ===== OWY NET Mobile Wallet UI 2.6 ===== */
.mobile-wallet-hero{display:none}

@media (max-width:700px){
  :root{
    --app-blue:#118eea;
    --app-blue-dark:#0872cf;
    --app-blue-soft:#eaf6ff;
    --app-bg:#f4f8fc;
  }
  html{background:var(--app-bg)}
  body{
    background:var(--app-bg);
    color:#18364d;
    overscroll-behavior-y:none;
  }
  .main-panel{background:var(--app-bg)}
  .topbar{
    min-height:84px;
    padding:calc(12px + env(safe-area-inset-top)) 14px 14px;
    background:linear-gradient(145deg,var(--app-blue) 0%,#0b7edf 58%,#066cc4 100%);
    border:0;
    border-radius:0 0 26px 26px;
    box-shadow:0 10px 25px rgba(8,99,181,.20);
    color:#fff;
  }
  .topbar-left{gap:10px;min-width:0;align-items:center}
  .topbar-right{gap:8px;align-items:center}
  .page-heading{min-width:0}
  .page-heading .eyebrow{display:none}
  .page-heading h1{
    color:#fff;
    font-size:19px;
    font-weight:850;
    letter-spacing:-.35px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:48vw;
  }
  .page-heading p{display:none}
  .mobile-menu,.notification-btn{
    display:grid;
    width:40px;
    height:40px;
    border:1px solid rgba(255,255,255,.22);
    background:rgba(255,255,255,.14);
    color:#fff;
    border-radius:14px;
    box-shadow:none;
  }
  .mobile-menu:hover,.notification-btn:hover{background:rgba(255,255,255,.22);color:#fff}
  .notification-count{border-color:#0b7edf;background:#ff4d5e;top:-4px;right:-4px}
  .topbar-date,.user-copy,.logout-link{display:none}
  .user-menu{padding:0;background:transparent;border:0}
  .avatar{
    width:40px;
    height:40px;
    border-radius:14px;
    background:#fff;
    color:var(--app-blue-dark);
    box-shadow:0 7px 16px rgba(1,52,101,.16);
  }
  .sidebar{
    width:min(86vw,330px);
    border-radius:0 28px 28px 0;
    overflow:hidden;
    box-shadow:18px 0 45px rgba(4,31,56,.26);
  }
  .content{padding:14px 12px calc(116px + env(safe-area-inset-bottom))}
  body[data-page="dashboard"] .content{padding-top:12px}
  body[data-page="dashboard"] .page-actions{display:none}

  .mobile-wallet-hero{display:block;margin-bottom:15px}
  .wallet-blue-card{
    position:relative;
    overflow:hidden;
    padding:20px 18px 42px;
    border-radius:23px;
    background:linear-gradient(145deg,#1296ed 0%,#087bdc 58%,#0868bd 100%);
    color:#fff;
    box-shadow:0 16px 32px rgba(7,111,201,.24);
  }
  .wallet-blue-card::before,
  .wallet-blue-card::after{
    content:"";
    position:absolute;
    border-radius:50%;
    background:rgba(255,255,255,.09);
    pointer-events:none;
  }
  .wallet-blue-card::before{width:170px;height:170px;right:-68px;top:-82px}
  .wallet-blue-card::after{width:115px;height:115px;left:-55px;bottom:-68px}
  .wallet-card-head,.wallet-balance,.wallet-mini-stats{position:relative;z-index:1}
  .wallet-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
  .wallet-card-head>div{display:flex;flex-direction:column;gap:2px}
  .wallet-kicker{font-size:9px;letter-spacing:1.35px;font-weight:850;opacity:.76}
  .wallet-card-head strong{font-size:14px;font-weight:800}
  .wallet-live{display:inline-flex;align-items:center;gap:5px;padding:6px 9px;border-radius:999px;background:rgba(255,255,255,.15);font-size:9px;font-weight:900;letter-spacing:.7px}
  .wallet-live i{width:6px;height:6px;border-radius:50%;background:#7cffb8;box-shadow:0 0 0 4px rgba(124,255,184,.13)}
  .wallet-balance{display:flex;flex-direction:column;margin-top:21px}
  .wallet-balance span{font-size:11px;opacity:.78}
  .wallet-balance strong{font-size:29px;line-height:1.15;letter-spacing:-.8px;margin-top:3px;font-weight:900}
  .wallet-mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:20px}
  .wallet-mini-stats>div{display:flex;flex-direction:column;gap:2px;padding:9px 10px;border-radius:13px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.10)}
  .wallet-mini-stats span{font-size:8.5px;opacity:.74;white-space:nowrap}
  .wallet-mini-stats strong{font-size:15px;font-weight:900}
  .wallet-quick-actions{
    position:relative;
    z-index:3;
    margin:-25px 12px 0;
    padding:13px 8px 10px;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:4px;
    border:1px solid #e8eef4;
    border-radius:21px;
    background:#fff;
    box-shadow:0 13px 30px rgba(21,62,94,.12);
  }
  .wallet-quick-actions a{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;text-decoration:none;color:#35536b;font-size:9.5px;font-weight:800;min-width:0}
  .wallet-action-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:var(--app-blue-soft);color:var(--app-blue);transition:.18s ease}
  .wallet-action-icon .icon{width:20px;height:20px}
  .wallet-quick-actions a:active .wallet-action-icon{transform:scale(.93);background:#d7efff}

  .page-actions{
    position:relative;
    top:auto;
    margin:0 0 13px;
    padding:11px;
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    background:#fff;
    border:1px solid #e5edf3;
    border-radius:19px;
    box-shadow:0 9px 24px rgba(25,63,91,.07);
  }
  .actions-left,.actions-right{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%}
  .page-actions .btn{width:100%;min-height:45px;border-radius:14px;padding:9px 10px;white-space:normal;text-align:center}

  .dashboard-reminder-strip{
    margin-bottom:13px;
    padding:14px;
    gap:11px;
    border-radius:19px;
    box-shadow:0 9px 23px rgba(26,61,88,.07);
  }
  .dashboard-reminder-strip-icon{width:42px;height:42px;border-radius:14px}
  .dashboard-reminder-strip-copy strong{font-size:13px}
  .dashboard-reminder-strip-copy span{font-size:10.5px;line-height:1.45}
  .dashboard-reminder-strip .btn{min-height:40px;border-radius:13px}

  .kpi-grid{
    display:flex!important;
    grid-template-columns:none!important;
    gap:10px;
    overflow-x:auto;
    margin:0 -12px 15px;
    padding:0 12px 6px;
    scroll-snap-type:x mandatory;
    scrollbar-width:none;
  }
  .kpi-grid::-webkit-scrollbar{display:none}
  .kpi-card{
    flex:0 0 160px;
    min-height:145px;
    padding:15px;
    border:0;
    border-radius:20px;
    scroll-snap-align:start;
    box-shadow:0 9px 23px rgba(25,63,91,.08);
  }
  .kpi-card::after{width:92px;height:92px;right:-35px;bottom:-35px}
  .kpi-icon{width:39px;height:39px;border-radius:14px}
  .kpi-label{font-size:9px;letter-spacing:.45px;margin-bottom:6px}
  .kpi-value{font-size:25px}
  .kpi-footer{font-size:8.5px;margin-top:12px;gap:3px}

  .grid-2,.grid-2-equal{display:grid;grid-template-columns:1fr;gap:13px;margin-bottom:13px}
  .panel{
    border:0;
    border-radius:21px;
    box-shadow:0 9px 25px rgba(24,62,91,.07);
  }
  .panel-header{
    padding:16px 15px 13px;
    background:#fff;
    border-bottom:1px solid #edf2f6;
    align-items:flex-start;
    flex-wrap:wrap;
  }
  .panel-title h2{font-size:13px;color:#183d58}
  .panel-title p{font-size:9.5px;line-height:1.45}
  .panel-body{padding:14px 15px}
  .chart-wrap{height:220px}
  .system-health{border-radius:17px;padding:13px;background:#f7fbfe}
  .status-row{padding:12px;border:0;background:#f7fafc;margin-bottom:8px;border-radius:15px}
  .status-row:last-child{margin-bottom:0}
  .status-symbol{border-radius:13px;background:#eaf5fd;color:var(--app-blue)}
  .reminder-dashboard-panel{border:0;box-shadow:0 9px 25px rgba(147,100,14,.09)}
  .reminder-dashboard-panel>.panel-header{background:linear-gradient(145deg,#fff9e9,#fff4d5)}
  .reminder-customer-card{border:0;border-radius:18px;background:#fff;box-shadow:0 7px 20px rgba(25,63,91,.07)}
  .upcoming-reminder-item{border:0;border-radius:17px;background:#f8fbfd;box-shadow:none}

  .table-responsive{border-radius:0}
  .data-table.table-mobile-cards tr{border:0;border-radius:18px;box-shadow:0 7px 20px rgba(22,58,86,.07)}
  .data-table.table-mobile-cards td{padding:10px 13px}
  .data-table.table-mobile-cards td::before{font-size:8.5px;color:#8a9aa7}
  .customer-avatar{background:linear-gradient(145deg,var(--app-blue),#0873ce);color:#fff}

  .form-card,.detail-card,.mini-stat,.summary-strip{border-radius:18px}
  .form-control,.filter-select,.search-control input{font-size:16px}
  .form-footer{position:sticky;bottom:92px;z-index:12;padding:10px;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-radius:17px;box-shadow:0 9px 26px rgba(21,57,85,.12)}

  .qris-admin-summary>.panel-header{background:linear-gradient(145deg,#eaf7ff,#e1f2ff)}
  .qris-preview-card,.qris-preview-card.large{border:0;border-radius:20px;background:#f3f9fd}
  .qris-preview-card img{border-radius:15px;box-shadow:0 8px 22px rgba(22,62,92,.09)}

  .app-footer{display:none}
  .mobile-bottom-nav{
    left:8px;
    right:8px;
    bottom:8px;
    grid-template-columns:repeat(5,1fr);
    padding:8px 6px calc(8px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.96);
    border:1px solid rgba(219,230,238,.96);
    border-radius:23px;
    box-shadow:0 14px 38px rgba(16,54,83,.22);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
  }
  .mobile-nav-link{color:#8596a4;border-radius:15px;padding:8px 2px 6px;font-size:8.5px;gap:4px}
  .mobile-nav-link .icon{width:19px;height:19px}
  .mobile-nav-link.active{background:transparent;color:var(--app-blue)}
  .mobile-nav-link:nth-child(3){
    transform:translateY(-17px);
    min-height:61px;
    margin:0 3px -17px;
    padding:10px 3px 5px;
    border-radius:20px;
    background:linear-gradient(145deg,var(--app-blue),#0874d0);
    color:#fff;
    border:5px solid var(--app-bg);
    box-shadow:0 10px 22px rgba(9,121,216,.30);
  }
  .mobile-nav-link:nth-child(3) .icon{width:22px;height:22px}
  .mobile-nav-link:nth-child(3).active{color:#fff;background:linear-gradient(145deg,#0e94ee,#066fc9)}
  .mobile-nav-link:active{transform:scale(.96)}
  .mobile-nav-link:nth-child(3):active{transform:translateY(-17px) scale(.95)}
}

@media (max-width:420px){
  .wallet-blue-card{padding:18px 15px 40px}
  .wallet-balance strong{font-size:26px}
  .wallet-mini-stats>div{padding:8px 7px}
  .wallet-mini-stats span{font-size:7.7px}
  .wallet-quick-actions{margin-left:8px;margin-right:8px}
  .wallet-action-icon{width:39px;height:39px}
  .kpi-card{flex-basis:150px}
  .actions-left,.actions-right{grid-template-columns:1fr}
}

/* ===== OWY NET Mobile Compact UI 2.7 ===== */
@media (max-width:700px){
  body{font-size:12px}
  .topbar{
    min-height:62px;
    padding:calc(8px + env(safe-area-inset-top)) 10px 9px;
    border-radius:0 0 18px 18px;
    box-shadow:0 6px 16px rgba(8,99,181,.16);
  }
  .topbar-left{gap:7px}
  .topbar-right{gap:6px}
  .page-heading h1{font-size:15px;max-width:45vw;letter-spacing:-.2px}
  .mobile-menu,.notification-btn,.avatar{width:34px;height:34px;border-radius:11px}
  .mobile-menu .icon,.notification-btn .icon{width:17px;height:17px}
  .avatar{font-size:12px}
  .sidebar{width:min(84vw,300px);border-radius:0 20px 20px 0}

  .content{padding:9px 8px calc(82px + env(safe-area-inset-bottom))}
  body[data-page="dashboard"] .content{padding-top:8px}
  .mobile-wallet-hero{margin-bottom:9px}
  .wallet-blue-card{
    padding:13px 12px 29px;
    border-radius:16px;
    box-shadow:0 9px 20px rgba(7,111,201,.19);
  }
  .wallet-blue-card::before{width:115px;height:115px;right:-48px;top:-58px}
  .wallet-blue-card::after{width:78px;height:78px;left:-38px;bottom:-47px}
  .wallet-card-head{gap:8px}
  .wallet-kicker{font-size:7px;letter-spacing:1px}
  .wallet-card-head strong{font-size:11px}
  .wallet-live{gap:4px;padding:4px 6px;font-size:7px}
  .wallet-live i{width:5px;height:5px;box-shadow:0 0 0 3px rgba(124,255,184,.13)}
  .wallet-balance{margin-top:11px}
  .wallet-balance span{font-size:8.5px}
  .wallet-balance strong{font-size:21px;letter-spacing:-.45px;margin-top:1px}
  .wallet-mini-stats{gap:5px;margin-top:11px}
  .wallet-mini-stats>div{padding:6px 7px;border-radius:9px}
  .wallet-mini-stats span{font-size:6.7px}
  .wallet-mini-stats strong{font-size:11px}
  .wallet-quick-actions{
    margin:-18px 7px 0;
    padding:8px 5px 7px;
    gap:2px;
    border-radius:15px;
    box-shadow:0 8px 18px rgba(21,62,94,.10);
  }
  .wallet-quick-actions a{gap:4px;font-size:7.5px}
  .wallet-action-icon{width:32px;height:32px;border-radius:11px}
  .wallet-action-icon .icon{width:16px;height:16px}

  .page-actions{margin-bottom:8px;padding:8px;gap:6px;border-radius:14px}
  .actions-left,.actions-right{gap:6px}
  .page-actions .btn{min-height:38px;border-radius:11px;padding:7px 8px;font-size:10px}

  .dashboard-reminder-strip{
    margin-bottom:8px;
    padding:9px;
    gap:8px;
    border-radius:14px;
    box-shadow:0 5px 14px rgba(26,61,88,.06);
  }
  .dashboard-reminder-strip-icon{width:32px;height:32px;border-radius:10px}
  .dashboard-reminder-strip-icon .icon{width:16px;height:16px}
  .dashboard-reminder-strip-copy strong{font-size:10.5px}
  .dashboard-reminder-strip-copy span{font-size:8.5px;line-height:1.35}
  .dashboard-reminder-strip .btn{width:auto;min-height:32px;padding:6px 8px;border-radius:9px;font-size:8.5px}

  .kpi-grid{gap:7px;margin:0 -8px 9px;padding:0 8px 3px}
  .kpi-card{
    flex:0 0 130px;
    min-height:107px;
    padding:10px;
    border-radius:14px;
    box-shadow:0 5px 14px rgba(25,63,91,.07);
  }
  .kpi-card::after{width:65px;height:65px;right:-25px;bottom:-25px}
  .kpi-top{gap:7px}
  .kpi-icon{width:31px;height:31px;border-radius:10px}
  .kpi-icon .icon{width:16px;height:16px}
  .kpi-label{font-size:7.3px;letter-spacing:.25px;margin-bottom:4px}
  .kpi-value{font-size:19px;letter-spacing:-.35px}
  .kpi-footer{font-size:6.8px;margin-top:8px;line-height:1.3}

  .grid-2,.grid-2-equal{gap:8px;margin-bottom:8px}
  .panel{border-radius:14px;box-shadow:0 5px 15px rgba(24,62,91,.06)}
  .panel-header{padding:10px 10px 8px;gap:8px}
  .panel-title h2{font-size:10.5px}
  .panel-title h2>.icon{width:15px;height:15px}
  .panel-title p{font-size:7.7px;line-height:1.35}
  .panel-actions{gap:5px}
  .panel-body{padding:9px 10px}
  .chart-wrap{height:160px}
  .badge{font-size:7px;padding:4px 6px}
  .btn{min-height:36px;border-radius:10px;padding:7px 10px;font-size:9.5px;gap:5px}
  .btn-sm{min-height:30px;padding:5px 7px;font-size:8px}
  .btn .icon{width:14px;height:14px}
  .btn-icon{width:30px;min-width:30px;padding:0}
  .info-banner{padding:8px 9px;border-radius:11px;font-size:8px;line-height:1.35}
  .info-banner .icon{width:16px;height:16px}
  .system-health{gap:9px;padding:9px;border-radius:12px;margin-bottom:9px}
  .health-ring{width:43px;height:43px}
  .health-ring::before{width:34px;height:34px}
  .health-ring strong{font-size:8px}
  .health-copy strong,.status-copy strong{font-size:9px}
  .health-copy span,.status-copy span{font-size:7.4px}
  .status-row{padding:8px;margin-bottom:5px;border-radius:11px}
  .status-row-left{gap:7px}
  .status-symbol{width:29px;height:29px;border-radius:9px}
  .status-symbol .icon{width:14px;height:14px}
  .status-value{font-size:9px}

  .reminder-customer-grid{gap:7px}
  .reminder-customer-card{border-radius:13px;padding:10px}
  .reminder-card-top{gap:7px;margin-bottom:7px}
  .customer-avatar{width:31px;height:31px;border-radius:10px;font-size:9px}
  .reminder-card-copy strong{font-size:9.5px}
  .reminder-card-copy span{font-size:7.5px}
  .reminder-card-detail{padding:5px 0;font-size:8px}
  .reminder-card-actions{gap:5px;margin-top:7px}
  .upcoming-reminder-list{gap:6px}
  .upcoming-reminder-item{padding:8px;border-radius:12px;gap:7px}
  .upcoming-reminder-item strong{font-size:9px}
  .upcoming-reminder-item span{font-size:7px}

  .form-card,.detail-card,.mini-stat,.summary-strip{border-radius:13px}
  .form-card{padding:10px}
  .form-group{margin-bottom:10px}
  .form-label{font-size:8.5px;margin-bottom:4px}
  .form-control,.filter-select,.search-control input{min-height:40px;border-radius:10px;font-size:16px;padding:8px 10px}
  .form-footer{bottom:69px;padding:7px;border-radius:12px}
  .currency-input{min-height:40px;border-radius:10px}
  .currency-input>span{padding:0 10px}
  .currency-input-lg{min-height:48px}
  .currency-input-lg .form-control{font-size:18px}
  .price-summary-card{padding:11px;border-radius:12px;margin-bottom:11px}
  .price-summary-icon{width:35px;height:35px;border-radius:10px}

  .table-toolbar{margin-bottom:8px}
  .data-table.table-mobile-cards tbody{gap:7px}
  .data-table.table-mobile-cards tr{border-radius:12px;padding:3px 0;box-shadow:0 4px 12px rgba(22,58,86,.06)}
  .data-table.table-mobile-cards td{padding:7px 9px;gap:8px;font-size:9px}
  .data-table.table-mobile-cards td::before{font-size:6.8px;letter-spacing:.35px}

  .qris-preview-card,.qris-preview-card.large{min-height:180px;border-radius:14px}
  .qris-preview-card img{max-height:220px;border-radius:10px}
  .qris-admin-grid,.qris-settings-grid{gap:9px}

  .mobile-bottom-nav{
    left:5px;right:5px;bottom:5px;
    padding:5px 4px calc(5px + env(safe-area-inset-bottom));
    border-radius:16px;
    box-shadow:0 8px 22px rgba(16,54,83,.18);
  }
  .mobile-nav-link{border-radius:10px;padding:5px 1px 4px;font-size:6.8px;gap:2px}
  .mobile-nav-link .icon{width:16px;height:16px}
  .mobile-nav-link:nth-child(3){
    transform:translateY(-10px);
    min-height:48px;
    margin:0 2px -10px;
    padding:7px 2px 4px;
    border-radius:15px;
    border-width:4px;
    box-shadow:0 6px 15px rgba(9,121,216,.25);
  }
  .mobile-nav-link:nth-child(3) .icon{width:18px;height:18px}
  .mobile-nav-link:nth-child(3):active{transform:translateY(-10px) scale(.95)}
}

@media (max-width:380px){
  .content{padding-left:6px;padding-right:6px}
  .wallet-blue-card{padding-left:10px;padding-right:10px}
  .wallet-balance strong{font-size:19px}
  .wallet-mini-stats>div{padding:5px 4px}
  .wallet-mini-stats span{font-size:6.1px}
  .wallet-quick-actions{margin-left:5px;margin-right:5px}
  .kpi-card{flex-basis:122px}
  .page-heading h1{max-width:41vw;font-size:14px}
}
