:root{--ec-primary:#1e5eff;--ec-primary-dark:#0b3fcc;--ec-primary-50:#eef3ff;--ec-primary-100:#dce6ff;--ec-accent:#00c2a8;--ec-bg:#f4f7fb;--ec-card:#fff;--ec-border:#e5e9f2;--ec-border-strong:#cdd5e2;--ec-text:#0f172a;--ec-text-muted:#64748b;--ec-text-light:#94a3b8;--ec-row-odd:#fff;--ec-row-even:#f7f9fc;--ec-row-hover:#eef3ff;--ec-success:#10b981;--ec-success-bg:#e6fbf3;--ec-error:#ef4444;--ec-error-bg:#feecec;--ec-warning:#f59e0b;--ec-warning-bg:#fff6e5;--ec-info:#3b82f6;--ec-shadow-sm:0 1px 2px #0f172a0d;--ec-shadow:0 4px 14px #0f172a0f;--ec-shadow-lg:0 20px 40px #0f172a1f}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--ec-bg);color:var(--ec-text);font-family:DM Sans,Plus Jakarta Sans,sans-serif;font-size:14px;line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5{letter-spacing:-.01em;font-family:Plus Jakarta Sans,sans-serif;font-weight:700}button{font-family:inherit}a{color:inherit;text-decoration:none}.app{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{color:#fff;background:linear-gradient(#0a1f44 0%,#0b2756 100%);flex-direction:column;height:100vh;padding:0;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--ec-border);background:#fff;align-items:center;gap:10px;height:64px;padding:0 18px;display:flex}.sidebar-brand img{object-fit:contain;width:auto;max-width:100%;height:36px}.sidebar-section{padding:18px 14px 8px}.sidebar-section-title{color:#5e7297;text-transform:uppercase;letter-spacing:.1em;padding:0 10px 8px;font-size:10px;font-weight:600}.nav-item{cursor:pointer;color:#c9d4e8;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;margin-bottom:2px;padding:10px 12px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.active{color:#fff;box-shadow:inset 3px 0 0 var(--ec-primary);background:linear-gradient(90deg,#1e5eff2e,#1e5eff0d)}.nav-item svg{opacity:.8;flex-shrink:0;width:18px;height:18px}.nav-item.active svg{opacity:1;color:var(--ec-primary)}.nav-badge{background:var(--ec-primary);color:#fff;border-radius:10px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:600}.sidebar-footer{border-top:1px solid #ffffff14;align-items:center;gap:10px;margin-top:auto;padding:16px 18px;display:flex}.avatar{color:#fff;background:linear-gradient(135deg,#ffb17a,#ff7e5f);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.footer-user{flex:1;min-width:0}.footer-user .name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.footer-user .role{color:#92a4c9;font-size:11px}.footer-logout{color:#92a4c9;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:flex}.footer-logout:hover{color:#fff;background:#ffffff14}.main{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--ec-border);z-index:10;background:#fff;align-items:center;gap:18px;height:64px;padding:0 28px;display:flex;position:sticky;top:0}.breadcrumb{color:var(--ec-text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.breadcrumb .crumb{cursor:pointer}.breadcrumb .crumb:hover{color:var(--ec-primary)}.breadcrumb .sep{color:var(--ec-text-light)}.breadcrumb .current{color:var(--ec-text);font-weight:600}.topbar-search{flex:1;max-width:380px;position:relative}.topbar-search input{border:1px solid var(--ec-border);background:var(--ec-bg);border-radius:8px;width:100%;padding:9px 12px 9px 36px;font-family:inherit;font-size:13px;transition:all .15s}.topbar-search input:focus{border-color:var(--ec-primary);background:#fff;outline:none;box-shadow:0 0 0 3px #1e5eff1f}.topbar-search svg{width:16px;height:16px;color:var(--ec-text-light);position:absolute;top:50%;left:11px;transform:translateY(-50%)}.topbar-actions{align-items:center;gap:14px;margin-left:auto;display:flex}.icon-btn{border:1px solid var(--ec-border);cursor:pointer;width:36px;height:36px;color:var(--ec-text-muted);background:#fff;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.icon-btn:hover{border-color:var(--ec-primary);color:var(--ec-primary)}.icon-btn .dot{background:var(--ec-error);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:7px;right:7px}.content{padding:24px 28px 40px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:20px;display:flex}.page-header h1{color:var(--ec-text);font-size:24px}.page-header .sub{color:var(--ec-text-muted);margin-top:4px;font-size:13.5px}.btn{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--ec-primary),var(--ec-primary-dark));color:#fff;box-shadow:0 4px 12px #1e5eff47}.btn-primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 16px #1e5eff5c}.btn-ghost{border-color:var(--ec-border);color:var(--ec-text);background:#fff}.btn-ghost:hover{border-color:var(--ec-primary);color:var(--ec-primary)}.btn svg{width:16px;height:16px}.btn-block{justify-content:center;width:100%;padding:12px 16px}.stat-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.stat-card{border:1px solid var(--ec-border);background:#fff;border-radius:12px;padding:16px 18px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--ec-primary);width:3px;position:absolute;top:0;bottom:0;left:0}.stat-card.success:before{background:var(--ec-success)}.stat-card.warn:before{background:var(--ec-warning)}.stat-card.error:before{background:var(--ec-error)}.card{background:var(--ec-card);border:1px solid var(--ec-border);box-shadow:var(--ec-shadow-sm);border-radius:12px;overflow:hidden}.table-toolbar{border-bottom:1px solid var(--ec-border);flex-wrap:wrap;align-items:center;gap:10px;padding:14px 18px;display:flex}.filter-group{flex-wrap:wrap;flex:1;align-items:center;gap:8px;display:flex}.filter-input,.filter-select{border:1px solid var(--ec-border);color:var(--ec-text);cursor:pointer;background:#fff;border-radius:7px;min-width:140px;padding:8px 12px;font-family:inherit;font-size:12.5px;transition:all .15s}.filter-input:focus,.filter-select:focus{border-color:var(--ec-primary);outline:none;box-shadow:0 0 0 3px #1e5eff1a}.filter-search{position:relative}.filter-search input{min-width:220px;padding-left:32px}.filter-search svg{width:14px;height:14px;color:var(--ec-text-light);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.toolbar-right{align-items:center;gap:8px;display:flex}.chip-btn{border:1px solid var(--ec-border);cursor:pointer;color:var(--ec-text-muted);background:#fff;border-radius:7px;align-items:center;gap:6px;padding:7px 12px;font-family:inherit;font-size:12.5px;font-weight:500;display:inline-flex}.chip-btn:hover{border-color:var(--ec-primary);color:var(--ec-primary)}.chip-btn svg{width:14px;height:14px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{color:var(--ec-text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--ec-border);white-space:nowrap;background:#f8fafd;padding:12px 16px;font-size:11.5px;font-weight:600}thead th .th-inner{cursor:pointer;align-items:center;gap:6px;display:flex}thead th .th-inner:hover{color:var(--ec-text)}thead th svg{opacity:.5;width:12px;height:12px}tbody tr{transition:background .12s}tbody tr:nth-child(odd){background:var(--ec-row-odd)}tbody tr:nth-child(2n){background:var(--ec-row-even)}tbody tr:hover{background:var(--ec-row-hover)}tbody td{border-bottom:1px solid var(--ec-border);color:var(--ec-text);vertical-align:middle;padding:14px 16px}tbody tr:last-child td{border-bottom:none}.cell-strong{color:var(--ec-text);font-weight:600}.cell-muted{color:var(--ec-text-muted);font-size:12.5px}.merchant-id{background:var(--ec-bg);color:var(--ec-text);border:1px solid var(--ec-border);border-radius:5px;padding:3px 8px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px}.group-pill{background:var(--ec-primary-50);color:var(--ec-primary-dark);border:1px solid var(--ec-primary-100);border-radius:12px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.group-pill .dot{background:var(--ec-primary);border-radius:50%;width:6px;height:6px}.badge{border:1px solid #0000;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex;position:relative}.badge[data-tooltip]{cursor:help}.badge[data-tooltip]:hover:after{content:attr(data-tooltip);color:#fff;z-index:100;white-space:normal;text-align:left;background:#0f172a;border-radius:6px;width:max-content;max-width:280px;padding:8px 10px;font-size:11.5px;font-weight:500;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 8px 20px #0003}.badge[data-tooltip]:hover:before{content:"";border:5px solid #0000;border-top-color:#0f172a;position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%)}.badge .dot{border-radius:50%;width:6px;height:6px}.badge.success{background:var(--ec-success-bg);color:#047857;border-color:#a7f3d0}.badge.success .dot{background:var(--ec-success);box-shadow:0 0 0 3px #10b98126}.badge.error{background:var(--ec-error-bg);color:#b91c1c;border-color:#fca5a5}.badge.error .dot{background:var(--ec-error)}.badge.warn{background:var(--ec-warning-bg);color:#92400e;border-color:#fcd34d}.badge.warn .dot{background:var(--ec-warning)}.badge.info{color:#075985;background:#e0f2fe;border-color:#7dd3fc}.badge.info .dot{background:var(--ec-info)}.row-actions{align-items:center;gap:6px;display:flex}.action-btn{border:1px solid var(--ec-border);cursor:pointer;width:30px;height:30px;color:var(--ec-text-muted);background:#fff;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.action-btn:hover{border-color:var(--ec-primary);color:var(--ec-primary);background:var(--ec-primary-50)}.action-btn.error{color:var(--ec-error);background:var(--ec-error-bg);border-color:#fca5a5}.action-btn.error:hover{background:var(--ec-error);color:#fff}.action-btn:disabled{opacity:.6;cursor:wait}.action-btn svg{width:14px;height:14px}.action-btn[data-tooltip]:hover:after{content:attr(data-tooltip);color:#fff;z-index:100;white-space:normal;text-align:left;background:#0f172a;border-radius:6px;width:max-content;max-width:280px;padding:8px 10px;font-size:11.5px;font-weight:500;position:absolute;bottom:calc(100% + 8px);right:0;box-shadow:0 8px 20px #0003}.action-btn[data-tooltip]:hover:before{content:"";border:5px solid #0000;border-top-color:#0f172a;position:absolute;bottom:calc(100% + 2px);right:8px}.pagination{border-top:1px solid var(--ec-border);color:var(--ec-text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;font-size:12.5px;display:flex}.page-controls{align-items:center;gap:6px;display:flex}.page-btn{border:1px solid var(--ec-border);cursor:pointer;min-width:30px;height:30px;color:var(--ec-text);background:#fff;border-radius:6px;justify-content:center;align-items:center;padding:0 8px;font-family:inherit;font-size:12.5px;font-weight:500;display:flex}.page-btn:hover:not(:disabled){border-color:var(--ec-primary);color:var(--ec-primary)}.page-btn.active{background:var(--ec-primary);color:#fff;border-color:var(--ec-primary)}.page-btn:disabled{opacity:.4;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a8c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{width:520px;max-width:92vw;box-shadow:var(--ec-shadow-lg);background:#fff;border-radius:16px;animation:.25s cubic-bezier(.2,.8,.2,1) slideUp;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:none}}.modal-header{border-bottom:1px solid var(--ec-border);justify-content:space-between;align-items:flex-start;gap:16px;padding:22px 24px 16px;display:flex}.modal-header h3{color:var(--ec-text);font-size:17px}.modal-header p{color:var(--ec-text-muted);margin-top:4px;font-size:13px}.modal-close{background:var(--ec-bg);cursor:pointer;width:32px;height:32px;color:var(--ec-text-muted);border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--ec-error-bg);color:var(--ec-error)}.modal-body{padding:22px 24px}.modal-footer{border-top:1px solid var(--ec-border);background:#fafbfd;justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}.modal-icon{background:linear-gradient(135deg,var(--ec-primary-50),#fff);border:1px solid var(--ec-primary-100);width:48px;height:48px;color:var(--ec-primary);border-radius:12px;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.modal-icon svg{width:24px;height:24px}.field{margin-bottom:14px}.field-label{color:var(--ec-text);margin-bottom:6px;font-size:12.5px;font-weight:600;display:block}.field-label .req{color:var(--ec-error)}.field-help{color:var(--ec-text-muted);margin-top:5px;font-size:11.5px}.field-error{color:var(--ec-error);margin-top:5px;font-size:11.5px}.group-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:4px;display:grid}.group-option{border:1.5px solid var(--ec-border);cursor:pointer;background:#fff;border-radius:9px;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.group-option:hover{border-color:var(--ec-primary-100);background:var(--ec-primary-50)}.group-option input{display:none}.group-option .gp-radio{border:2px solid var(--ec-border-strong);border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:all .15s;position:relative}.group-option input:checked+.gp-radio{border-color:var(--ec-primary);background:var(--ec-primary);box-shadow:inset 0 0 0 3px #fff}.group-option:has(input:checked){border-color:var(--ec-primary);background:var(--ec-primary-50)}.gp-info{flex-direction:column;display:flex}.gp-info .gp-name{color:var(--ec-text);font-size:13px;font-weight:600}.gp-info .gp-meta{color:var(--ec-text-muted);font-size:11px}.info-banner{color:#7c4a03;background:linear-gradient(135deg,#fff7e5,#fffdf5);border:1px solid #fcd34d;border-radius:8px;align-items:flex-start;gap:10px;margin-top:14px;padding:10px 12px;font-size:12.5px;display:flex}.info-banner svg{color:#b45309;flex-shrink:0;width:16px;height:16px;margin-top:1px}.status-modal .modal-body{text-align:center;padding:30px 24px}.status-icon{border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex}.status-icon svg{width:32px;height:32px}.status-icon.ok{background:var(--ec-success-bg);color:var(--ec-success)}.status-icon.err{background:var(--ec-error-bg);color:var(--ec-error)}.status-modal h3{margin-bottom:6px;font-size:18px}.status-modal p{color:var(--ec-text-muted);max-width:340px;margin:0 auto;font-size:13.5px}.detail-row{border-bottom:1px dashed var(--ec-border);justify-content:space-between;padding:7px 0;font-size:12.5px;display:flex}.detail-row:last-child{border-bottom:none}.detail-row .k{color:var(--ec-text-muted)}.detail-row .v{color:var(--ec-text);font-weight:600}.toast-wrap{z-index:300;flex-direction:column;gap:10px;display:flex;position:fixed;top:16px;right:16px}.toast{border-left:4px solid var(--ec-success);box-shadow:var(--ec-shadow-lg);background:#fff;border-radius:10px;align-items:flex-start;gap:12px;min-width:300px;max-width:380px;padding:12px 16px 12px 14px;animation:.3s cubic-bezier(.2,.8,.2,1) slideIn;display:flex}.toast.error{border-left-color:var(--ec-error)}.toast .t-icon{width:24px;height:24px;color:var(--ec-success);flex-shrink:0}.toast.error .t-icon{color:var(--ec-error)}.toast .t-content{flex:1}.toast .t-title{color:var(--ec-text);font-size:13px;font-weight:700}.toast .t-msg{color:var(--ec-text-muted);margin-top:2px;font-size:12.5px}.toast .t-close{cursor:pointer;color:var(--ec-text-light);background:0 0;border:none;font-size:18px;line-height:1}@keyframes slideIn{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:none}}.empty-cell{color:var(--ec-text-light);font-style:italic}.small{color:var(--ec-text-muted);font-size:11.5px}.integrating-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:250;background:#0f172a99;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.integrating-card{text-align:center;box-shadow:var(--ec-shadow-lg);background:#fff;border-radius:14px;max-width:380px;padding:36px 40px}.spinner{border:4px solid var(--ec-primary-100);border-top-color:var(--ec-primary);border-radius:50%;width:48px;height:48px;margin:0 auto 16px;animation:1s linear infinite spin}.spinner-sm{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.integrating-card h4{margin-bottom:6px;font-size:16px}.integrating-card p{color:var(--ec-text-muted);font-size:13px}.login-page{background:var(--ec-bg);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-hero{color:#fff;background:linear-gradient(135deg,#0a1f44 0%,#0b2756 50%,#1e5eff 130%);flex-direction:column;padding:48px 56px;display:flex;position:relative;overflow:hidden}.login-hero:before{content:"";background:radial-gradient(circle,#1e5eff59,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-200px}.login-hero:after{content:"";background:radial-gradient(circle,#00c2a82e,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.login-hero-brand{z-index:1;background:#fff;border-radius:14px;width:fit-content;padding:18px 22px;position:relative;box-shadow:0 12px 28px #0000002e}.login-hero-brand img{width:auto;height:64px;display:block}.login-hero-copy{z-index:1;max-width:480px;margin-top:80px;margin-bottom:auto;position:relative}.login-hero-copy h1{color:#fff;letter-spacing:-.025em;margin-bottom:14px;font-size:34px;line-height:1.15}.login-hero-copy p{color:#ffffffc7;font-size:15px;line-height:1.6}.login-hero-tags{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.login-hero-tags span{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff1f;border:1px solid #ffffff2e;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:500}.login-hero-foot{color:#ffffff8c;z-index:1;font-size:12px;position:relative}.login-form-side{justify-content:center;align-items:center;padding:40px;display:flex}.login-card{border:1px solid var(--ec-border);width:100%;max-width:420px;box-shadow:var(--ec-shadow);background:#fff;border-radius:16px;padding:36px 32px}.login-card-brand-mobile{justify-content:center;margin-bottom:18px;display:none}.login-card-brand-mobile img{width:auto;height:48px}.login-card h2{color:var(--ec-text);margin-bottom:6px;font-size:22px}.login-card .sub{color:var(--ec-text-muted);margin-bottom:24px;font-size:13.5px}.login-form .field input{border:1px solid var(--ec-border);width:100%;color:var(--ec-text);background:#fff;border-radius:9px;padding:11px 13px;font-family:inherit;font-size:14px;transition:all .15s}.login-form .field input:focus{border-color:var(--ec-primary);outline:none;box-shadow:0 0 0 3px #1e5eff1f}.login-form .field input.has-error{border-color:var(--ec-error);box-shadow:0 0 0 3px #ef44441a}.login-error-banner{background:var(--ec-error-bg);color:#b91c1c;border:1px solid #fca5a5;border-radius:8px;align-items:flex-start;gap:8px;margin-bottom:14px;padding:10px 12px;font-size:12.5px;font-weight:500;display:flex}.login-error-banner svg{flex-shrink:0;width:16px;height:16px;margin-top:1px}.login-card .footnote{color:var(--ec-text-light);text-align:center;margin-top:18px;font-size:11.5px;line-height:1.5}@media (width<=1100px){.stat-row{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.login-page{grid-template-columns:1fr}.login-hero{display:none}.login-card-brand-mobile{display:flex}}@media (width<=860px){.app{grid-template-columns:1fr}.sidebar{display:none}.content{padding:16px}}
