@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";:root{--color-bg:#fafaf8;--color-surface:#f7f7f5;--color-accent:#3b6d11;--color-accent-light:#eaf3de;--color-text:#1a1a18;--color-text-muted:#6b6b67;--color-border:#e4e4e0;--color-border-strong:#c8c8c4;--color-danger:#c0392b;--color-danger-light:#fdf2f1;--color-success:#16a34a;--color-warning:#b45309;--color-warning-light:#fef9ee;--color-info:#1d4ed8;--color-info-light:#eff6ff;--sidebar-width:240px;--topbar-height:56px;--radius:6px;--radius-lg:10px}[data-theme=dark]{--color-bg:#141412;--color-surface:#1c1c1a;--color-accent:#97c459;--color-accent-light:#1e3010;--color-text:#e8e7e0;--color-text-muted:#8a8a82;--color-border:#2a2a26;--color-border-strong:#3a3a36;--color-danger:#e05d4e;--color-danger-light:#2a1512;--color-warning:#f59e0b;--color-warning-light:#2a1f0a;--color-info:#60a5fa;--color-info-light:#0f1e3a}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-family:Inter,system-ui,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{background:var(--color-bg);color:var(--color-text)}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block}h1{font-size:1.5rem}h1,h2{font-weight:600;line-height:1.3}h2{font-size:1.25rem}h3{font-size:1rem;font-weight:600;line-height:1.4}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.font-mono{font-family:Fira Mono,Consolas,monospace}.amount,.tabular{font-variant-numeric:tabular-nums}.amount{text-align:right}.app-shell{background:var(--color-bg);height:100dvh}.app-shell,.main-content{display:flex;overflow:hidden}.main-content{flex:1;flex-direction:column;min-width:0}.page-body{flex:1;overflow-y:auto;padding:24px}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .2s ease;width:var(--sidebar-width)}.sidebar-logo{align-items:center;border-bottom:1px solid var(--color-border);color:var(--color-accent);display:flex;font-size:1rem;font-weight:600;gap:10px;height:var(--topbar-height);padding:0 16px;white-space:nowrap}.sidebar-logo svg{flex-shrink:0}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 8px}.sidebar-section-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;padding:8px 8px 4px;text-transform:uppercase}.sidebar-item,.sidebar-section-label{color:var(--color-text-muted);overflow:hidden;white-space:nowrap}.sidebar-item{align-items:center;border-radius:var(--radius);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:8px;text-decoration:none;transition:background .12s,color .12s}.sidebar-item:hover{text-decoration:none}.sidebar-item.active,.sidebar-item:hover{background:var(--color-accent-light);color:var(--color-accent)}.sidebar-item svg{flex-shrink:0}.sidebar-item-label{overflow:hidden;text-overflow:ellipsis}.sidebar-bottom{border-top:1px solid var(--color-border);padding:8px}.sidebar-user{padding:8px 10px 4px}.sidebar-user-name{color:var(--color-text);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:var(--color-text-muted);font-size:11px;letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}.topbar{align-items:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;gap:12px;height:var(--topbar-height);padding:0 20px}.topbar-spacer{flex:1}.topbar-title{font-size:.875rem;font-weight:600}.theme-toggle,.topbar-title{color:var(--color-text-muted)}.theme-toggle{align-items:center;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .12s,color .12s;width:32px}.theme-toggle:hover{background:var(--color-accent-light);color:var(--color-accent)}.btn{align-items:center;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:6px;padding:7px 14px;text-decoration:none;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-secondary{background:transparent;border-color:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:var(--color-accent-light);border-color:var(--color-accent);color:var(--color-accent)}.btn-ghost{background:transparent;border-color:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background:var(--color-accent-light);color:var(--color-accent)}.btn-danger{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.08)}.btn-sm{font-size:.8125rem;padding:5px 10px}.btn-icon{padding:6px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.flex>.form-group,.form-group:last-child{margin-bottom:0}.link-form-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr}.link-form-grid>*{margin-bottom:0}.link-form-grid>.span-2{grid-column:1/-1}.form-label{color:var(--color-text);font-size:.8125rem;font-weight:500}.form-label.required:after{color:var(--color-danger);content:" *"}.form-input,.form-select,.form-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:.875rem;outline:none;padding:7px 10px;transition:border-color .12s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent)}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--color-text-muted)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{min-height:80px;resize:vertical}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-hint{color:var(--color-text-muted);font-size:.75rem}.field-error{color:var(--color-danger);display:block;font-size:.75rem;margin-top:4px}.form-input.input-error{border-color:var(--color-danger)}.form-input.input-error:focus{box-shadow:0 0 0 3px #c0392b1f}.form-error{color:var(--color-danger);font-size:.75rem}.input-group{display:flex}.input-group .form-input{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.input-group .input-addon{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-left:none;border-radius:0 var(--radius) var(--radius) 0;color:var(--color-text-muted);display:flex;font-size:.875rem;padding:0 10px;white-space:nowrap}.toggle-wrap{align-items:center;cursor:pointer;display:inline-flex;gap:8px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toggle{background:var(--color-border-strong);border-radius:10px;flex-shrink:0;height:20px;position:relative;transition:background .2s;width:36px}.toggle:after{background:#fff;border-radius:50%;content:"";height:14px;left:3px;position:absolute;top:3px;transition:transform .2s;width:14px}.toggle.on{background:var(--color-accent)}.toggle.on:after{transform:translate(16px)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.stat-grid{display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.stat-card-label{color:var(--color-text-muted);font-size:.75rem;font-weight:500;letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}.stat-card-value{color:var(--color-text);font-size:1.75rem;font-variant-numeric:tabular-nums;font-weight:600;line-height:1}.stat-card-sub{color:var(--color-text-muted);font-size:.75rem;margin-top:6px}.badge{align-items:center;border-radius:100px;display:inline-flex;font-size:.75rem;font-weight:500;gap:4px;padding:2px 8px}.badge-active{background:#dcfce7;color:#166534}.badge-paid{background:#dbeafe;color:#1e40af}.badge-pending{background:#fef9c3;color:#854d0e}.badge-expired{background:#fee2e2;color:#991b1b}.badge-inactive{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted)}.badge-succeeded{background:#dcfce7;color:#166534}.badge-failed{background:#fee2e2;color:#991b1b}.badge-refunded{background:#f3e8ff;color:#6b21a8}.badge-partially_refunded{background:#ede9fe;color:#5b21b6}[data-theme=dark] .badge-active{background:#14532d;color:#86efac}[data-theme=dark] .badge-paid{background:#1e3a5f;color:#93c5fd}[data-theme=dark] .badge-pending{background:#422006;color:#fcd34d}[data-theme=dark] .badge-succeeded{background:#14532d;color:#86efac}[data-theme=dark] .badge-expired,[data-theme=dark] .badge-failed{background:#450a0a;color:#fca5a5}[data-theme=dark] .badge-refunded{background:#3b0764;color:#d8b4fe}[data-theme=dark] .badge-partially_refunded{background:#2e1065;color:#c4b5fd}.table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table{border-collapse:collapse;width:100%}.table th{background:var(--color-surface);color:var(--color-text-muted);font-size:.75rem;font-weight:600;letter-spacing:.06em;padding:10px 14px;text-align:left;text-transform:uppercase}.table td,.table th{border-bottom:1px solid var(--color-border)}.table td{color:var(--color-text);font-size:.875rem;padding:11px 14px}.table tr:last-child td{border-bottom:none}.table tbody tr{background:var(--color-bg);transition:background .1s}.table tbody tr:hover{background:var(--color-surface)}.table-row-clickable{cursor:pointer}.table tbody tr.row-selected,.table tbody tr.row-selected:hover{background:var(--color-accent-light)}.invoice-detail-row td{background:var(--color-surface);border-bottom:1px solid var(--color-border)}.table td.amount-col,.table th.amount-col{font-variant-numeric:tabular-nums;text-align:right}.filter-pills,.row-actions{display:flex;gap:4px}.filter-pills{flex-wrap:wrap}.filter-pill{background:transparent;border:1px solid var(--color-border);border-radius:100px;color:var(--color-text-muted);cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;padding:4px 12px;transition:background .12s,color .12s,border-color .12s}.filter-pill:hover{border-color:var(--color-accent);color:var(--color-accent)}.filter-pill.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.modal-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:50}.modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-height:90dvh;max-width:520px;overflow-y:auto;padding:24px;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.modal-footer{border-top:1px solid var(--color-border);display:flex;gap:8px;justify-content:flex-end;margin-top:24px;padding-top:16px}.slideover-overlay{background:#00000059;inset:0;position:fixed;z-index:40}.slideover{background:var(--color-bg);border-left:1px solid var(--color-border);display:flex;flex-direction:column;height:100dvh;max-width:100vw;overflow:hidden;position:fixed;right:0;top:0;width:480px;z-index:41}.slideover-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 20px}.slideover-body{display:flex;flex:1;flex-direction:column;gap:16px;overflow-y:auto;padding:20px}.slideover-footer{border-top:1px solid var(--color-border);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:16px 20px}.pdf-upload-area,.pdf-upload-label{align-items:center;display:flex;gap:8px}.pdf-upload-label{border:1px dashed var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;flex:1;font-size:.875rem;padding:7px 12px;transition:border-color .15s,color .15s}.pdf-upload-label:hover{border-color:var(--color-primary);color:var(--color-primary)}.auth-layout{align-items:center;background:var(--color-bg);display:flex;justify-content:center;min-height:100dvh;padding:24px}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-width:400px;padding:36px;width:100%}.auth-logo{align-items:center;color:var(--color-accent);display:flex;font-size:1.125rem;font-weight:700;gap:8px;justify-content:center;margin-bottom:28px}.auth-title{font-size:1.25rem;font-weight:600;margin-bottom:4px;text-align:center}.auth-subtitle{color:var(--color-text-muted);font-size:.875rem;margin-bottom:24px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-footer{color:var(--color-text-muted);font-size:.875rem;margin-top:20px;text-align:center}.alert{border:1px solid transparent;border-radius:var(--radius);font-size:.875rem;padding:10px 14px}.alert-error{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.alert-warning{background:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning)}.alert-info{background:var(--color-info-light);border-color:var(--color-info);color:var(--color-info)}.alert-success{background:#f0fdf4;border-color:#16a34a;color:#16a34a}[data-theme=dark] .alert-success{background:#14532d;border-color:#16a34a;color:#86efac}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:1.25rem}.search-wrap{align-items:center;display:inline-flex;position:relative}.search-wrap .search-icon{color:var(--color-text-muted);left:9px;pointer-events:none;position:absolute}.search-wrap .form-input{padding-left:32px}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}.toolbar-spacer{flex:1}.section-divider{border:none;border-top:1px solid var(--color-border);margin:24px 0}.settings-layout{max-width:680px}.settings-section{margin-bottom:32px}.settings-section-title{color:var(--color-text-muted);font-size:.75rem;font-weight:600;letter-spacing:.08em;margin-bottom:12px;padding-bottom:8px;text-transform:uppercase}.settings-row,.settings-section-title{border-bottom:1px solid var(--color-border)}.settings-row{align-items:center;display:flex;justify-content:space-between;padding:12px 0}.settings-row:last-child{border-bottom:none}.settings-row-info{flex:1}.settings-row-label{font-size:.875rem;font-weight:500}.settings-row-desc{color:var(--color-text-muted);font-size:.8125rem;margin-top:2px}.danger-zone{border:1px solid var(--color-danger);border-radius:var(--radius-lg);margin-top:8px;padding:20px}.psp-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:14px 16px;transition:border-color .15s}.psp-card--active{background:var(--color-accent-light);border-color:var(--color-accent)}.psp-card-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.psp-form{border-top:1px solid var(--color-border);margin-top:14px;padding-top:14px}.empty-state,.psp-form{display:flex;flex-direction:column;gap:12px}.empty-state{align-items:center;color:var(--color-text-muted);justify-content:center;padding:60px 24px;text-align:center}.empty-state-icon{opacity:.35}.empty-state-title{color:var(--color-text);font-size:.9375rem;font-weight:600}.empty-state-desc{font-size:.875rem;max-width:320px}@keyframes spin{to{transform:rotate(1turn)}}.spinner{animation:spin .7s linear infinite;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-accent);height:20px;width:20px}.pay-layout{align-items:center;background:var(--color-bg);display:flex;justify-content:center;min-height:100dvh;padding:24px}.pay-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-width:440px;padding:32px;width:100%}.pay-merchant-logo{border-radius:var(--radius);height:56px;margin-bottom:16px;-o-object-fit:contain;object-fit:contain;width:56px}.pay-merchant-name{color:var(--color-text-muted);font-size:.875rem;margin-bottom:4px}.pay-description{font-size:1rem;font-weight:600;margin-bottom:8px}.pay-amount{color:var(--color-accent);font-size:2rem;font-variant-numeric:tabular-nums;font-weight:700;margin-bottom:24px}.chart-wrap{height:220px;position:relative}.chart-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-top:16px}.editor-toolbar{background:var(--color-surface);border:1px solid var(--color-border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;display:flex;gap:2px;padding:6px 8px}.editor-body{background:var(--color-bg);border:1px solid var(--color-border);border-radius:0 0 var(--radius) var(--radius);color:var(--color-text);font-size:.875rem;line-height:1.6;min-height:160px;outline:none;padding:12px}.editor-body:focus{border-color:var(--color-accent)}.variable-chip{align-items:center;background:var(--color-accent-light);border:1px solid var(--color-accent);border-radius:3px;color:var(--color-accent);cursor:pointer;display:inline-flex;font-family:monospace;font-size:.8125rem;margin:0 2px;padding:0 5px}.variable-chip:hover{filter:brightness(.93)}.topbar-hamburger{align-items:center;background:transparent;border:none;border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;display:none;flex-shrink:0;height:36px;justify-content:center;transition:background .12s,color .12s;width:36px}.topbar-hamburger:hover{background:var(--color-accent-light);color:var(--color-accent)}@media(min-width:640px)and (max-width:899px){.sidebar{width:56px}.sidebar-item-label,.sidebar-logo-text,.sidebar-section-label{display:none}.sidebar-logo{justify-content:center;padding:0}.sidebar-item{justify-content:center;padding:8px 0}.page-body{padding:16px}.stat-grid{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}}@media(max-width:639px){.sidebar{box-shadow:none;height:100dvh;left:0;position:fixed;top:0;transform:translate(-100%);transition:transform .22s ease;width:var(--sidebar-width);z-index:100}.sidebar.mobile-open{box-shadow:4px 0 32px #0000002e;transform:translate(0)}.topbar-hamburger{display:flex}.table-wrap{overflow-x:auto}.page-header{flex-wrap:wrap;gap:10px}.stat-grid{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}.modal-overlay,.page-body{padding:12px}.modal{padding:16px}.link-form-grid{grid-template-columns:1fr}.slideover{width:100vw}}.flex,.flex-col{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.04em;padding:2px 10px;text-transform:uppercase;white-space:nowrap}.status-active{background:#dcfce7;color:#15803d}.status-paid{background:#dbeafe;color:#1d4ed8}.status-expired{background:#fef9c3;color:#a16207}.status-inactive{background:#f1f5f9;color:#64748b}.status-pending{background:#fef3c7;color:#b45309}
