*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.splash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease}.splash-overlay.splash-leaving{opacity:0;pointer-events:none}.splash-content{display:flex;flex-direction:column;align-items:center;animation:splashIn .75s cubic-bezier(.2,.8,.3,1) both}.splash-logo{width:min(220px,55vw);height:min(220px,55vw);object-fit:contain;border-radius:24px}@keyframes splashIn{0%{opacity:0;transform:scale(.82)}60%{transform:scale(1.03)}to{opacity:1;transform:scale(1)}}.skeleton-block{background:linear-gradient(90deg,var(--border) 25%,var(--purple-light) 50%,var(--border) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}:root{--purple: #7D669E;--purple-dark: #5e4c7a;--purple-light: #f0ebf8;--text: #0f0f14;--text-muted: #6b7280;--bg: #f5f5f7;--white: #ffffff;--border: #e4e4ec;--success: #16a34a;--danger: #dc2626;--warning: #d97706;--radius: 14px;--shadow: 0 1px 3px rgba(0,0,0,.05), 0 4px 20px rgba(0,0,0,.07)}html,body,#root{height:100%}[data-theme=dark]{--text: #ededf0;--text-muted: #7a8494;--bg: #0c0c13;--white: #13131e;--border: #1c1c2b;--purple-light: #1e1830;--shadow: 0 1px 4px rgba(0,0,0,.5), 0 4px 24px rgba(0,0,0,.4)}body{font-family:Jost,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;min-height:100%;max-width:480px;margin:0 auto}.page-content{flex:1;padding:16px 16px 88px;overflow-y:auto}.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.topbar-brand{display:flex;align-items:center;gap:10px}.topbar-logo-img{height:60px;width:60px;object-fit:contain;border-radius:12px;flex-shrink:0}[data-theme=dark] .topbar-logo-img{height:72px;width:72px;border-radius:14px}.topbar-logo{font-size:16px;font-weight:700;letter-spacing:1.5px;color:var(--text);text-transform:uppercase;line-height:1.1}.topbar-subtitle{font-size:10px;color:var(--purple);letter-spacing:1.5px;text-transform:uppercase;font-weight:500}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:var(--white);border-top:1px solid var(--border);display:flex;z-index:20}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px 4px 8px;text-decoration:none;color:var(--text-muted);font-size:10px;letter-spacing:.3px;gap:4px;transition:color .15s}.nav-item.active,.nav-item:hover{color:var(--purple)}.nav-item svg{width:22px;height:22px}.card{background:var(--white);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);margin-bottom:12px}.card-title{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}.big-number{font-size:32px;font-weight:700;color:var(--purple);line-height:1.1}.big-number-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.progress-bar{background:var(--purple-light);border-radius:99px;height:8px;overflow:hidden;margin:8px 0 4px}.progress-fill{background:var(--purple);height:100%;border-radius:99px;transition:width .4s ease}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-premium{background:#fef3c7;color:#92400e}.badge-active{background:#dcfce7;color:#15803d}.badge-suspended{background:#fee2e2;color:#991b1b}.badge-inactive{background:#f3f4f6;color:#6b7280}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s;text-decoration:none}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--purple);color:var(--white);width:100%}.btn-primary:hover:not(:disabled){background:var(--purple-dark)}.btn-outline{background:transparent;color:var(--purple);border:1.5px solid var(--purple)}.btn-danger{background:var(--danger);color:var(--white)}.btn-ghost{background:transparent;color:var(--text-muted)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text)}.form-input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;background:var(--white);color:var(--text);transition:border-color .15s;outline:none}.form-input:focus{border-color:var(--purple)}.form-error{font-size:12px;color:var(--danger);margin-top:4px}.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;background:var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--white);border-radius:16px;padding:32px 24px;box-shadow:var(--shadow)}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-img{width:160px;height:160px;object-fit:contain;border-radius:28px}.client-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);gap:12px}.client-row:last-child{border-bottom:none}.client-avatar{width:40px;height:40px;border-radius:50%;background:var(--purple-light);color:var(--purple);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}.client-info{flex:1;min-width:0}.client-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-meta{font-size:12px;color:var(--text-muted)}.client-amount{text-align:right;font-weight:600;color:var(--purple);font-size:14px;white-space:nowrap}.alert{padding:12px 14px;border-radius:8px;font-size:13px;margin-bottom:12px}.alert-info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.alert-warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.alert-success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.copy-box{display:flex;align-items:center;gap:8px;background:var(--purple-light);border-radius:8px;padding:10px 12px}.copy-link{flex:1;font-size:13px;color:var(--purple-dark);word-break:break-all;font-weight:500}.history-item{border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.history-period{font-size:13px;color:var(--text-muted)}.history-total{font-size:18px;font-weight:700;color:var(--purple)}.history-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.history-stat{text-align:center}.history-stat-value{font-size:15px;font-weight:600}.history-stat-label{font-size:11px;color:var(--text-muted)}.spinner{width:24px;height:24px;border:3px solid var(--purple-light);border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite;margin:24px auto}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 16px;color:var(--text-muted)}.empty-state svg{width:48px;height:48px;margin-bottom:12px;opacity:.4}.search-input{width:100%;padding:10px 14px 10px 36px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;background:var(--white);outline:none;transition:border-color .15s;margin-bottom:12px}.search-input:focus{border-color:var(--purple)}.search-wrapper{position:relative}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.divider{height:1px;background:var(--border);margin:16px 0}.page-heading{font-size:20px;font-weight:700;margin-bottom:16px}.text-muted{color:var(--text-muted)}.text-small{font-size:12px}.text-center{text-align:center}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-2{gap:8px}.notif-banner{background:var(--purple-light);border:1px solid var(--purple);border-radius:12px;padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:10px}.notif-banner-content{display:flex;align-items:flex-start;gap:12px}.notif-banner-icon{font-size:1.4rem;flex-shrink:0}.notif-banner-content strong{display:block;color:var(--text);font-size:.95rem;margin-bottom:2px}.notif-banner-content p{color:var(--text-muted);font-size:.82rem}.notif-banner-actions{display:flex;gap:8px}.btn-sm{padding:6px 14px;font-size:.82rem;border-radius:8px}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:.9rem}.btn-ghost:hover{background:var(--border)}.balance-card{text-align:center;padding:24px;margin-bottom:20px}.balance-label{color:var(--text-muted);font-size:.85rem;margin-bottom:6px}.balance-amount{font-size:2rem;font-weight:700;color:var(--purple);margin-bottom:16px}.withdrawal-list{display:flex;flex-direction:column;gap:10px}.withdrawal-item{padding:14px 16px}.withdrawal-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.withdrawal-amount{font-weight:600;font-size:1rem}.withdrawal-date{font-size:.8rem}.withdrawal-note{font-size:.8rem;margin-top:4px}.badge{padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#1e40af}.badge-success{background:#d1fae5;color:#065f46}.badge-error{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--card-bg, #fff);border-radius:16px;padding:24px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px}.modal h2{font-size:1.1rem}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;color:var(--text-muted)}.notif-info-list{list-style:disc;padding-left:20px;margin-top:8px;display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:.9rem}.success-text{color:#065f46;font-size:.9rem}.error-text{color:#991b1b;font-size:.9rem}.section-label{font-size:.8rem;color:var(--text-muted);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.section-title{font-size:1rem;font-weight:600;margin:16px 0 10px}
