:root{--distrix-purple: #4A3DB5;--distrix-purple-dark: #352D8A;--distrix-purple-light: #6B5ED4;--distrix-purple-50: #EDEAFB;--distrix-purple-100: #D4D0F3;--primary: var(--distrix-purple);--primary-dark: var(--distrix-purple-dark);--primary-light: var(--distrix-purple-50);--success: #16a34a;--success-light: #f0fdf4;--danger: #dc2626;--danger-light: #fef2f2;--warning: #d97706;--warning-light: #fffbeb;--info: #0891b2;--info-light: #ecfeff;--neutral: #6b7280;--neutral-light: #f9fafb;--sidebar-w: 240px;--sidebar-bg: #ffffff;--sidebar-text: #64748b;--sidebar-hover: var(--distrix-purple-50);--bg: #F4F2FA;--surface: #ffffff;--border: #E5E1F0;--text: #1E1B2E;--text-muted: #6B6580;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(74,61,181,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(74,61,181,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 8px 24px rgba(74,61,181,.1);--font-heading: "DM Sans", "Inter", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}input,select,textarea{font:inherit}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh;overflow-x:hidden}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100}.sidebar-header{padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-logo{display:flex;flex-direction:column;gap:6px}.logo-tenant{color:var(--text-muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius);color:var(--sidebar-text);font-size:13.5px;font-weight:500;transition:background .15s,color .15s}.nav-item:hover{background:var(--sidebar-hover);color:var(--distrix-purple)}.nav-item--active{background:var(--distrix-purple-50)!important;color:var(--distrix-purple)!important;font-weight:600}.sidebar-footer{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}.sidebar-user{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--distrix-purple);color:#fff;display:grid;place-items:center;font-weight:700;font-size:12px;flex-shrink:0}.user-name{color:var(--text);font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:var(--text-muted);font-size:11px;text-transform:capitalize}.logout-btn{color:var(--text-muted);padding:6px;border-radius:6px;transition:color .15s}.logout-btn:hover{color:var(--danger)}.page{padding:28px 32px;max-width:1400px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.page-title{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--text)}.page-sub{color:var(--text-muted);font-size:13px;margin-top:3px}.page-actions{display:flex;gap:8px;flex-shrink:0}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px}.kpi-link{display:block}.kpi-link:hover .kpi-card{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s;border-top:3px solid transparent}.kpi-card--blue{border-top-color:var(--distrix-purple)}.kpi-card--red{border-top-color:var(--danger)}.kpi-card--orange{border-top-color:var(--warning)}.kpi-card--purple{border-top-color:var(--distrix-purple-light)}.kpi-card--green{border-top-color:var(--success)}.kpi-card--yellow{border-top-color:#ca8a04}.kpi-icon{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}.kpi-card--blue .kpi-icon{background:var(--distrix-purple-50);color:var(--distrix-purple)}.kpi-card--red .kpi-icon{background:var(--danger-light);color:var(--danger)}.kpi-card--orange .kpi-icon{background:var(--warning-light);color:var(--warning)}.kpi-card--purple .kpi-icon{background:var(--distrix-purple-50);color:var(--distrix-purple-light)}.kpi-card--green .kpi-icon{background:var(--success-light);color:var(--success)}.kpi-card--yellow .kpi-icon{background:#fefce8;color:#ca8a04}.kpi-value{font-family:var(--font-heading);font-size:20px;font-weight:800;color:var(--text)}.kpi-label{font-size:12px;color:var(--text-muted);margin-top:2px}.kpi-sub{font-size:11px;color:var(--text-muted)}.alert{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);margin-bottom:20px;font-size:13.5px}.alert-warning{background:var(--warning-light);color:#92400e;border:1px solid #fcd34d}.alert-action{margin-left:auto;display:flex;align-items:center;gap:4px;font-weight:600;color:var(--warning);text-decoration:underline}.dashboard-tables{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 1100px){.dashboard-tables{grid-template-columns:1fr}}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-family:var(--font-heading);font-size:15px;font-weight:600}.card-link{font-size:12px;color:var(--primary);display:flex;align-items:center;gap:4px}.card-link:hover{text-decoration:underline}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--neutral-light);border-bottom:1px solid var(--border)}.data-table td{padding:11px 16px;border-bottom:1px solid var(--border);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--neutral-light)}.table-link{color:var(--primary);font-weight:500}.table-link:hover{text-decoration:underline}.td-client{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.td-amount{font-family:var(--font-mono);font-weight:600;font-variant-numeric:tabular-nums;font-size:12.5px}.td-date{color:var(--text-muted)}.badge{display:inline-block;padding:3px 8px;border-radius:99px;font-size:11px;font-weight:600}.badge-success{background:var(--success-light);color:var(--success)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-info{background:var(--info-light);color:var(--info)}.badge-neutral{background:#f1f5f9;color:var(--neutral)}.badge-primary{background:var(--primary-light);color:var(--primary)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;transition:background .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--neutral-light)}.btn-full{width:100%;justify-content:center}.btn-icon{padding:5px 7px;border-radius:6px;color:var(--text-muted);transition:background .15s,color .15s}.btn-icon:hover{background:var(--primary-light);color:var(--primary)}.btn-icon+.btn-icon{margin-left:2px}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-group label{font-size:13px;font-weight:500}.form-group input,.form-group select,.form-group textarea{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4a3db51a}.form-error{color:var(--danger);font-size:12px;margin-top:4px;display:block}.form-group .input-error{border-color:var(--danger)!important}.form-group .input-error:focus{box-shadow:0 0 0 3px #dc26261f}.login-page{min-height:100vh;display:flex}.login-hero{flex:0 0 44%;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(160deg,#352d8a,#4a3db5 40%,#6b5ed4);padding:60px 56px}.login-hero-content{position:relative;z-index:1}.login-hero-title{font-family:var(--font-heading);color:#fff;font-size:28px;font-weight:700;line-height:1.3;margin-top:32px}.login-hero-desc{color:#ffffffb3;font-size:15px;line-height:1.6;margin-top:16px;max-width:360px}.login-hero-pattern{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.06;background-image:radial-gradient(circle at 2px 2px,#fff 1px,transparent 0);background-size:28px 28px}.login-form-side{flex:1;display:flex;align-items:center;justify-content:center;background:#fff;padding:40px}.login-card{background:#fff;padding:44px 40px;width:100%;max-width:420px}.login-header{margin-bottom:32px}.login-subtitle{color:var(--text-muted);font-size:14px;margin-top:12px}.login-form{display:flex;flex-direction:column;gap:18px}.login-footer{text-align:center;color:var(--text-muted);font-size:11px;margin-top:24px;list-style:none;display:block}.input-icon-wrap{position:relative;display:flex;align-items:center;border:1.5px solid var(--border);border-radius:10px;background:#fff;transition:border-color .15s,box-shadow .15s}.input-icon-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #4a3db514}.input-icon{position:absolute;left:14px;color:var(--text-muted);pointer-events:none;flex-shrink:0}.input-icon-wrap input{flex:1;border:none;outline:none;background:transparent;padding:12px 14px 12px 42px;font-size:14px;color:var(--text);border-radius:10px}.input-icon-wrap input::placeholder{color:var(--text-muted)}.pwd-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:6px;display:flex;align-items:center}.pwd-toggle:hover{color:var(--text);background:var(--neutral-light)}.login-error{display:flex;align-items:center;gap:8px;background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;padding:10px 14px;border-radius:10px;font-size:13px}.login-btn{width:100%;padding:13px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-family:var(--font-heading);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.login-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn-loading{display:flex;align-items:center;justify-content:center;gap:10px}.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media (max-width: 900px){.login-hero{display:none}.login-form-side{background:#fff}}.placeholder-content{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 20px;color:var(--text-muted)}.placeholder-icon{opacity:.3}.lookup-root{position:relative}.lookup-field{display:flex;align-items:center;gap:8px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .15s,box-shadow .15s;min-height:38px}.lookup-field--open{border-color:var(--primary);box-shadow:0 0 0 3px #4a3db51a}.lookup-field--error{border-color:var(--danger)}.lookup-field-icon{color:var(--text-muted);flex-shrink:0}.lookup-input{flex:1;border:none;outline:none;background:transparent;font-size:14px;color:var(--text);padding:8px 0}.lookup-input::placeholder{color:var(--text-muted)}.lookup-chevron{color:var(--text-muted);flex-shrink:0}.lookup-chevron-btn{display:flex;align-items:center;justify-content:center;width:32px;height:100%;margin:-6px -10px -6px 0;padding:0;border:none;background:transparent;cursor:pointer;color:var(--text-muted);flex-shrink:0;border-left:1px solid var(--border);border-radius:0 var(--radius) var(--radius) 0;transition:background .15s,color .15s}.lookup-chevron-btn:hover{background:var(--neutral-light);color:var(--text)}.lookup-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.lookup-selected{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--primary-light);min-height:38px}.lookup-selected--disabled{background:var(--neutral-light);cursor:not-allowed}.lookup-selected-icon{color:var(--success);flex-shrink:0}.lookup-selected-name{font-size:14px;font-weight:600;color:var(--text);flex:1}.lookup-selected-secondary{font-size:11.5px;background:var(--border);color:var(--text-muted);padding:1px 7px;border-radius:99px;white-space:nowrap}.lookup-clear{padding:3px;border-radius:4px;color:var(--text-muted);transition:background .12s,color .12s;flex-shrink:0}.lookup-clear:hover{background:var(--danger-light);color:var(--danger)}.lookup-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:300;max-height:280px;overflow-y:auto;animation:fade-in .12s ease}.lookup-item{display:block;width:100%;padding:9px 12px;text-align:left;font-size:13.5px;transition:background .1s;border-radius:0;color:var(--text);background:transparent;border:none;cursor:pointer}.lookup-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.lookup-item:hover,.lookup-item--active{background:var(--primary-light)}.lookup-item-label{font-weight:500;color:var(--text)}.lookup-item-secondary{font-size:11.5px;color:var(--text-muted);margin-top:1px}.lookup-state{padding:12px;font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:8px}.lookup-state--empty{justify-content:center}.lookup-spinner-sm{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.lookup-create-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;text-align:left;font-size:13px;color:var(--primary);font-weight:600;border-top:1px solid var(--border);transition:background .1s;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.lookup-create-btn:hover,.lookup-create-btn.lookup-item--active{background:var(--primary-light)}.mf-page{min-height:100vh;background:var(--bg)}.mf-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.mf-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13.5px}.mf-breadcrumb-link{color:var(--primary);font-weight:500}.mf-breadcrumb-link:hover{text-decoration:underline}.mf-breadcrumb-sep{color:var(--text-muted)}.mf-breadcrumb-current{color:var(--text);font-weight:600}.mf-header-actions{display:flex;gap:8px;align-items:center}.mf-dirty-banner{background:var(--warning-light);border-bottom:1px solid var(--warning);color:var(--warning);padding:10px 32px;font-size:13px;font-weight:500}.mf-title-block{display:flex;align-items:center;gap:16px;padding:20px 32px 0}.mf-avatar{width:52px;height:52px;border-radius:12px;background:var(--primary);color:#fff;font-size:22px;font-weight:800;display:grid;place-items:center;flex-shrink:0}.mf-title{font-family:var(--font-heading);font-size:22px;font-weight:800}.mf-title-input{font-family:var(--font-heading);font-size:22px;font-weight:800;border:none;outline:none;background:transparent;border-bottom:2px solid var(--primary);padding:0 0 2px;width:100%;min-width:280px}.mf-tabs{padding:0 32px;margin-top:16px}.mf-columns{display:grid;grid-template-columns:1fr 320px;gap:20px;margin-bottom:20px}.mf-col,.mf-col--side{display:flex;flex-direction:column;gap:16px}.mf-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.mf-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:6px}.mf-stat-value{font-family:var(--font-heading);font-size:20px;font-weight:800}.mf-stat-value--accent{color:var(--danger)}.list-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.vs-root{position:relative;flex-shrink:0}.vs-trigger{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:13.5px;font-weight:600;color:var(--text);cursor:pointer;transition:border-color .15s,box-shadow .15s}.vs-trigger:hover{border-color:var(--primary)}.vs-icon{font-size:15px}.vs-name{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vs-chevron{color:var(--text-muted);transition:transform .2s;flex-shrink:0}.vs-chevron--open{transform:rotate(180deg)}.vs-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:280px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:200;padding:6px;animation:fade-in .12s ease}.vs-dropdown-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:4px 10px 6px}.vs-option{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:var(--radius);font-size:13px;cursor:pointer;transition:background .12s;text-align:left}.vs-option:hover{background:var(--neutral-light)}.vs-option--active{background:var(--primary-light)}.vs-option-icon{font-size:16px;flex-shrink:0;width:24px;text-align:center}.vs-option-body{flex:1;min-width:0}.vs-option-name{font-weight:600;color:var(--text)}.vs-option-desc{font-size:11px;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-box{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0 10px;gap:8px;min-width:280px;flex:1;max-width:480px;transition:border-color .15s,box-shadow .15s}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #4a3db514}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{flex:1;border:none;outline:none;background:transparent;font-size:13.5px;padding:8px 0;color:var(--text)}.search-input::placeholder{color:var(--text-muted)}.search-clear{color:var(--text-muted);font-size:18px;line-height:1;padding:0 2px;transition:color .12s}.search-clear:hover{color:var(--text)}.filter-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:11.5px;font-weight:600}.filter-chip--success{background:var(--success-light);color:var(--success)}.filter-chip--neutral{background:#f1f5f9;color:var(--neutral)}.filter-chip--danger{background:var(--danger-light);color:var(--danger)}.filter-chip--info{background:var(--info-light);color:var(--info)}.grid-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;margin-bottom:14px}.td-name{max-width:220px}.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 0;flex-wrap:wrap;gap:10px}.pagination-info{font-size:13px;color:var(--text-muted)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{font-size:13px;padding:6px 12px}.pagination-page{width:32px;height:32px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-muted);transition:background .12s,color .12s}.pagination-page:hover{background:var(--neutral-light);color:var(--text)}.pagination-page--active{background:var(--primary);color:#fff;font-weight:700}.top-loader{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;background:var(--primary-light)}.top-loader-bar{height:100%;background:var(--primary);transition:width .2s ease;border-radius:0 2px 2px 0;box-shadow:0 0 8px var(--primary)}.rp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:500;opacity:0;pointer-events:none;transition:opacity .25s}.rp-overlay--visible{opacity:1;pointer-events:all}.rp-panel{position:fixed;top:0;right:0;bottom:0;background:var(--surface);box-shadow:-8px 0 32px #0000002e;z-index:501;display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}.rp-panel--open{transform:translate(0)}.rp-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.rp-title{font-family:var(--font-heading);font-size:17px;font-weight:700;color:var(--text)}.rp-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}.rp-close{padding:6px;border-radius:var(--radius);color:var(--text-muted);transition:background .15s,color .15s}.rp-close:hover{background:var(--neutral-light);color:var(--text)}.rp-body{flex:1;overflow-y:auto;padding:24px}.rp-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0}.toast-stack{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;gap:10px;max-width:380px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);box-shadow:var(--shadow-md);font-size:13.5px;font-weight:500;cursor:pointer;animation:toast-in .22s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast--success{background:var(--success-light);color:var(--success);border-left:4px solid var(--success)}.toast--error{background:var(--danger-light);color:var(--danger);border-left:4px solid var(--danger)}.toast--warning{background:var(--warning-light);color:var(--warning);border-left:4px solid var(--warning)}.toast--info{background:var(--info-light);color:var(--info);border-left:4px solid var(--info)}.toast-icon{font-size:15px;flex-shrink:0}.toast-msg{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:800;display:grid;place-items:center;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-dialog{background:var(--surface);border-radius:var(--radius-lg);padding:32px;max-width:400px;width:92%;text-align:center;box-shadow:0 20px 60px #00000040;animation:dialog-in .18s ease}@keyframes dialog-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.modal-icon{font-size:32px;margin-bottom:12px}.modal-title{font-family:var(--font-heading);font-size:18px;font-weight:700;margin-bottom:8px}.modal-msg{color:var(--text-muted);font-size:14px;margin-bottom:24px;line-height:1.5}.modal-actions{display:flex;justify-content:center;gap:10px}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:8px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600}.btn-ghost:hover{background:var(--neutral-light)}.mda-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:0}.mda-tab{padding:10px 20px;font-size:13.5px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.mda-tab:hover{color:var(--text)}.mda-tab--active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.mda-section{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}.mda-section-header{padding:12px 20px;background:var(--neutral-light);border-bottom:1px solid var(--border);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.mda-section-body{padding:20px}.mda-grid{display:grid;gap:16px 24px}.mda-grid-2{grid-template-columns:1fr 1fr}.mda-grid-3{grid-template-columns:1fr 1fr 1fr}@media (max-width: 700px){.mda-grid-2,.mda-grid-3{grid-template-columns:1fr}}.page-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-title{font-size:22px;font-weight:800}.page-actions{display:flex;gap:8px}.settings-layout{display:flex;min-height:calc(100vh - 120px);gap:0}.settings-nav{width:220px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:8px;flex-shrink:0;align-self:flex-start;position:sticky;top:24px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);font-size:13.5px;font-weight:500;color:var(--text-muted);transition:background .15s,color .15s;width:100%;text-align:left}.settings-nav-item:hover{background:var(--neutral-light);color:var(--text)}.settings-nav-item--active{background:var(--primary-light);color:var(--primary);font-weight:600}.settings-content{flex:1;min-width:0;padding-left:20px}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:14px;font-weight:500}.toggle-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.toggle{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#cbd5e1;border-radius:99px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-slider{background:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.inline-table{width:100%;border-collapse:collapse}.inline-table th{text-align:left;padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--neutral-light);border-bottom:1px solid var(--border)}.inline-table td{padding:6px 8px;border-bottom:1px solid var(--border)}.inline-table tr:last-child td{border-bottom:none}.inline-table input,.inline-table select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);width:100%;font-size:13px;box-sizing:border-box}.inline-table select{-moz-appearance:auto;appearance:auto;-webkit-appearance:menulist;padding-right:24px}.inline-table input:focus,.inline-table select:focus{outline:none;border-color:var(--primary)}.filter-input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font:inherit;font-size:13px;transition:border-color .15s}.filter-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4a3db51a}.form-group textarea{width:100%;resize:vertical;box-sizing:border-box}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:40px;opacity:.3;margin-bottom:12px}.empty-state-title{font-size:15px;font-weight:600;margin-bottom:4px}.empty-state-desc{font-size:13px}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.tpl-card{border:2px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;background:var(--surface)}.tpl-card:hover{border-color:var(--primary);box-shadow:0 0 0 3px #4a3db514}.tpl-card--selected{border-color:var(--primary);background:var(--primary-light)}.tpl-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.tpl-card-name{font-size:15px;font-weight:700}.tpl-card-format{font-size:11px;color:var(--text-muted);margin-top:2px}.tpl-card-check{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800;flex-shrink:0}.tpl-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:10px}.tpl-card-features{list-style:none;margin-bottom:12px}.tpl-card-features li{font-size:11.5px;color:var(--text-muted);padding:2px 0}.tpl-card-features li:before{content:"✓ ";color:var(--success);font-weight:700}.tpl-card-preview-btn{font-size:12px;padding:5px 12px;width:100%;justify-content:center}.tpl-field-section{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.tpl-field-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 16px;border:none;background:var(--bg-alt, #f8fafc);cursor:pointer;font-size:13px;font-weight:600;color:var(--text);transition:background .15s}.tpl-field-section-toggle:hover{background:var(--bg-hover, #f1f5f9)}.tpl-field-section-body{padding:12px 16px 16px;display:flex;flex-direction:column;gap:16px}.tpl-field-config{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}.tpl-field-config-header{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.tpl-field-config-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px 16px}.tpl-field-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0}.tpl-field-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.tpl-field-toggle-label{font-size:12.5px;color:var(--text);-webkit-user-select:none;user-select:none}.print-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:900;display:flex;flex-direction:column;animation:fade-in .15s ease}.print-preview-shell{display:flex;flex-direction:column;height:100%}.print-preview-topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#1e1b2e;color:#fff;flex-shrink:0}.print-preview-title{font-size:15px;font-weight:700}.print-preview-canvas{flex:1;overflow-y:auto;background:#525659;display:flex;justify-content:center;padding:32px}.print-preview-doc{background:#fff;box-shadow:0 4px 32px #00000059}.pt-page{background:#fff;font-family:Arial,sans-serif;font-size:12px;color:#0f172a}.pt-a4{width:794px;min-height:1123px;padding:56px 60px}.pt-thermal{width:302px;padding:16px}.pt-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #1e293b}.pt-company-name{font-size:18px;font-weight:800;color:#1e293b;margin-bottom:4px}.pt-company-info{font-size:10px;color:#475569;line-height:1.7}.pt-legal{font-weight:700;color:#1e293b!important}.pt-doc-type{font-size:24px;font-weight:900;color:var(--distrix-purple);text-align:right;letter-spacing:1px;margin-bottom:6px}.pt-copy-label{font-size:10px;font-weight:700;color:#6b7280;text-align:right;border:1px solid #6b7280;padding:1px 6px;display:inline-block}.pt-doc-number{font-size:14px;font-weight:700;text-align:right;margin-bottom:4px}.pt-doc-date,.pt-doc-ref{font-size:11px;text-align:right;color:#475569;line-height:1.6}.pt-client-block{border:1px solid #e2e8f0;border-radius:6px;padding:12px 16px;margin-bottom:24px;max-width:300px}.pt-client-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin-bottom:4px}.pt-client-name{font-size:14px;font-weight:700;margin-bottom:2px}.pt-client-info{font-size:10px;color:#475569;line-height:1.6}.pt-table{width:100%;border-collapse:collapse;font-size:10.5px;margin-bottom:20px}.pt-table th{background:#1e293b;color:#fff;padding:8px 7px;text-align:left;font-size:9px;font-weight:600;letter-spacing:.04em}.pt-table td{padding:7px;border-bottom:1px solid #f1f5f9;vertical-align:top}.pt-table tbody tr:nth-child(2n) td{background:#f8fafc}.pt-table tfoot td{background:#f1f5f9;font-weight:700;border-top:2px solid #1e293b;font-size:11px}.pt-ref{font-size:9px;color:#94a3b8}.pt-center{text-align:center}.pt-right{text-align:right}.pt-bold{font-weight:700}.pt-totals{display:flex;justify-content:flex-end;gap:20px;margin-bottom:16px;align-items:flex-start}.pt-taxes-summary{min-width:220px}.pt-tax-table{width:100%;border-collapse:collapse;font-size:10px}.pt-tax-table th{background:#f1f5f9;padding:5px 8px;font-size:9px;font-weight:600;text-align:center;border-bottom:1px solid #e2e8f0}.pt-tax-table td{padding:4px 8px;border-bottom:1px solid #f8fafc}.pt-total-box{min-width:220px;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.pt-total-row{display:flex;justify-content:space-between;padding:6px 12px;font-size:11px;border-bottom:1px solid #f1f5f9}.pt-total-ttc{background:#1e293b;color:#fff;font-size:14px;font-weight:800;padding:10px 12px;border-bottom:none}.pt-words{font-size:10px;font-style:italic;color:#475569;border-top:1px solid #e2e8f0;padding:10px 0;margin-bottom:14px}.pt-notes{font-size:10px;color:#475569;border:1px dashed #cbd5e1;border-radius:4px;padding:8px 12px;margin-bottom:20px}.pt-signatures{display:flex;gap:24px;margin-top:36px}.pt-sig-box{flex:1;border:1px solid #e2e8f0;border-radius:6px;padding:14px;min-height:80px}.pt-sig-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:6px}.pt-sig-name,.pt-sig-date{font-size:10px;color:#94a3b8}.pt-cut-line{text-align:center;font-size:9px;color:#94a3b8;margin:12px 0;border-top:1px dashed #cbd5e1;padding-top:4px}.pt-inv-kpis{display:flex;gap:16px;margin-bottom:24px}.pt-inv-kpi{flex:1;border:1px solid #e2e8f0;border-radius:8px;padding:12px;text-align:center}.pt-inv-kpi-val{font-size:26px;font-weight:800}.pt-inv-kpi-label{font-size:9px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.pt-footer{margin-top:36px;padding-top:8px;border-top:1px solid #e2e8f0;font-size:8px;color:#94a3b8;text-align:center;line-height:1.6}.pt-thermal-header{font-size:15px;font-weight:800;text-align:center;margin-bottom:2px}.pt-thermal-sub{font-size:9px;text-align:center;color:#475569}.pt-thermal-divider{border-top:1px dashed #000;margin:6px 0}.pt-thermal-doctype{font-size:13px;font-weight:900;text-align:center;letter-spacing:1.5px;margin:5px 0}.pt-thermal-ref{font-size:11px;font-weight:700;text-align:center}.pt-thermal-client{font-size:10px;text-align:center;color:#475569;margin-bottom:4px}.pt-thermal-line{margin:3px 0}.pt-thermal-line-amounts{display:flex;justify-content:space-between;font-size:10px;color:#475569}.pt-thermal-total{font-size:15px;font-weight:900;text-align:center;padding:7px 0;border-top:2px solid #000;border-bottom:2px solid #000;margin:6px 0}.pt-pro{font-family:Inter,DM Sans,system-ui,sans-serif}.pt-pro-accent{height:5px;background:linear-gradient(90deg,var(--distrix-purple, #4A3DB5) 0%,#6B5ED4 50%,#8B7FE8 100%);margin:-56px -60px 24px;border-radius:0}.pt-pro-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px}.pt-pro-company-name{font-family:DM Sans,system-ui,sans-serif;font-size:22px;font-weight:700;color:#1e293b;margin-bottom:6px}.pt-pro-company-details{display:flex;flex-direction:column;gap:1px;font-size:10px;color:#64748b;line-height:1.6}.pt-pro-legal{display:flex;gap:16px;font-size:10px;font-weight:600;color:#1e293b;margin-top:4px}.pt-pro-doc-info{text-align:right}.pt-pro-doc-badge{display:inline-block;background:var(--distrix-purple, #4A3DB5);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;padding:6px 16px;border-radius:4px;margin-bottom:8px}.pt-pro-doc-number{font-size:16px;font-weight:700;color:#1e293b;margin-bottom:6px;font-family:JetBrains Mono,monospace}.pt-pro-doc-meta{font-size:10px;color:#64748b;line-height:1.8}.pt-pro-meta-label{font-weight:600;color:#475569}.pt-pro-client{border-left:3px solid var(--distrix-purple, #4A3DB5);padding:10px 14px;margin-bottom:24px;background:#f8fafc;border-radius:0 6px 6px 0;max-width:320px}.pt-pro-client-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--distrix-purple, #4A3DB5);margin-bottom:4px}.pt-pro-client-name{font-size:14px;font-weight:700;color:#1e293b;margin-bottom:2px}.pt-pro-client-info{font-size:10px;color:#64748b;line-height:1.6}.pt-pro-table{width:100%;border-collapse:collapse;font-size:10.5px;margin-bottom:20px}.pt-pro-table th{background:var(--distrix-purple, #4A3DB5);color:#fff;padding:9px 8px;text-align:left;font-size:9px;font-weight:600;letter-spacing:.04em}.pt-pro-table td{padding:8px;border-bottom:1px solid #f1f5f9;vertical-align:top}.pt-pro-table tbody tr:nth-child(2n) td{background:#fafaff}.pt-pro-table tfoot td{background:#f1f5f9;font-weight:700;border-top:2px solid var(--distrix-purple, #4A3DB5);font-size:11px}.pt-pro-totals{display:flex;justify-content:flex-end;gap:20px;margin-bottom:16px;align-items:flex-start}.pt-pro-taxes{min-width:200px}.pt-pro-taxes-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:6px}.pt-pro-tax-row{display:flex;justify-content:space-between;gap:12px;font-size:10px;padding:3px 0;border-bottom:1px solid #f1f5f9}.pt-pro-total-box{min-width:230px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.pt-pro-total-row{display:flex;justify-content:space-between;padding:7px 14px;font-size:11px;border-bottom:1px solid #f1f5f9}.pt-pro-total-final{background:var(--distrix-purple, #4A3DB5);color:#fff;font-size:15px;font-weight:800;padding:12px 14px;border-bottom:none}.pt-pro-words{font-size:10px;font-style:italic;color:#475569;border-top:1px solid #e2e8f0;padding:10px 0;margin-bottom:14px}.pt-pro-footer{margin-top:32px;padding-top:8px;border-top:2px solid var(--distrix-purple, #4A3DB5);font-size:8px;color:#94a3b8;text-align:center;line-height:1.8}.pt-pro-bl-summary{display:flex;gap:24px;padding:10px 0;font-size:11px;color:#475569;border-top:1px solid #e2e8f0;margin-bottom:16px}.pt-pro-responsibles{margin:0 0 16px;font-size:11px;border-left:3px solid var(--distrix-purple, #4A3DB5);padding:6px 12px;background:#fafaff}.pt-bilingual{font-family:Inter,Cairo,system-ui,sans-serif}.pt-bi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:14px;border-bottom:3px solid #1e293b}.pt-bi-header-fr{flex:1}.pt-bi-header-ar{flex:1;text-align:right;direction:rtl;font-family:Cairo,Noto Sans Arabic,sans-serif}.pt-bi-company-name{font-size:17px;font-weight:700;color:#1e293b;margin-bottom:4px}.pt-bi-company-name-ar{font-size:17px;font-weight:700;color:#1e293b;margin-bottom:4px;font-family:Cairo,sans-serif}.pt-bi-info{font-size:10px;color:#64748b;line-height:1.6}.pt-bi-info-ar{font-size:10px;color:#64748b;line-height:1.6;font-family:Cairo,sans-serif}.pt-bi-title{text-align:center;margin-bottom:6px;padding:10px 0;background:#1e293b;color:#fff;border-radius:4px}.pt-bi-title-fr{font-size:18px;font-weight:800;letter-spacing:1px}.pt-bi-title-sep{font-size:18px;margin:0 14px;opacity:.5}.pt-bi-title-ar{font-size:18px;font-weight:700;font-family:Cairo,sans-serif}.pt-bi-doc-meta{display:flex;justify-content:center;gap:24px;font-size:11px;color:#475569;margin-bottom:16px;padding:6px 0}.pt-bi-client{display:flex;gap:20px;margin-bottom:20px}.pt-bi-client-fr{flex:1;border:1px solid #e2e8f0;border-radius:6px;padding:10px 14px}.pt-bi-client-ar{flex:1;border:1px solid #e2e8f0;border-radius:6px;padding:10px 14px;direction:rtl;text-align:right;font-family:Cairo,sans-serif}.pt-bi-client-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin-bottom:4px}.pt-bi-client-label-ar{font-size:11px;font-weight:700;color:#64748b;margin-bottom:4px;font-family:Cairo,sans-serif}.pt-bi-client-name{font-size:13px;font-weight:700;margin-bottom:2px}.pt-bi-client-info{font-size:10px;color:#64748b;line-height:1.5}.pt-bi-table{width:100%;border-collapse:collapse;font-size:10.5px;margin-bottom:20px}.pt-bi-table th{background:#1e293b;color:#fff;padding:8px 7px;text-align:center;font-size:9px;font-weight:600;line-height:1.4}.pt-bi-table td{padding:7px;border-bottom:1px solid #f1f5f9;vertical-align:top}.pt-bi-table tbody tr:nth-child(2n) td{background:#f8fafc}.pt-bi-totals{display:flex;flex-direction:column;align-items:flex-end;margin-bottom:16px}.pt-bi-total-row{display:flex;justify-content:space-between;width:350px;padding:6px 14px;font-size:11px;border-bottom:1px solid #f1f5f9}.pt-bi-total-final{background:#1e293b;color:#fff;font-size:14px;font-weight:800;padding:10px 14px;border-radius:4px;border-bottom:none}.pt-bi-words{font-size:10px;color:#475569;border-top:1px solid #e2e8f0;padding:10px 0;margin-bottom:12px}.pt-bi-words-ar{direction:rtl;text-align:right;font-family:Cairo,sans-serif}.pt-arabic{font-family:Cairo,Noto Sans Arabic,sans-serif;direction:rtl}.pt-ar-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:3px solid #1e293b;direction:rtl}.pt-ar-header-right{flex:1}.pt-ar-header-left{flex:1;text-align:left}.pt-ar-company-name{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:6px}.pt-ar-info{font-size:10px;color:#64748b;line-height:1.8}.pt-ar-doc-type{font-size:22px;font-weight:800;color:var(--distrix-purple, #4A3DB5);text-align:left;margin-bottom:6px}.pt-ar-doc-number{font-size:14px;font-weight:700;text-align:left;margin-bottom:4px;font-family:JetBrains Mono,Cairo,monospace;direction:ltr}.pt-ar-doc-date,.pt-ar-doc-ref{font-size:11px;text-align:left;color:#475569;line-height:1.6}.pt-ar-client{border:1px solid #e2e8f0;border-radius:6px;padding:12px 16px;margin-bottom:24px;max-width:300px;margin-right:0}.pt-ar-client-label{font-size:10px;font-weight:700;color:#64748b;margin-bottom:4px}.pt-ar-client-name{font-size:14px;font-weight:700;margin-bottom:2px}.pt-ar-client-info{font-size:10px;color:#64748b;line-height:1.6}.pt-ar-table{width:100%;border-collapse:collapse;font-size:10.5px;margin-bottom:20px;direction:rtl}.pt-ar-table th{background:#1e293b;color:#fff;padding:8px 7px;text-align:center;font-size:10px;font-weight:600}.pt-ar-table td{padding:7px;border-bottom:1px solid #f1f5f9;vertical-align:top;text-align:center}.pt-ar-table tbody tr:nth-child(2n) td{background:#f8fafc}.pt-ar-totals{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:16px}.pt-ar-total-row{display:flex;justify-content:space-between;width:320px;padding:6px 14px;font-size:11px;border-bottom:1px solid #f1f5f9;direction:rtl}.pt-ar-total-final{background:#1e293b;color:#fff;font-size:14px;font-weight:800;padding:10px 14px;border-radius:4px;border-bottom:none}.pt-ar-words{font-size:10px;color:#475569;border-top:1px solid #e2e8f0;padding:10px 0;margin-bottom:12px;direction:rtl;text-align:right}@media print{body>*:not(.print-root){display:none!important}.print-root{display:block!important;position:static!important}.pt-page{box-shadow:none}}.ppv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:800;opacity:0;pointer-events:none;transition:opacity .2s}.ppv-overlay--open{opacity:1;pointer-events:all}.ppv-panel{position:fixed;top:0;right:0;bottom:0;width:min(96vw,920px);background:#f1f5f9;z-index:801;transform:translate(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.ppv-panel--open{transform:translate(0)}.ppv-toolbar{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0}.ppv-toolbar-title{font-size:15px;font-weight:700;flex:1}.ppv-template-tabs{display:flex;gap:4px}.ppv-template-tab{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--neutral-light);font-size:12px;cursor:pointer;transition:all .15s}.ppv-template-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.ppv-body{flex:1;overflow-y:auto;padding:24px;display:flex;justify-content:center}.ppv-page-wrap{width:100%;max-width:794px}.ppv-close{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:var(--text-muted);font-size:20px;line-height:1}.ppv-close:hover{background:var(--neutral-light);color:var(--text)}.filter-chip--warning{background:var(--warning-light);color:var(--warning)}.col-resize-handle{position:absolute;top:0;right:-3px;width:7px;height:100%;cursor:col-resize;z-index:2;-webkit-user-select:none;user-select:none;display:flex;align-items:stretch;justify-content:center}.col-resize-handle:after{content:"";width:2px;background:var(--border);border-radius:1px;transition:background .15s,width .15s;align-self:stretch;margin:4px 0}.col-resize-handle:hover:after{background:var(--primary);width:2px}.col-resize-handle--active:after{background:var(--primary)!important}body.col-resizing,body.col-resizing *{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}.cmd-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 1px 4px #0000000f,0 4px 12px #0000000a;margin-bottom:16px}.cmd-bar-top{display:flex;align-items:center;height:48px;padding:0 6px 0 0}.cmd-bar-sep{width:1px;align-self:stretch;background:var(--border);margin:8px 4px;flex-shrink:0}.cmd-bar-search{flex:1;display:flex;align-items:center;gap:8px;padding:0 14px;height:100%;min-width:0}.cmd-bar-search input{flex:1;border:none;outline:none;background:transparent;font-size:13.5px;color:var(--text);min-width:0}.cmd-bar-search input::placeholder{color:var(--text-muted)}.cmd-bar-actions{display:flex;align-items:center;gap:4px;padding:0 6px}.cmd-bar-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius);border:1px solid transparent;background:transparent;font-size:12.5px;font-weight:600;color:var(--text);cursor:pointer;transition:background .14s,border-color .14s,color .14s;white-space:nowrap}.cmd-bar-btn:hover{background:var(--neutral-light);border-color:var(--border)}.cmd-bar-btn--primary{color:var(--distrix-purple);border-color:var(--distrix-purple-100);background:var(--distrix-purple-50)}.cmd-bar-btn--primary:hover{background:var(--distrix-purple-100);border-color:var(--distrix-purple-light)}.cmd-bar-btn--ghost{color:var(--text-muted);font-weight:500}.cmd-bar-btn--ghost:hover{background:var(--neutral-light);color:var(--danger);border-color:#fca5a5}.cmd-bar-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:99px;background:var(--distrix-purple);color:#fff;font-size:10px;font-weight:700;line-height:1}.cmd-bar-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .14s,color .14s;flex-shrink:0}.cmd-bar-icon-btn:hover{background:var(--neutral-light);color:var(--text)}.cmd-bar .vs-trigger{border:none;border-radius:0;background:transparent;height:48px;padding:0 16px;font-size:14px;font-weight:700;color:var(--text);border-right:none}.cmd-bar .vs-trigger:hover{background:var(--neutral-light)}.cmd-bar-chips{display:flex;align-items:center;gap:6px;padding:6px 14px 8px;border-top:1px solid var(--border);background:#f8fafc;flex-wrap:wrap;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.cmd-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px 3px 8px;background:var(--distrix-purple-50);border:1px solid var(--distrix-purple-100);border-radius:99px;font-size:11.5px;font-weight:600;color:var(--distrix-purple);cursor:pointer;transition:border-color .14s,background .14s;white-space:nowrap}.cmd-chip:hover{border-color:var(--distrix-purple-light);background:var(--distrix-purple-100)}.cmd-chip-icon{font-size:10px;opacity:.7}.cmd-chip-close{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:none;background:none;color:var(--distrix-purple-100);font-size:13px;line-height:1;cursor:pointer;padding:0;font-weight:700;transition:color .12s}.cmd-chip-close:hover{color:var(--distrix-purple-dark)}.mf-title-block{display:flex;align-items:flex-start;gap:16px;padding:20px 32px 0;flex-wrap:wrap}.mf-title{font-size:22px;font-weight:800}.mf-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px}.mf-body{padding:20px 32px 40px}.mf-columns{display:grid;grid-template-columns:1fr 320px;gap:20px}.mf-col,.mf-col--side{display:flex;flex-direction:column;gap:0}@media (max-width: 900px){.mf-columns{grid-template-columns:1fr}}.register-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#352d8a,#2a2470);padding:32px 16px}.register-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:680px;box-shadow:0 25px 50px #0006;overflow:hidden}.register-header{padding:28px 32px 20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:center;text-align:center}.register-logo{display:flex;align-items:center;gap:10px;margin-bottom:6px}.register-stepper{display:flex;align-items:center;padding:20px 32px 0;gap:0}.register-step{display:flex;align-items:center;flex:1;position:relative}.register-step-circle{width:30px;height:30px;border-radius:50%;border:2px solid var(--border);background:var(--surface);color:var(--text-muted);display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0;transition:background .2s,border-color .2s,color .2s;z-index:1}.register-step--active .register-step-circle{border-color:var(--primary);background:var(--primary);color:#fff}.register-step--done .register-step-circle{border-color:var(--success);background:var(--success);color:#fff}.register-step-label{font-size:11px;color:var(--text-muted);margin-left:6px;white-space:nowrap}.register-step--active .register-step-label{color:var(--primary);font-weight:600}.register-step--done .register-step-label{color:var(--success)}.register-step-line{flex:1;height:2px;background:var(--border);margin:0 6px}.register-step--done .register-step-line{background:var(--success)}.register-errors{margin:16px 32px 0;background:var(--danger-light);border:1px solid #fca5a5;color:var(--danger);border-radius:var(--radius);padding:10px 14px;font-size:13px;display:flex;flex-direction:column;gap:4px}.register-body{padding:24px 32px;min-height:320px}.register-step-title{font-size:16px;font-weight:700;margin-bottom:18px;color:var(--text)}.register-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px}.form-label{font-size:13px;font-weight:500;color:var(--text)}.form-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:14px;width:100%;transition:border-color .15s,box-shadow .15s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4a3db51a}.register-checkbox-grid{display:flex;flex-direction:column;gap:10px;margin-top:8px}.register-checkbox-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s,background .15s;font-size:13px}.register-checkbox-item:hover{border-color:var(--primary);background:var(--primary-light)}.register-checkbox-item input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px;flex-shrink:0}.register-module-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.register-module-card{display:flex;align-items:center;gap:12px;padding:14px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;background:var(--surface)}.register-module-card:hover,.register-module-card--active{border-color:var(--primary);background:var(--primary-light)}.register-module-check input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}.register-module-icon{font-size:22px;flex-shrink:0}.register-module-info{display:flex;flex-direction:column;gap:2px}.register-module-info strong{font-size:13px;font-weight:600}.register-module-info span{font-size:11px;color:var(--text-muted)}.register-demo-toggle{display:flex;align-items:flex-start;gap:14px;padding:16px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px}.register-summary{background:var(--neutral-light);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.register-summary-title{font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.register-summary-grid{display:flex;flex-direction:column;gap:8px}.register-summary-row{display:flex;gap:12px;font-size:13px;padding-bottom:8px;border-bottom:1px solid var(--border)}.register-summary-row:last-child{border-bottom:none;padding-bottom:0}.register-summary-key{color:var(--text-muted);flex-shrink:0;width:160px}.register-summary-val{font-weight:500;flex:1}.register-nav{display:flex;justify-content:space-between;align-items:center;padding:16px 32px 24px;border-top:1px solid var(--border)}.register-success-grid{display:flex;flex-direction:column;gap:12px;padding:0 16px}.register-success-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--neutral-light);border-radius:var(--radius);gap:12px}.register-success-label{font-size:13px;color:var(--text-muted)}.register-success-value{font-size:14px;font-weight:600;text-align:right}@media (max-width: 640px){.register-form-grid,.register-module-grid{grid-template-columns:1fr}.register-step-label{display:none}.register-card{border-radius:0}.register-body{padding:20px 16px}.register-header{padding:20px 16px 16px}.register-nav{padding:14px 16px 20px}}.panel-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:500;padding:20px}.panel-modal-box{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 20px 40px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:fade-in .15s ease}.panel-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--border)}.panel-modal-title{font-family:var(--font-heading);font-size:16px;font-weight:700}.panel-modal-close{color:var(--text-muted);font-size:16px;padding:4px 8px;border-radius:var(--radius);transition:background .15s}.panel-modal-close:hover{background:var(--neutral-light)}.panel-modal-body{padding:20px}.panel-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}.fv-layout{display:grid;grid-template-columns:220px 1fr;gap:0;min-height:500px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.fv-entities{background:var(--neutral-light);border-right:1px solid var(--border);display:flex;flex-direction:column}.fv-entities-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:14px 14px 8px}.fv-entity-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;transition:background .12s}.fv-entity-btn:hover{background:#e5e7eb}.fv-entity-btn--active{background:var(--primary-light);border-right:3px solid var(--primary)}.fv-entity-icon{font-size:18px;flex-shrink:0}.fv-entity-info{display:flex;flex-direction:column;flex:1;min-width:0}.fv-entity-label{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fv-entity-stats{font-size:11px;color:var(--text-muted);margin-top:1px}.fv-entity-badge{background:var(--primary);color:#fff;border-radius:999px;font-size:11px;font-weight:700;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0}.fv-content{background:#fff;padding:24px;overflow-y:auto}.fv-detail-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.fv-detail-header>div:first-child{display:flex;align-items:center;gap:8px}.fv-detail-icon{font-size:22px}.fv-detail-title{font-size:16px;font-weight:700}.fv-detail-count{margin-left:4px}.fv-fields-list{display:flex;flex-direction:column;gap:8px}.fv-row{border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;background:#fafafa;transition:border-color .15s,background .15s}.fv-row--required{border-left:3px solid var(--primary);background:var(--primary-light)}.fv-row-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.fv-field-label{display:flex;flex-direction:column;gap:1px}.fv-field-name{font-size:13px;font-weight:600;color:var(--text)}.fv-field-key{font-size:11px;color:var(--text-muted);font-family:monospace}.fv-toggle-wrap{flex-shrink:0}.fv-toggle{display:flex;align-items:center;gap:8px;cursor:pointer}.fv-toggle input{display:none}.fv-toggle-slider{position:relative;width:36px;height:20px;border-radius:999px;background:#d1d5db;transition:background .2s;flex-shrink:0}.fv-toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.fv-toggle input:checked+.fv-toggle-slider{background:var(--primary)}.fv-toggle input:checked+.fv-toggle-slider:after{transform:translate(16px)}.fv-toggle-label{font-size:12px;color:var(--text-muted);font-weight:500;min-width:60px}.fv-toggle-label--on{color:var(--primary)}.fv-msg-row{display:flex;align-items:flex-start;gap:8px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}.fv-msg-icon{font-size:14px;flex-shrink:0;margin-top:2px}.fv-msg-display{display:flex;align-items:center;gap:10px;cursor:pointer;flex:1;min-width:0}.fv-msg-display:hover .fv-msg-edit-hint{opacity:1}.fv-msg-text{font-size:12px;color:var(--text);flex:1;min-width:0}.fv-msg-text--default{color:var(--text-muted);font-style:italic}.fv-msg-edit-hint{font-size:11px;color:var(--primary);opacity:0;transition:opacity .15s;white-space:nowrap;flex-shrink:0}.fv-msg-editor{flex:1;display:flex;flex-direction:column;gap:6px}.fv-msg-input{width:100%;padding:6px 10px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius);outline:none;transition:border-color .15s}.fv-msg-input:focus{border-color:var(--primary)}.fv-msg-actions{display:flex;gap:6px;flex-wrap:wrap}.fv-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 10px}.connection-bar{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;gap:12px;padding:8px 16px;font-size:14px;font-weight:500;animation:slideDown .3s ease}.connection-bar--offline{background:var(--danger);color:#fff}.connection-bar--api-down{background:var(--warning);color:#fff}.connection-bar--syncing{background:var(--primary);color:#fff}.connection-bar__icon{font-size:16px;flex-shrink:0}.connection-bar__text{flex:1}.connection-bar__badge{margin-left:auto;background:#ffffff40;padding:2px 10px;border-radius:12px;font-size:12px}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.reconnection-toast{position:fixed;bottom:24px;right:24px;z-index:9999;padding:14px 20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:slideUp .3s ease;max-width:380px}.reconnection-toast--syncing{background:var(--primary);color:#fff}.reconnection-toast--success{background:var(--success);color:#fff}.reconnection-toast__content{display:flex;align-items:flex-start;gap:10px}.reconnection-toast__content p{margin:2px 0 0;font-size:12px;opacity:.9}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.sync-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.02em}.sync-badge--pending{background:var(--warning-light);color:var(--warning)}.sync-badge--modified{background:var(--info-light);color:var(--info)}.sync-badge--conflict,.sync-badge--error{background:var(--danger-light);color:var(--danger)}.sync-badge--synced{background:var(--success-light);color:var(--success)}.sidebar-connection{display:flex;align-items:center;gap:8px;padding:8px 16px;margin:0 8px;border-radius:var(--radius);font-size:12px;font-weight:500}.sidebar-connection--online{color:var(--success);background:var(--success-light)}.sidebar-connection--offline{color:var(--danger);background:var(--danger-light)}.sidebar-connection--api-down{color:var(--warning);background:var(--warning-light)}.sidebar-connection__text{flex:1}.sidebar-connection__badge{background:#fff3;padding:1px 7px;border-radius:10px;font-size:11px;font-weight:700}.sa-login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#2a2470,#4a3db5,#6b5ed4);position:relative;overflow:hidden}.sa-login-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.05;background-image:radial-gradient(circle at 2px 2px,#fff 1px,transparent 0);background-size:28px 28px}.sa-login-box{background:#fff;border-radius:20px;padding:44px 40px;width:420px;box-shadow:0 25px 80px #00000059;position:relative;z-index:1}.sa-login-logo{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;align-items:center}.sa-admin-badge{display:inline-block;background:linear-gradient(135deg,#4a3db5,#6b5ed4);color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:4px 14px;border-radius:20px}.sa-admin-badge--header{background:#ffffff26;font-size:10px;padding:3px 10px}.sa-login-form{display:flex;flex-direction:column;gap:10px}.sa-login-form label{font-size:13px;font-weight:600;color:#374151;margin-top:4px}.sa-login-form input{border:1.5px solid #e2e8f0;border-radius:10px;padding:11px 14px;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}.sa-login-form input:focus{border-color:#4a3db5;box-shadow:0 0 0 3px #4a3db514}.sa-btn-primary{margin-top:10px;padding:12px;background:#4a3db5;color:#fff;border:none;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:background .15s,transform .1s}.sa-btn-primary:hover:not(:disabled){background:#352d8a;transform:translateY(-1px)}.sa-btn-primary:active:not(:disabled){transform:translateY(0)}.sa-btn-primary:disabled{opacity:.6;cursor:not-allowed}.sa-btn-link{background:none;border:none;color:#4a3db5;font-size:13px;cursor:pointer;margin-top:16px;width:100%;text-align:center}.sa-btn-link:hover{text-decoration:underline}.sa-error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;padding:10px 12px;border-radius:8px;font-size:13px}.sa-success-msg{background:#f0fdf4;border:1px solid #86efac;color:#166534;padding:10px 12px;border-radius:8px;font-size:13px}.sa-portal{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column}.sa-header{background:linear-gradient(135deg,#2a2470,#4a3db5);color:#fff;padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 12px #4a3db54d}.sa-header-left{display:flex;align-items:center;gap:12px}.sa-header-title{font-size:17px;font-weight:700}.sa-header-sub{font-size:12px;color:#93c5fd;display:block}.sa-header-right{display:flex;align-items:center;gap:14px}.sa-header-user{font-size:14px;color:#cbd5e1}.sa-main{padding:24px 28px;flex:1}.sa-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.sa-stat{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;gap:4px}.sa-stat span:last-child{font-size:13px;color:#64748b}.sa-stat-n{font-size:28px;font-weight:700;color:#0f172a}.sa-stat-green .sa-stat-n{color:#16a34a}.sa-stat-red .sa-stat-n{color:#dc2626}.sa-stat-blue .sa-stat-n{color:#4a3db5}.sa-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.sa-search{flex:1;max-width:320px;padding:9px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;outline:none}.sa-search:focus{border-color:#4a3db5}.sa-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.sa-table{width:100%;border-collapse:collapse;font-size:13px}.sa-table th{padding:12px 16px;background:#f8fafc;color:#64748b;font-weight:600;text-align:left;border-bottom:1px solid #e2e8f0}.sa-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.sa-table tr:last-child td{border-bottom:none}.sa-row-inactive td{opacity:.55}.sa-code{background:#f1f5f9;padding:2px 8px;border-radius:4px;font-family:monospace;color:#352d8a;font-size:12px}.sa-tenant-name{font-weight:600;color:#0f172a}.sa-tenant-sub{font-size:11px;color:#94a3b8;margin-top:2px}.sa-badge{background:#e2e8f0;color:#475569;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.sa-badge-code{background:#edeafb;color:#4a3db5}.sa-modules{display:flex;gap:4px;flex-wrap:wrap}.sa-mod-chip{background:#edeafb;color:#6b5ed4;padding:2px 7px;border-radius:10px;font-size:11px}.sa-center{text-align:center}.sa-status-pill{font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}.sa-pill-active{background:#dcfce7;color:#16a34a}.sa-pill-inactive{background:#fee2e2;color:#dc2626}.sa-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}.sa-active.sa-status-dot{background:#16a34a}.sa-inactive.sa-status-dot{background:#dc2626}.sa-actions{display:flex;gap:6px;flex-wrap:wrap}.sa-btn-sm{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.sa-btn-sm:disabled{opacity:.5;cursor:not-allowed}.sa-btn-outline{background:transparent;border:1px solid #cbd5e1;color:#475569}.sa-btn-outline:hover:not(:disabled){background:#f1f5f9}.sa-btn-danger{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}.sa-btn-danger:hover:not(:disabled){background:#fecaca}.sa-btn-warning{background:#fef3c7;color:#d97706;border:1px solid #fde68a}.sa-btn-warning:hover:not(:disabled){background:#fde68a}.sa-btn-success{background:#dcfce7;color:#16a34a;border:1px solid #86efac}.sa-btn-success:hover:not(:disabled){background:#bbf7d0}.sa-btn-export{background:#eff6ff;color:#4a3db5;border:1px solid #bfdbfe}.sa-btn-export:hover:not(:disabled){background:#dbeafe}.sa-btn-new-tenant{display:inline-flex;align-items:center;background:#4a3db5;color:#fff;border:none;text-decoration:none}.sa-btn-new-tenant:hover{background:#352d8a;color:#fff}.sa-role-badge{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.sa-role-admin{background:#fef3c7;color:#d97706}.sa-role-user{background:#edeafb;color:#4a3db5}.sa-role-readonly{background:#f1f5f9;color:#64748b}.sa-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.sa-modal{background:#fff;border-radius:16px;width:100%;max-width:860px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.sa-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:1}.sa-modal-header h2{margin:0;font-size:18px;color:#0f172a}.sa-close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#64748b;line-height:1;padding:4px 8px;border-radius:6px}.sa-close-btn:hover{background:#f1f5f9}.sa-modal .sa-table{font-size:13px}.sa-modal .sa-table th,.sa-modal .sa-table td{padding:10px 16px}.sa-sub-modal{border-top:1px solid #e2e8f0;padding:20px 24px;background:#f8fafc}.sa-sub-modal h3{margin:0 0 12px;font-size:15px;color:#0f172a}.sa-sub-modal input{width:100%;padding:9px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;outline:none;margin-bottom:12px;box-sizing:border-box}.sa-sub-modal input:focus{border-color:#4a3db5}.sa-sub-modal-actions{display:flex;gap:8px;justify-content:flex-end}.sa-modal-sm{max-width:500px}.sa-reset-warn{padding:28px 28px 20px;text-align:center}.sa-reset-warn-icon{font-size:40px;margin-bottom:12px}.sa-reset-warn-title{font-size:17px;font-weight:700;color:#dc2626;margin:0 0 16px}.sa-reset-warn-list{text-align:left;list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:8px}.sa-reset-warn-list li{font-size:13px;color:#374151;padding:8px 12px;background:#fef2f2;border-left:3px solid #fca5a5;border-radius:0 6px 6px 0}.sa-reset-warn-actions{display:flex;gap:10px;justify-content:center}.sa-reset-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:6px}.sa-reset-form label{font-size:12px;font-weight:600;color:#374151;margin-top:6px}.sa-reset-form input{padding:9px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;outline:none}.sa-reset-form input:focus{border-color:#4a3db5}.sa-reset-form-label{font-size:13px;font-weight:700;color:#0f172a;margin:0 0 4px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.sa-reset-confirm-block{margin-top:10px;padding:12px;background:#fef9c3;border:1px solid #fde047;border-radius:8px;display:flex;flex-direction:column;gap:6px}.sa-reset-confirm-block label{color:#854d0e}.sa-reset-confirm-block input{border-color:#fde047;font-family:monospace}.sa-toast{position:fixed;bottom:24px;right:24px;z-index:2000;background:#0f172a;color:#fff;padding:12px 20px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:0 4px 20px #0000004d;animation:sa-fade-in .2s ease}@keyframes sa-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.sa-loading{padding:40px;text-align:center;color:#64748b;font-size:14px}
