*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}:root{--brand-cyan:#00f0f0;--brand-azure:#2b72ed;--brand-ink:#01081c;--brand-gradient:linear-gradient(135deg, #00f0f0 0%, #2b72ed 100%);--azure-700:#1458c7;--azure-500:#2b72ed;--azure-300:#5c97f2;--azure-200:#8db7f6;--azure-100:#c4d9fb;--azure-50:#eaf1fe;--fg-1:#0a0a0a;--fg-2:#1f2937;--fg-3:#475467;--fg-4:#98a2b3;--fg-inverse:#fff;--bg-1:#fff;--bg-2:#fafafa;--bg-3:#f2f4f7;--bg-4:#e4e6eb;--valid-500:#10c06a;--valid-100:#e6f9ef;--error-500:#ff2d2d;--error-100:#ffeaea;--warning-500:#f59e0b;--warning-100:#fef3c7;--other-500:#7c3aed;--other-100:#ede9fe;--border-1:#10182814;--border-2:#1018280d;--shadow-xs:0 1px 2px #1018280f;--shadow-sm:0 2px 8px #1018280f;--shadow-md:0 4px 16px #10182814;--shadow-lg:0 12px 32px #1018281f;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-pill:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--font-body:"Poppins", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--ease:cubic-bezier(.22, 1, .36, 1);--dur-fast:.15s;--dur-normal:.25s;--sidebar-width:240px;--header-height:64px;--content-max:1200px}body{font-family:var(--font-body);color:var(--fg-2);background:var(--bg-2);font-size:14px;line-height:1.5}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-1);border-right:1px solid var(--border-1);z-index:100;flex-direction:column;min-height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-logo{padding:var(--space-5) var(--space-5) var(--space-4);align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border-1);text-decoration:none;display:flex}.sidebar-logo img{object-fit:contain;flex-shrink:0;width:28px;height:28px}.sidebar-logo-text{color:var(--fg-1);letter-spacing:-.02em;font-size:15px;font-weight:700}.sidebar-nav{padding:var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-section-label{color:var(--fg-4);letter-spacing:.08em;text-transform:uppercase;padding:var(--space-3) var(--space-3) var(--space-2);margin-top:var(--space-2);font-size:11px;font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius-sm);color:var(--fg-3);cursor:pointer;transition:background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);text-align:left;background:0 0;border:none;width:100%;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--bg-3);color:var(--fg-1)}.nav-item.active{background:var(--azure-50);color:var(--brand-azure);font-weight:600}.nav-item svg{opacity:.65;flex-shrink:0;width:18px;height:18px}.nav-item.active svg{opacity:1}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-1);align-items:center;gap:var(--space-3);display:flex}.sidebar-avatar{border-radius:var(--radius-pill);background:var(--brand-gradient);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.sidebar-user-name{color:var(--fg-1);font-size:13px;font-weight:600;line-height:1.3}.sidebar-user-role{color:var(--fg-4);font-size:11px;line-height:1.3}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.topbar{height:var(--header-height);background:var(--bg-1);border-bottom:1px solid var(--border-1);padding:0 var(--space-6);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-title{color:var(--fg-1);letter-spacing:-.02em;font-size:16px;font-weight:700}.topbar-actions{align-items:center;gap:var(--space-3);display:flex}.page-content{padding:var(--space-6);flex:1;overflow-y:auto}.page{padding:var(--space-6);flex:1}.page-header{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.page-title{color:var(--fg-1);letter-spacing:-.03em;font-size:22px;font-weight:700}.card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.card-hover{transition:box-shadow var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);cursor:pointer}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--fg-1);letter-spacing:-.01em;font-size:15px;font-weight:600}.card-subtitle{color:var(--fg-4);margin-top:2px;font-size:12px}.metric-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.metric-label{color:var(--fg-4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2);font-size:11px;font-weight:600}.metric-value{color:var(--fg-1);letter-spacing:-.03em;font-size:28px;font-weight:700;line-height:1}.metric-breakdown{margin-top:var(--space-3);gap:var(--space-1);flex-direction:column;display:flex}.metric-breakdown-item{color:var(--fg-3);justify-content:space-between;font-size:12px;display:flex}.btn,button.btn{align-items:center;gap:var(--space-2);padding:8px var(--space-4);border-radius:var(--radius-sm);font-family:var(--font-body);cursor:pointer;transition:all var(--dur-fast) var(--ease);white-space:nowrap;border:none;font-size:14px;font-weight:600;line-height:1.4;text-decoration:none;display:inline-flex}.btn--primary,.btn-primary{background:var(--brand-azure);color:#fff}.btn--primary:hover,.btn-primary:hover{background:var(--azure-700)}.btn--gradient,.btn-gradient{background:var(--brand-gradient);color:#fff}.btn--gradient:hover,.btn-gradient:hover{opacity:.9}.btn--secondary,.btn-secondary{background:var(--bg-3);color:var(--fg-2);border:1px solid var(--border-1)}.btn--secondary:hover,.btn-secondary:hover{background:var(--bg-4)}.btn--ghost,.btn-ghost{color:var(--fg-3);border:1px solid var(--border-1);background:0 0}.btn--ghost:hover,.btn-ghost:hover{background:var(--bg-3);color:var(--fg-1)}.btn--danger,.btn-danger{background:var(--error-100);color:var(--error-500)}.btn--danger:hover,.btn-danger:hover{background:var(--error-500);color:#fff}.btn--sm,.btn-sm{padding:6px 12px;font-size:13px}.btn--icon,.btn-icon{border-radius:var(--radius-sm);padding:8px}.btn:disabled,button.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.badge{border-radius:var(--radius-pill);align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-green{background:var(--valid-100);color:#0a7a43}.badge-red{background:var(--error-100);color:var(--error-500)}.badge-amber{background:var(--warning-100);color:#92600a}.badge-blue{background:var(--azure-50);color:var(--brand-azure)}.badge-gray{background:var(--bg-3);color:var(--fg-3);border:1px solid var(--border-1)}.badge-purple{background:var(--other-100);color:var(--other-500)}.tabs{border-bottom:1px solid var(--border-1);margin-bottom:var(--space-5);gap:0;display:flex}.tab{padding:10px var(--space-5);color:var(--fg-3);cursor:pointer;transition:all var(--dur-fast) var(--ease);font-size:14px;font-weight:500;font-family:var(--font-body);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tab:hover{color:var(--fg-1)}.tab.active{color:var(--brand-azure);border-bottom-color:var(--brand-azure);font-weight:600}.form-grid{gap:var(--space-4);flex-direction:column;display:flex}.form-grid--2col{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-row,.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{color:var(--fg-2);font-size:13px;font-weight:600}.form-label-required:after{content:" *";color:var(--error-500)}.form-input,input[type=text],input[type=number],input[type=email],input[type=date],input[type=password],select,textarea{width:100%;padding:10px var(--space-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--fg-1);background:var(--bg-1);transition:border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);outline:none;font-size:14px}.form-input:focus,input[type=text]:focus,input[type=number]:focus,input[type=email]:focus,input[type=date]:focus,input[type=password]:focus,select:focus,textarea:focus{border-color:var(--brand-azure);box-shadow:0 0 0 3px var(--azure-50)}.form-input::placeholder{color:var(--fg-4)}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2398A2B3' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}textarea{resize:vertical;min-height:80px}.form-error{color:var(--error-500);font-size:12px}.form-hint{color:var(--fg-4);font-size:12px}.table-container{border:1px solid var(--border-1);border-radius:var(--radius-lg);background:var(--bg-1);overflow:hidden}table{border-collapse:collapse;width:100%}thead{background:var(--bg-2)}th{padding:10px var(--space-4);text-align:left;color:var(--fg-4);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-1);white-space:nowrap;font-size:11px;font-weight:600}td{padding:14px var(--space-4);color:var(--fg-2);border-bottom:1px solid var(--border-2);font-size:14px}tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg-2)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-5);background:#00000040;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex;overflow:hidden}.modal--wide{max-width:680px}.modal>form{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-1);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 28px 16px;display:flex}.modal-title{color:var(--fg-1);font-size:16px;font-weight:700}.modal-body{gap:var(--space-4);scrollbar-width:thin;scrollbar-color:var(--bg-4) transparent;flex-direction:column;flex:1;padding:24px 28px;display:flex;overflow-y:auto}.modal-body::-webkit-scrollbar{width:4px}.modal-body::-webkit-scrollbar-track{background:0 0}.modal-body::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:var(--radius-pill)}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--fg-4)}.modal-footer{border-top:1px solid var(--border-1);justify-content:flex-end;gap:var(--space-3);flex-shrink:0;padding:16px 28px 24px;display:flex}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--fg-3);cursor:pointer;transition:background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-3);color:var(--fg-1)}.modal-close:disabled{opacity:.4;cursor:not-allowed}.toast{bottom:var(--space-5);right:var(--space-5);align-items:center;gap:var(--space-3);padding:12px var(--space-4);background:var(--fg-1);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:slideIn var(--dur-normal) var(--ease);z-index:2000;max-width:360px;font-size:14px;font-weight:500;display:flex;position:fixed}.toast--success{background:var(--valid-500)}.toast--error{background:var(--error-500)}.toast--warning{background:var(--warning-500)}@keyframes slideIn{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);background:var(--brand-ink);color:#fff;border-radius:var(--radius-xs);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--dur-fast) var(--ease);z-index:500;padding:4px 10px;font-size:12px;font-weight:500;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1;transition-delay:.3s}.info-tip{vertical-align:middle;cursor:help;align-items:center;display:inline-flex;position:relative}.info-tip__icon{background:var(--bg-3);border:1px solid var(--border-1);width:16px;height:16px;color:var(--fg-4);transition:background var(--dur-fast), color var(--dur-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-style:normal;font-weight:700;line-height:1;display:inline-flex}.info-tip:hover .info-tip__icon{background:var(--azure-50);color:var(--brand-azure);border-color:var(--azure-100)}.info-tip__tooltip{background:var(--brand-ink);color:#fff;border-radius:var(--radius-sm);white-space:normal;z-index:500;min-width:180px;max-width:260px;box-shadow:var(--shadow-md);pointer-events:none;padding:6px 10px;font-size:12px;font-weight:400;line-height:1.4;display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.info-tip:hover .info-tip__tooltip{display:block}.state-empty,.empty-state{padding:var(--space-8) var(--space-5);text-align:center;justify-content:center;align-items:center;gap:var(--space-3);color:var(--fg-4);flex-direction:column;display:flex}.state-empty--inline{padding:var(--space-6) var(--space-5)}.state-empty p,.empty-state-desc{color:var(--fg-4);max-width:320px;font-size:14px}.empty-state-title{color:var(--fg-1);font-size:16px;font-weight:600}.state-spinner{border:2px solid var(--bg-4);border-top-color:var(--brand-azure);vertical-align:middle;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg, var(--bg-3) 25%, var(--bg-4) 50%, var(--bg-3) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.grid-2{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.toggle-wrap{align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.toggle{background:var(--bg-4);border-radius:var(--radius-pill);width:44px;height:24px;transition:background var(--dur-fast) var(--ease);cursor:pointer;border:none;flex-shrink:0;padding:0;position:relative}.toggle.on{background:var(--brand-azure)}.toggle:after{content:"";width:18px;height:18px;transition:transform var(--dur-fast) var(--ease);box-shadow:var(--shadow-xs);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle.on:after{transform:translate(20px)}.period-selector{gap:var(--space-2);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.period-btn{border-radius:var(--radius-pill);cursor:pointer;border:1px solid var(--border-1);background:var(--bg-1);color:var(--fg-3);transition:all var(--dur-fast) var(--ease);font-size:13px;font-weight:500;font-family:var(--font-body);padding:6px 14px}.period-btn:hover{background:var(--bg-3);color:var(--fg-1)}.period-btn.active{background:var(--azure-50);border-color:var(--brand-azure);color:var(--brand-azure);font-weight:600}.notif-bell-wrapper{position:relative}.notif-bell-btn{border:1px solid var(--border-1);border-radius:var(--radius-sm);background:var(--bg-1);cursor:pointer;width:38px;height:38px;transition:background var(--dur-fast) var(--ease);color:var(--fg-3);justify-content:center;align-items:center;display:flex;position:relative}.notif-bell-btn:hover{background:var(--bg-3)}.notif-bell-icon{font-size:17px;line-height:1}.notif-badge{border-radius:var(--radius-pill);background:var(--error-500);color:#fff;text-align:center;pointer-events:none;border:2px solid #fff;min-width:17px;height:17px;padding:0 4px;font-size:10px;font-weight:700;line-height:17px;position:absolute;top:-5px;right:-5px}@keyframes notif-pulse{0%{box-shadow:0 0 #ff2d2d80}70%{box-shadow:0 0 0 6px #ff2d2d00}to{box-shadow:0 0 #ff2d2d00}}.notif-badge--pulse{animation:1.8s ease-out infinite notif-pulse}.notif-panel{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);width:360px;max-height:480px;box-shadow:var(--shadow-lg);z-index:200;flex-direction:column;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notif-panel-header{padding:14px var(--space-4) 10px;border-bottom:1px solid var(--border-1);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.notif-panel-title{color:var(--fg-1);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.notif-panel-count{color:var(--fg-4);background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-pill);padding:1px 7px;font-size:11px;font-weight:500}.notif-read-all-btn{color:var(--brand-azure);cursor:pointer;border-radius:var(--radius-xs);transition:background var(--dur-fast);font-size:12px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;padding:4px 8px}.notif-read-all-btn:hover:not(:disabled){background:var(--azure-50)}.notif-read-all-btn:disabled{opacity:.4;cursor:not-allowed}.notif-list{flex:1;overflow-y:auto}.notif-empty{color:var(--fg-4);flex-direction:column;align-items:center;gap:8px;padding:40px 20px;font-size:13px;display:flex}.notif-empty-icon{opacity:.35;font-size:28px}.notif-item{padding:12px var(--space-4);border-bottom:1px solid var(--border-2);cursor:pointer;transition:background var(--dur-fast);align-items:flex-start;gap:10px;display:flex;position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-2)}.notif-item--unread{background:var(--azure-50)}.notif-item--unread:hover{background:#dce9fd}.notif-item--unread:before{content:"";background:var(--brand-azure);border-radius:50%;width:5px;height:5px;position:absolute;top:50%;left:6px;transform:translateY(-50%)}.notif-item-icon{flex-shrink:0;margin-top:1px;font-size:18px}.notif-item-body{flex:1;min-width:0}.notif-item-title{color:var(--fg-1);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;line-height:1.35;overflow:hidden}.notif-item-desc{color:var(--fg-3);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.notif-item-meta{align-items:center;gap:8px;margin-top:4px;display:flex}.notif-item-time{color:var(--fg-4);font-size:11px}.notif-item-partner{color:var(--fg-4);background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-pill);padding:1px 6px;font-size:11px}.notif-item-delete{width:24px;height:24px;color:var(--fg-4);cursor:pointer;transition:background var(--dur-fast), color var(--dur-fast);opacity:0;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:11px;display:flex}.notif-item:hover .notif-item-delete{opacity:1}.notif-item-delete:hover:not(:disabled){background:var(--error-100);color:var(--error-500)}.notif-mgmt-topbar{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.notif-filter-bar{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.notif-filter-group{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);gap:2px;padding:3px;display:flex}.notif-filter-btn{border-radius:var(--radius-xs);color:var(--fg-4);cursor:pointer;transition:all var(--dur-fast) var(--ease);white-space:nowrap;font-size:12px;font-weight:500;font-family:var(--font-body);background:0 0;border:none;padding:5px 12px}.notif-filter-btn:hover:not(.notif-filter-btn--active){color:var(--fg-1)}.notif-filter-btn--active{background:var(--bg-1);color:var(--fg-1);box-shadow:var(--shadow-xs)}.notif-rules-list{flex-direction:column;gap:6px;display:flex}.notif-rule-card{padding:13px var(--space-4);background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-md);transition:border-color var(--dur-fast), box-shadow var(--dur-fast);align-items:center;gap:12px;display:flex}.notif-rule-card:hover{border-color:var(--azure-200);box-shadow:var(--shadow-xs)}.notif-rule-card-icon{flex-shrink:0;font-size:20px}.notif-rule-card-body{flex:1;min-width:0}.notif-rule-card-title{color:var(--fg-1);align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.notif-rule-card-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:5px;display:flex}.notif-rule-badge{border-radius:var(--radius-pill);white-space:nowrap;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.notif-rule-badge--timing{background:var(--bg-3);border:1px solid var(--border-1);color:var(--fg-3)}.notif-rule-badge--channel{background:var(--azure-50);border:1px solid var(--azure-100);color:var(--brand-azure)}.notif-rule-badge--person{background:var(--valid-100);color:#0a7a43;border:1px solid #b3f0d4}.notif-rule-badge--filter{background:var(--other-100);color:var(--other-500);border:1px solid #d4c5fd}.notif-rule-delete{width:28px;height:28px;color:var(--fg-4);cursor:pointer;transition:background var(--dur-fast), color var(--dur-fast);opacity:0;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.notif-rule-card:hover .notif-rule-delete{opacity:1}.notif-rule-delete:hover:not(:disabled){background:var(--error-100);color:var(--error-500)}.notif-builder-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;padding:var(--space-5);background:#00000040;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.notif-builder-modal{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-xl);width:min(560px,100%);max-height:88vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.notif-builder-header{border-bottom:1px solid var(--border-1);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 28px 16px;display:flex}.notif-builder-body{scrollbar-width:thin;scrollbar-color:var(--bg-4) transparent;flex:1;min-height:0;padding:24px 28px;overflow-y:auto}.notif-builder-body::-webkit-scrollbar{width:4px}.notif-builder-body::-webkit-scrollbar-track{background:0 0}.notif-builder-body::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:var(--radius-pill)}.notif-builder-body::-webkit-scrollbar-thumb:hover{background:var(--fg-4)}.notif-builder-actions{border-top:1px solid var(--border-1);flex-shrink:0;padding:16px 28px 24px}.notif-builder-title{color:var(--fg-1);margin:0;font-size:17px;font-weight:700}.notif-builder-close{border:1px solid var(--border-1);background:var(--bg-2);width:30px;height:30px;color:var(--fg-3);cursor:pointer;transition:all var(--dur-fast);border-radius:50%;justify-content:center;align-items:center;font-size:13px;display:flex}.notif-builder-close:hover{background:var(--error-100);color:var(--error-500);border-color:#0000}.notif-builder-section{margin-bottom:var(--space-5)}.notif-builder-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-4);align-items:center;gap:6px;margin-bottom:10px;font-size:11px;font-weight:700;display:flex}.notif-builder-section-hint{text-transform:none;letter-spacing:0;color:var(--fg-4);font-size:10px;font-weight:400}.notif-trigger-pills{flex-wrap:wrap;gap:8px;display:flex}.notif-trigger-pill{border:1px solid var(--border-1);border-radius:var(--radius-pill);background:var(--bg-1);color:var(--fg-3);font-size:13px;font-family:var(--font-body);cursor:pointer;transition:all var(--dur-fast) var(--ease);align-items:center;gap:6px;padding:8px 14px;display:inline-flex}.notif-trigger-pill:hover:not(.notif-trigger-pill--active){border-color:var(--azure-200);color:var(--fg-1);background:var(--bg-2)}.notif-trigger-pill--active{background:var(--azure-50);border-color:var(--brand-azure);color:var(--brand-azure);font-weight:600}.notif-timing-row{color:var(--fg-2);flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;display:flex}.notif-timing-input{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-sm);width:64px;color:var(--fg-1);font-size:14px;font-family:var(--font-body);text-align:center;outline:none;padding:6px 8px}.notif-timing-input:focus{border-color:var(--brand-azure);box-shadow:0 0 0 3px var(--azure-50)}.notif-timing-context{color:var(--fg-4);font-size:13px;font-style:italic}.notif-check-group{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.notif-check-group--wrap{gap:10px 20px}.notif-check-item{color:var(--fg-3);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--dur-fast);align-items:center;gap:8px;font-size:14px;display:flex}.notif-check-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--brand-azure);cursor:pointer;flex-shrink:0}.notif-check-item--checked{color:var(--fg-1)}.notif-check-all-btn{color:var(--brand-azure);cursor:pointer;border-radius:var(--radius-xs);transition:background var(--dur-fast);font-size:12px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;padding:4px 8px}.notif-check-all-btn:hover{background:var(--azure-50)}.notif-builder-actions{justify-content:flex-end;gap:var(--space-3);display:flex}.app-right{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.app-topbar{padding:0 var(--space-6);height:var(--header-height);background:var(--bg-1);border-bottom:1px solid var(--border-1);flex-shrink:0;justify-content:flex-end;align-items:center;display:flex}.app-main{flex:1;overflow-y:auto}.settings-section{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm)}.settings-section-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.settings-section-title{color:var(--fg-1);align-items:center;gap:var(--space-2);font-size:15px;font-weight:700;display:flex}.settings-section-sub{color:var(--fg-4);margin-top:3px;font-size:13px}.settings-loading{align-items:center;gap:var(--space-3);padding:var(--space-5);color:var(--fg-4);font-size:14px;display:flex}.split-row{padding:12px var(--space-4);border:1px solid var(--border-2);border-radius:var(--radius-sm);background:var(--bg-2);justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.split-row--active{background:var(--azure-50);border-color:var(--azure-100)}.split-row-period{color:var(--fg-2);margin-bottom:2px;font-size:13px}.split-row-pcts{color:var(--fg-4);font-size:12px}.bonus-grid{gap:var(--space-4);margin-bottom:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.bonus-field{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius-md);padding:var(--space-4)}.bonus-field-label{color:var(--fg-3);margin-bottom:4px;font-size:12px;font-weight:600}.bonus-field-desc{color:var(--fg-4);margin-bottom:var(--space-3);font-size:11px;line-height:1.4}.bonus-field-input{align-items:center;gap:6px;display:flex}.bonus-field-input input{max-width:70px}.bonus-field-input span{color:var(--fg-3);font-size:14px}.bonus-valid-from{color:var(--fg-4);margin-bottom:var(--space-4);font-size:12px}.bonus-actions{gap:var(--space-3);display:flex}.clients-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.client-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow var(--dur-fast), transform var(--dur-fast), border-color var(--dur-fast)}.client-card:hover{box-shadow:var(--shadow-md);border-color:var(--azure-100);transform:translateY(-2px)}.client-name{color:var(--fg-1);margin-bottom:4px;font-size:16px;font-weight:700}.client-company{color:var(--fg-4);margin-bottom:var(--space-4);font-size:13px}.client-meta{flex-direction:column;gap:6px;display:flex}.client-meta-row{color:var(--fg-3);justify-content:space-between;font-size:13px;display:flex}.client-meta-label{color:var(--fg-4);font-size:12px}.client-meta-value{color:var(--fg-2);font-weight:500}.contract-list{gap:var(--space-3);flex-direction:column;display:flex}.contract-item{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:all var(--dur-fast)}.contract-item:hover{box-shadow:var(--shadow-sm);border-color:var(--azure-100)}.contract-item-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.contract-label{color:var(--fg-1);font-size:15px;font-weight:600}.contract-meta-row{gap:var(--space-4);color:var(--fg-4);flex-wrap:wrap;font-size:12px;display:flex}.split-preview{margin-top:var(--space-3);flex-direction:column;gap:6px;display:flex}.split-preview-bar{border-radius:var(--radius-pill);background:var(--bg-4);height:6px;display:flex;overflow:hidden}.split-preview-bar-fill{background:var(--brand-gradient);height:100%;transition:width var(--dur-normal) var(--ease)}.split-preview-labels{color:var(--fg-3);justify-content:space-between;font-size:12px;display:flex}.economics-grid{gap:var(--space-4);margin-bottom:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}.tx-list{flex-direction:column;gap:6px;display:flex}.tx-card{align-items:center;gap:var(--space-3);padding:12px var(--space-4);background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-md);transition:box-shadow var(--dur-fast);display:flex}.tx-card:hover{box-shadow:var(--shadow-sm)}.tx-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.tx-icon--income{background:var(--valid-100)}.tx-icon--expense{background:var(--error-100)}.tx-icon--transfer{background:var(--azure-50)}.tx-icon--other{background:var(--other-100)}.tx-body{flex:1;min-width:0}.tx-description{color:var(--fg-1);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.tx-meta{color:var(--fg-4);margin-top:2px;font-size:12px}.tx-category{color:var(--fg-4);margin-top:2px;font-size:11px;font-weight:500}.tx-other-category{color:var(--other-500);font-size:12px;font-weight:500}.tx-amount{white-space:nowrap;font-size:15px;font-weight:700}.tx-amount--income{color:var(--valid-500)}.tx-amount--expense{color:var(--error-500)}.tx-amount--transfer{color:var(--brand-azure)}.tx-amount--other{color:var(--other-500)}.tx-actions{flex-shrink:0;gap:4px;display:flex}.tx-action-btn{border-radius:var(--radius-xs);width:28px;height:28px;color:var(--fg-4);cursor:pointer;transition:all var(--dur-fast);opacity:0;background:0 0;border:none;justify-content:center;align-items:center;font-size:13px;display:flex}.tx-card:hover .tx-action-btn{opacity:1}.tx-action-btn:hover{background:var(--bg-3);color:var(--fg-1)}.tx-action-btn--delete:hover{background:var(--error-100);color:var(--error-500)}.period-cards{gap:var(--space-3);flex-direction:column;display:flex}.period-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-md);padding:var(--space-4)}.period-card__title{color:var(--fg-1);margin-bottom:var(--space-3);font-size:14px;font-weight:600}.period-card__row{color:var(--fg-3);border-bottom:1px solid var(--border-2);justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.period-card__row:last-child{border-bottom:none}.period-card__row-label{color:var(--fg-4)}.period-card__row-val{color:var(--fg-1);font-weight:600}.period-card__row-val--green{color:var(--valid-500)}.period-card__row-val--red{color:var(--error-500)}.period-card__row-val--muted{color:var(--fg-4);font-weight:400}.period-card__row-sub{color:var(--fg-4);margin-top:2px;font-size:11px}.period-card__row-sub--muted{color:var(--fg-4);font-style:italic}.period-card__other-hint{color:var(--other-500);margin-top:2px;font-size:11px}.balance-section{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);margin-bottom:var(--space-5);overflow:hidden}.balance-section-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-1);background:var(--bg-2);justify-content:space-between;align-items:center;display:flex}.balance-title{color:var(--fg-1);font-size:15px;font-weight:700}.balance-table-row{gap:var(--space-4);padding:12px var(--space-5);border-bottom:1px solid var(--border-2);color:var(--fg-2);font-size:13px;display:grid}.balance-table-row:last-child{border-bottom:none}.balance-table-row--header{background:var(--bg-2);color:var(--fg-4);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.balance-table-row--total{background:var(--bg-2);font-weight:700}.tx-form-tabs{background:var(--bg-3);border-radius:var(--radius-sm);margin-bottom:var(--space-4);gap:2px;padding:3px;display:flex}.tx-form-tab{border-radius:var(--radius-xs);color:var(--fg-3);cursor:pointer;transition:all var(--dur-fast);font-size:13px;font-weight:500;font-family:var(--font-body);text-align:center;background:0 0;border:none;flex:1;padding:6px}.tx-form-tab--active{background:var(--bg-1);color:var(--fg-1);box-shadow:var(--shadow-xs);font-weight:600}.payment-toggle{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);gap:2px;width:fit-content;padding:3px;display:flex}.payment-toggle__btn{border-radius:var(--radius-xs);color:var(--fg-3);cursor:pointer;transition:all var(--dur-fast);font-size:13px;font-weight:500;font-family:var(--font-body);background:0 0;border:none;padding:6px 20px}.payment-toggle__btn:hover:not(.payment-toggle__btn--active){color:var(--fg-1)}.payment-toggle__btn--active{background:var(--bg-1);color:var(--fg-1);box-shadow:var(--shadow-xs);font-weight:600}.cash-toggle-row{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;width:fit-content;display:flex}.cash-toggle-text{color:var(--fg-3);font-size:13px}.cash-toggle-switch{border-radius:var(--radius-pill);background:var(--bg-4);width:44px;height:24px;transition:background var(--dur-fast);flex-shrink:0;position:relative}.cash-toggle-switch--on{background:var(--brand-azure)}.cash-toggle-thumb{width:18px;height:18px;box-shadow:var(--shadow-xs);transition:transform var(--dur-fast);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.cash-toggle-switch--on .cash-toggle-thumb{transform:translate(20px)}.income-billing-partner{color:var(--fg-4);margin-top:6px;font-size:13px;display:block}.tx-other-hint{background:var(--other-100);border-radius:var(--radius-sm);color:var(--other-500);border:1px solid #d4c5fd;margin-top:4px;padding:8px 12px;font-size:12px}.invoice-list{flex-direction:column;gap:6px;display:flex}.invoice-item{justify-content:space-between;align-items:center;gap:var(--space-3);padding:12px var(--space-4);background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-md);transition:box-shadow var(--dur-fast);font-size:13px;display:flex}.invoice-item:hover{box-shadow:var(--shadow-sm)}.invoice-number{color:var(--fg-1);font-weight:600}.invoice-date{color:var(--fg-4)}.invoice-amount{color:var(--fg-1);font-weight:700}.payment-row{padding:8px var(--space-4);background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--fg-3);justify-content:space-between;align-items:center;margin-top:4px;font-size:12px;display:flex}.payment-row--paid{background:var(--valid-100);border-color:#b3f0d4}.payment-row--overdue{background:var(--error-100);border-color:#ffc5c5}.contract-detail-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-5);display:flex}.contract-detail-title{color:var(--fg-1);font-size:20px;font-weight:700}.contract-detail-meta{color:var(--fg-4);margin-top:4px;font-size:13px}.contract-detail-grid{gap:var(--space-5);margin-bottom:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.split-modal-row{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border-2);display:flex}.split-modal-row:last-child{border-bottom:none}.split-modal-name{color:var(--fg-1);flex:1;font-size:14px}.split-modal-pct{color:var(--fg-1);text-align:right;width:60px;font-size:18px;font-weight:700}.history-item{padding:var(--space-4);background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius-sm);margin-bottom:6px}.history-item-period{color:var(--fg-4);margin-bottom:var(--space-2);font-size:12px}.history-item-splits{flex-direction:column;gap:4px;display:flex}.history-split-row{color:var(--fg-2);justify-content:space-between;font-size:13px;display:flex}.summary-grid{gap:var(--space-4);margin-bottom:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.summary-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm)}.summary-card-label{color:var(--fg-4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2);font-size:11px;font-weight:600}.summary-card-value{color:var(--fg-1);letter-spacing:-.02em;font-size:24px;font-weight:700;line-height:1}.summary-card-sub{color:var(--fg-4);margin-top:var(--space-2);font-size:12px}.confirm-modal-warning{background:var(--warning-100);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);color:#92600a;border:1px solid #fde68a;font-size:13px;line-height:1.5}.divider{background:var(--border-1);height:1px;margin:var(--space-4) 0}.text-muted{color:var(--fg-4)}.text-success{color:var(--valid-500)}.text-error{color:var(--error-500)}.text-brand{color:var(--brand-azure)}.font-mono{font-family:var(--font-mono)}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-gap-2{align-items:center;gap:var(--space-2);display:flex}.flex-gap-3{align-items:center;gap:var(--space-3);display:flex}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sr-only{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
