.admin-dashboard{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.admin-header{margin-bottom:1.5rem}.admin-header h2{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.admin-header p{margin:0;color:var(--text-muted);font-size:.875rem}.access-denied{text-align:center;padding:4rem 1.5rem}.access-denied h2{margin:0 0 .75rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.access-denied p{margin:.5rem 0;color:var(--text-secondary);font-size:.9375rem}.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.admin-tab{padding:0 1rem;height:40px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s;margin-bottom:-1px;border-radius:0;width:auto;font-family:inherit}.admin-tab:hover{color:var(--text-primary);background:var(--hover-bg);transform:none;box-shadow:none}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:transparent}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.section-header h3{margin:0;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.users-table,.keys-table,.audit-table{background:var(--form-bg);border-radius:8px;overflow:hidden;border:1px solid var(--border)}.users-table table,.keys-table table,.audit-table table{width:100%;border-collapse:collapse}.users-table th,.keys-table th,.audit-table th{background:var(--hover-bg);padding:.625rem .875rem;text-align:left;font-weight:600;color:var(--text-muted);font-size:.6875rem;text-transform:uppercase;letter-spacing:.07em}.users-table td,.keys-table td,.audit-table td{padding:.75rem .875rem;border-top:1px solid var(--border);color:var(--text-primary);font-size:.875rem;vertical-align:middle}.users-table tbody tr:hover,.keys-table tbody tr:hover,.audit-table tbody tr:hover{background:var(--hover-bg)}.users-table code,.keys-table code,.audit-table code{background:var(--hover-bg);padding:.125rem .375rem;border-radius:4px;font-family:var(--font-mono);font-size:.8125rem;color:var(--accent)}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.status-badge.active{background:var(--success-light);color:var(--success)}.status-badge.inactive{background:var(--danger-light);color:var(--danger)}.btn-primary{padding:.5rem 1rem;border:none;border-radius:9999px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--accent);color:#fff;width:auto;font-family:inherit}.btn-primary:hover:not(:disabled){background:var(--accent-dark);transform:none;box-shadow:0 2px 8px #f9731659}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:.5rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--form-bg);color:var(--text-secondary);width:auto;font-family:inherit}.btn-secondary:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary);box-shadow:none;transform:none}.btn-danger-small{padding:.375rem .75rem;border:1px solid rgba(220,38,38,.2);border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--danger-light);color:var(--danger);width:auto;font-family:inherit}.btn-danger-small:hover{background:var(--danger);color:#fff;border-color:var(--danger);transform:none;box-shadow:none}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--text-muted);font-size:.875rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.25rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:overlayIn .15s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card-bg);border-radius:12px;padding:1.75rem;max-width:480px;width:100%;border:1px solid var(--border);box-shadow:var(--shadow-lg);animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{margin:0 0 1.25rem;font-size:1.0625rem;font-weight:600;color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.form-group label{font-weight:500;color:var(--text-secondary);font-size:.8125rem}.form-group input{padding:.5625rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9375rem;background:var(--form-bg);color:var(--text-primary);transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f973161f}.modal-actions{display:flex;gap:.625rem;justify-content:flex-end;margin-top:1.25rem}.key-created{text-align:center}.key-created h3{color:var(--success)!important}.warning-text{color:var(--warning);font-weight:500;font-size:.875rem;margin:.75rem 0;padding:.625rem .875rem;background:var(--warning-light);border-radius:6px;border:1px solid rgba(217,119,6,.2)}.api-key-display{background:var(--form-bg);padding:.875rem;border-radius:8px;margin:1rem 0;display:flex;align-items:center;gap:.75rem;border:1px solid var(--border)}.api-key-display code{flex:1;font-family:var(--font-mono);font-size:.75rem;word-break:break-all;color:var(--accent);background:transparent;padding:0;border:none;text-align:left}.api-key-display button{padding:.4375rem .75rem;background:var(--accent);color:#fff;border:none;border-radius:9999px;cursor:pointer;font-size:.8125rem;white-space:nowrap;width:auto;font-family:inherit;flex-shrink:0}.api-key-display button:hover{background:var(--accent-dark);transform:none;box-shadow:none}.role-select{padding:.375rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--form-bg);color:var(--text-primary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:border-color .15s;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}.role-select:hover{border-color:var(--accent)}.role-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f973161f}.text-muted{color:var(--text-muted);font-size:.8125rem}.audit-table pre{margin:0;font-family:var(--font-mono);font-size:.6875rem;max-width:260px;overflow-x:auto;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all}.limits-hint{margin:0 0 1.25rem;color:var(--text-muted);font-size:.8125rem}.limit-input{width:90px;padding:.375rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--form-bg);color:var(--text-primary);font-size:.875rem;font-family:inherit}.limit-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f973161f}.usage-count{font-weight:600;font-size:.875rem;color:var(--text-primary);display:block}.usage-bar-wrap{display:block;height:4px;background:var(--border);border-radius:2px;margin-top:4px;width:80px;overflow:hidden}.usage-bar{display:block;height:100%;border-radius:2px;transition:width .3s}.btn-small{padding:.375rem .75rem;font-size:.8125rem}.usage-strip{display:flex;align-items:center;gap:.625rem;padding:.5rem .875rem;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;margin-bottom:1.25rem;font-size:.75rem;color:var(--text-muted);flex-wrap:wrap}.usage-strip-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-right:.25rem}.usage-strip-item{display:flex;align-items:center;gap:.375rem;color:var(--text-muted)}.usage-strip-count{font-weight:600;color:var(--text-primary);font-size:.8125rem}.usage-strip-count.at-limit{color:var(--danger)}.usage-strip-bar-wrap{width:60px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.usage-strip-bar{height:100%;border-radius:2px;transition:width .3s}.usage-strip-sub{font-size:.6875rem;color:var(--text-muted)}.usage-strip-divider{width:1px;height:16px;background:var(--border);margin:0 .125rem}@media (max-width: 768px){.admin-tabs{overflow-x:auto}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.users-table,.keys-table,.audit-table{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:560px}.modal-content{padding:1.25rem;max-width:min(90vw,480px)}}@media (max-width: 480px){.admin-header{flex-direction:column;align-items:flex-start;gap:.75rem}.admin-header .btn-primary{width:100%}.admin-tabs{gap:0}.admin-tab{font-size:.75rem;padding:.5rem .625rem}table{min-width:480px;font-size:.8125rem}.modal-overlay{padding:.5rem}.modal-content{padding:1rem;max-width:100%;border-radius:12px}.form-row{grid-template-columns:1fr!important}}.login-container{min-height:100vh;display:flex;background:var(--bg-page)}.login-left{flex:1;background:#0f172a;display:flex;flex-direction:column;padding:3rem;color:#fff;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;pointer-events:none;z-index:0;display:none}.login-left.has-bg-image:before{display:block}.login-left:after{content:"";position:absolute;bottom:-30%;left:-10%;width:400px;height:400px;border-radius:50%;background:#f973160a;pointer-events:none;z-index:0}.login-left>*{position:relative;z-index:1}.login-brand{display:flex;align-items:center;gap:9px;margin-bottom:auto}.login-brand-logo{height:72px;width:auto;display:block}.login-tagline{margin-bottom:2.5rem}.login-tagline h2{font-family:Syne,sans-serif;font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:1rem;color:#fff;letter-spacing:-.02em}.login-tagline p{font-size:1rem;line-height:1.65;color:#ffffffb3;max-width:400px}.login-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.login-feature{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;color:#fffc}.feature-dot{width:6px;height:6px;border-radius:50%;background:#f97316;flex-shrink:0}.login-right{width:480px;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-page)}.login-card{width:100%;max-width:380px;animation:loginFadeIn .3s ease}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:2rem}.login-header h3{font-family:Syne,sans-serif;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.375rem;letter-spacing:-.01em}.login-header p{font-size:.9375rem;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.optional{font-weight:400;color:var(--text-muted)}.form-group input{padding:10px 14px;border:1.5px solid transparent;border-radius:10px;font-size:.9375rem;background:var(--input-bg);color:var(--text-primary);transition:border-color .15s;font-family:Plus Jakarta Sans,sans-serif;width:100%}.form-group input:focus{outline:none;border-color:#f97316}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:2.75rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:.25rem;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .15s;width:auto}.password-toggle:hover{opacity:1;transform:translateY(-50%);box-shadow:none;background:transparent}.login-button{padding:11px;background:#f97316;color:#fff;border:none;border-radius:9999px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.5rem;font-family:Plus Jakarta Sans,sans-serif;width:100%}.login-button:hover:not(:disabled){background:#ea6c0a;transform:none;box-shadow:none}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:1.5rem;text-align:center}.toggle-mode-button{background:transparent;color:#f97316;border:none;padding:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;width:100%;font-family:Plus Jakarta Sans,sans-serif}.toggle-mode-button:hover{background:var(--hover-bg);transform:none;box-shadow:none;border-radius:6px}@media (max-width: 900px){.login-left{display:none}.login-right{width:100%}}.profile-modal{max-width:420px}.profile-modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.profile-modal-header h3{margin:0 0 .375rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.profile-avatar-large{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;flex-shrink:0}.profile-section-title{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:1.25rem 0 .75rem}.toggle-password-section{background:none;border:none;color:var(--accent);font-size:.8125rem;font-weight:500;cursor:pointer;padding:0;font-family:inherit;width:auto}.toggle-password-section:hover{text-decoration:underline;transform:none;box-shadow:none;background:none}.role-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.role-admin{background:#dc26261a;color:#dc2626}.role-operator{background:#f973161a;color:var(--accent)}.role-viewer{background:var(--hover-bg);color:var(--text-muted)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #F97316;--accent-dark: #EA6C0A;--accent-light: #FFF7ED;--accent-mid: #FED7AA;--nav-bg: #0F172A;--nav-bg-2: #1E293B;--slate-50: #F8FAFC;--slate-100: #F1F5F9;--slate-200: #E2E8F0;--slate-300: #CBD5E1;--slate-400: #94A3B8;--slate-500: #64748B;--slate-600: #475569;--slate-700: #334155;--slate-800: #1E293B;--slate-900: #0F172A;--color-success: #10B981;--color-success-tint: #ECFDF5;--color-warning: #F59E0B;--color-warning-tint: #FFFBEB;--color-error: #EF4444;--color-error-tint: #FEF2F2;--color-info: #3B82F6;--color-info-tint: #EFF6FF;--indigo-500: #6366F1;--indigo-600: #4F46E5;--indigo-100: #E0E7FF;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 9999px;--shadow-1: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-2: 0 4px 12px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--shadow-3: 0 12px 32px rgba(0,0,0,.16), 0 4px 8px rgba(0,0,0,.08);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--dur-fast: .15s;--dur-normal: .2s;--dur-slow: .3s;--font-display: "Syne", sans-serif;--font-body: "Plus Jakarta Sans", sans-serif;--font-mono: "JetBrains Mono", monospace}:root,:root[data-theme=light]{--bg-page: var(--slate-50);--bg-card: #FFFFFF;--bg-secondary: var(--slate-100);--bg-input: var(--slate-100);--bg-hover: var(--slate-100);--fg-primary: var(--slate-900);--fg-secondary: var(--slate-600);--fg-muted: var(--slate-400);--border: var(--slate-200);--border-strong: var(--slate-300);--shadow-sm: var(--shadow-1);--shadow: var(--shadow-2);--shadow-lg: var(--shadow-3);--bg-primary: var(--slate-50);--card-bg: #FFFFFF;--form-bg: var(--slate-100);--input-bg: var(--slate-100);--text-primary: var(--slate-900);--text-secondary: var(--slate-600);--text-muted: var(--slate-400);--hover-bg: var(--slate-100);--primary: var(--accent);--primary-rgb: 249, 115, 22;--primary-dark: var(--accent-dark);--primary-light: var(--accent-light);--success: var(--color-success);--success-light: var(--color-success-tint);--danger: var(--color-error);--danger-light: var(--color-error-tint);--warning: var(--color-warning);--warning-light: var(--color-warning-tint)}:root[data-theme=dark]{--bg-page: #0B0F1A;--bg-card: #1E293B;--bg-secondary: #111827;--bg-input: #273449;--bg-hover: #273449;--fg-primary: #F1F5F9;--fg-secondary: #CBD5E1;--fg-muted: #94A3B8;--border: #334155;--border-strong: #475569;--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow: 0 4px 12px rgba(0,0,0,.5), 0 2px 4px rgba(0,0,0,.3);--shadow-lg: 0 12px 32px rgba(0,0,0,.6), 0 4px 8px rgba(0,0,0,.4);--bg-primary: #0B0F1A;--card-bg: #1E293B;--form-bg: #273449;--input-bg: #273449;--text-primary: #F1F5F9;--text-secondary: #CBD5E1;--text-muted: #94A3B8;--hover-bg: #273449;--primary: var(--accent);--primary-rgb: 249, 115, 22;--primary-dark: var(--accent-dark);--primary-light: rgba(249,115,22,.15);--success: #34D399;--success-light: rgba(52,211,153,.1);--danger: #F87171;--danger-light: rgba(248,113,113,.1);--warning: #FBBF24;--warning-light: rgba(251,191,36,.1)}html,body,#root{height:100%}body{font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--fg-primary, var(--text-primary));background:var(--bg-page, var(--bg-primary));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--dur-normal) var(--ease-out),color var(--dur-normal) var(--ease-out)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#96969640;border-radius:3px}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-page)}.app-header{position:sticky;top:0;z-index:100}.header-row-1{display:flex;align-items:center;padding:0 24px;height:52px;gap:16px;background:var(--nav-bg)}.header-row-2{display:flex;align-items:center;padding:0 20px;background:var(--nav-bg-2);border-bottom:1px solid rgba(255,255,255,.06)}.header-brand{display:flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;flex-shrink:0}.header-brand:hover{opacity:.85;transform:none;box-shadow:none;background:none}.header-brand-logo{height:36px;width:auto;display:block}.header-brand-name{font-size:.95rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap}.header-spacer{flex:1}.header-right{display:flex;align-items:center;gap:6px}.user-info{display:flex;align-items:center;gap:8px;padding:5px 12px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-pill);background:transparent;cursor:pointer;font-family:inherit;transition:background var(--dur-fast) var(--ease-out);width:auto}.user-info:hover{background:#ffffff0f;border-color:#fff3;transform:none;box-shadow:none}.user-avatar{width:26px;height:26px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-size:13px;font-weight:500;color:#ffffffd9}.user-role{padding:2px 7px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.user-role.role-super_admin{background:#f9731633;color:var(--accent)}.user-role.role-admin{background:#ef444433;color:#fca5a5}.user-role.role-operator{background:#6366f133;color:#a5b4fc}.user-role.role-viewer{background:#ffffff14;color:#ffffff73}.icon-button{width:34px;height:34px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-pill);color:#fff9;cursor:pointer;transition:all var(--dur-fast) var(--ease-out)}.icon-button:hover{background:#ffffff14;color:#ffffffe6;border-color:#ffffff38;transform:none;box-shadow:none}.logout-button{display:flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--radius-pill);border:1px solid rgba(255,255,255,.12);background:transparent;font-size:13px;font-weight:500;color:#ffffffb3;cursor:pointer;transition:all var(--dur-fast) var(--ease-out);width:auto;font-family:inherit}.logout-button:hover{background:#ffffff0f;color:#ffffffe6;transform:none;box-shadow:none}.tab-nav-inner{display:flex;align-items:center}.tab-button{padding:9px 15px;border:none;border-bottom:2px solid transparent;background:transparent;font-size:13px;font-weight:400;color:#ffffff73;cursor:pointer;transition:color var(--dur-fast) var(--ease-out);white-space:nowrap;margin-bottom:-1px;display:flex;align-items:center;gap:6px;border-radius:0;width:auto;font-family:inherit}.tab-button:hover{color:#ffffffbf;background:transparent;transform:none;box-shadow:none}.tab-button.active{color:#fff;font-weight:600;border-bottom-color:var(--accent);background:transparent}.tab-button svg{opacity:.7}.tab-button.active svg,.tab-button:hover svg{opacity:1}.app-content{max-width:1440px;margin:0 auto;padding:2rem;width:100%;flex:1}.single-panel-view{max-width:1100px}.notifications-view{display:grid;grid-template-columns:400px 1fr;gap:1.5rem;align-items:start}@media (max-width: 1024px){.notifications-view{grid-template-columns:1fr}}.notification-form,.notification-list{background:var(--card-bg);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.notification-form h2,.notification-list h2{color:var(--text-primary);margin-bottom:1.25rem;font-size:1rem;font-weight:600}.card{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.form-group{margin-bottom:1.125rem}.form-group>label:not(.customer-checkbox):not(.template-toggle):not(.polling-indicator){display:block;color:var(--text-secondary);font-weight:500;font-size:.8125rem;margin-bottom:.375rem}.form-label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.form-group input:not([type=checkbox]):not([type=radio]),.form-group textarea,.form-group select,.form-input{width:100%;padding:10px 14px;border:1.5px solid transparent;border-radius:var(--radius-md);font-size:14px;font-family:var(--font-body);background:var(--bg-input, var(--input-bg));color:var(--text-primary);transition:border-color var(--dur-fast) var(--ease-out);-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-group select,.form-input[type=select],select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem}.form-group input:not([type=checkbox]):not([type=radio]):focus,.form-group textarea:focus,.form-group select:focus,.form-input:focus{outline:none;border-color:var(--accent)}.form-group textarea,textarea.form-input{resize:vertical;min-height:100px}button{border:none;padding:8px 18px;border-radius:var(--radius-pill);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--dur-fast) var(--ease-out);font-family:var(--font-body)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;width:auto;border-radius:var(--radius-pill);font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-secondary{background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border);width:auto;border-radius:var(--radius-pill)}.btn-secondary:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary);box-shadow:none}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid rgba(239,68,68,.25);width:auto;border-radius:var(--radius-pill)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-submit{background:var(--accent);width:100%;padding:10px 18px;font-size:.9375rem;font-weight:600;border-radius:var(--radius-pill)}.error-message{display:flex;align-items:flex-start;gap:.5rem;background:var(--danger-light);color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;border:1px solid rgba(239,68,68,.2);font-size:.875rem}.success-message{background:var(--success-light);color:var(--success);padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;border:1px solid rgba(16,185,129,.2);font-size:.875rem}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.refresh-button{width:auto;padding:7px 16px;font-size:.8125rem;background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-pill)}.refresh-button:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary);box-shadow:none}.polling-indicator{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-muted)}.polling-indicator label{display:flex;align-items:center;gap:.375rem;cursor:pointer}.polling-indicator input[type=checkbox]{width:auto}.polling-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2s ease-in-out infinite;display:inline-block}.poll-interval-input{width:48px;padding:2px 6px;border:1px solid var(--border);border-radius:4px;background:var(--form-bg);color:var(--text-primary);font-size:.75rem;font-family:inherit;text-align:center;border-radius:var(--radius-sm)}.poll-interval-input:focus{outline:none;border-color:var(--accent)}.poll-interval-label{font-size:.75rem;color:var(--text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.loading{text-align:center;padding:3rem 2rem;color:var(--text-muted);font-size:.875rem}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:var(--text-muted)}.loading-spinner{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted);font-size:.875rem}.notifications{display:flex;flex-direction:column;gap:.625rem}.notification-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card-bg);transition:box-shadow var(--dur-fast) var(--ease-out);overflow:hidden}.notification-card:hover{box-shadow:var(--shadow-sm)}.notification-card.collapsed{padding:0}.notification-card.expanded{padding-bottom:1rem}.notification-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.notification-header:hover{background:var(--hover-bg)}.notification-card.expanded .notification-header{border-bottom:1px solid var(--border)}.notification-header-left{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.notification-chevron{color:var(--text-muted);font-size:.75rem;flex-shrink:0}.notification-chevron-icon{color:var(--text-muted);flex-shrink:0}.notification-header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.notification-header h3{color:var(--text-primary);font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-timestamp{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.notification-type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--hover-bg);color:var(--text-muted);border:1px solid var(--border)}.notif-type-email{background:#3b82f614;color:#3b82f6;border-color:#3b82f633}.notif-type-sms{background:#8b5cf614;color:#8b5cf6;border-color:#8b5cf633}.notification-body{padding:.875rem 1rem 0;color:var(--text-secondary);line-height:1.5;font-size:.875rem}.notification-meta{padding:.625rem 1rem 0;margin-top:.75rem;display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--border)}.notification-meta strong{color:var(--text-secondary);font-weight:500}.notification-id code{background:var(--hover-bg);padding:2px 6px;border-radius:var(--radius-sm);font-size:11px;color:var(--text-secondary);font-family:var(--font-mono)}.status-badge{padding:3px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.status-completed{background:var(--success-light);color:var(--success)}.status-processing{background:var(--accent-light);color:var(--accent)}.status-pending{background:var(--warning-light);color:var(--warning)}.status-failed{background:var(--danger-light);color:var(--danger)}.status-cancelled{background:var(--hover-bg);color:var(--text-muted)}.notif-type-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1rem}.notif-type-tab{padding:0 1rem;height:36px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:color var(--dur-fast);margin-bottom:-1px;font-family:inherit;display:flex;align-items:center;gap:.375rem;width:auto;border-radius:0}.notif-type-tab:hover{color:var(--text-primary);background:transparent;transform:none;box-shadow:none}.notif-type-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:transparent}.tab-count{background:var(--hover-bg);color:var(--text-muted);border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.notif-type-tab.active .tab-count{background:var(--accent-light);color:var(--accent)}.notif-filter-bar{display:flex;align-items:center;gap:.625rem;margin-bottom:1rem;flex-wrap:wrap}.notif-filter-select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--card-bg);color:var(--text-primary);font-size:.8125rem;font-family:inherit;cursor:pointer}.notif-filter-select:focus{outline:none;border-color:var(--accent)}.notif-sort-btn{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--card-bg);color:var(--text-secondary);font-size:.8125rem;font-family:inherit;cursor:pointer;width:auto;transition:border-color var(--dur-fast)}.notif-sort-btn:hover{border-color:var(--accent);color:var(--accent);transform:none;box-shadow:none;background:var(--card-bg)}.notif-filter-count{margin-left:auto;font-size:.75rem;color:var(--text-muted)}@media (max-width: 480px){.notif-filter-bar{gap:.4rem}.notif-filter-select{flex:1 1 calc(50% - .2rem);font-size:.75rem}.notif-filter-count{width:100%;margin-left:0}}.notif-user-badge{padding:2px 7px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;background:var(--hover-bg);color:var(--text-muted);font-family:var(--font-mono)}.notif-recipients{color:var(--text-primary);word-break:break-word}.template-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.375rem 0}.template-toggle input[type=checkbox]{width:auto;cursor:pointer}.template-toggle span{color:var(--text-primary);font-size:.875rem;font-weight:500}.variable-inputs{display:flex;flex-direction:column;gap:.75rem}.variable-input-group{display:flex;flex-direction:column;gap:.375rem}.variable-input-group label{display:flex;align-items:center;gap:.375rem}.variable-input-group label code{background:var(--accent-light);color:var(--accent);padding:2px 6px;border-radius:var(--radius-sm);font-size:.75rem;font-family:var(--font-mono);font-weight:600}.template-preview{background:var(--form-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;margin-top:.75rem}.template-preview strong{display:block;color:var(--text-primary);margin-bottom:.75rem;font-size:.8125rem}.preview-section{margin-bottom:.75rem}.preview-section:last-child{margin-bottom:0}.preview-label{display:block;color:var(--text-muted);font-weight:600;margin-bottom:.375rem;font-size:11px;text-transform:uppercase;letter-spacing:.07em}.preview-content{background:var(--card-bg);padding:.75rem;border-radius:6px;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word;border:1px solid var(--border);line-height:1.5;font-size:.875rem}.customer-selector{border:1px solid var(--border);border-radius:var(--radius-md);max-height:200px;overflow-y:auto;background:var(--input-bg)}.customer-checkbox{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.customer-checkbox:last-child{border-bottom:none}.customer-checkbox:hover{background:var(--hover-bg)}.customer-checkbox input[type=checkbox]{width:15px;height:15px;min-width:15px;cursor:pointer;flex-shrink:0;accent-color:var(--accent);-moz-appearance:auto;appearance:auto;-webkit-appearance:auto;margin:0;padding:0;border:none;background:none;box-shadow:none}.customer-checkbox .customer-name-text{font-size:.875rem;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.customer-email-small{font-size:.75rem;color:var(--text-muted);margin-left:auto;flex-shrink:0;padding-left:.5rem}.recipient-search-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--form-bg);color:var(--text-primary);font-size:.875rem;font-family:inherit;margin-bottom:.5rem;box-sizing:border-box;transition:border-color .15s}.recipient-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f973161a}.add-recipient-prompt{display:flex;flex-direction:column;gap:.5rem;padding:.625rem .75rem;background:var(--accent-light);border:1px solid rgba(249,115,22,.25);border-radius:var(--radius-md);margin-bottom:.5rem;font-size:.8125rem;color:var(--text-secondary)}.add-recipient-header{font-size:.8125rem}.add-recipient-name-row{display:flex;gap:.375rem;align-items:center}.add-recipient-name-input{flex:1;padding:.3125rem .5rem;border:1px solid rgba(249,115,22,.3);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text-primary);font-size:.8125rem;font-family:inherit;min-width:0}.add-recipient-name-input:focus{outline:none;border-color:var(--accent)}.add-recipient-btn{flex-shrink:0;padding:.3125rem .75rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-pill);font-size:.75rem;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;width:auto;transition:background .15s}.add-recipient-btn:hover:not(:disabled){background:var(--accent-dark);box-shadow:none;transform:none}.add-recipient-btn:disabled{opacity:.6;cursor:not-allowed}.select-all-btn{font-size:.75rem!important;padding:4px 10px!important;width:auto!important;background:transparent!important;color:var(--accent)!important;border:1px solid var(--accent)!important;border-radius:var(--radius-pill)!important}.select-all-btn:hover:not(:disabled){background:var(--accent-light)!important;box-shadow:none!important}.stat-card{background:var(--form-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:.875rem 1rem}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1}.progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s}@media (max-width: 768px){.header-row-1{padding:0 12px;height:48px;gap:8px}.header-brand-logo{height:28px}.logout-button span{display:none}.logout-button{width:34px;height:34px;padding:0;justify-content:center}.user-name{display:none}.user-info{padding:4px 8px;gap:6px}.header-row-2{padding:0 4px;overflow-x:auto;scrollbar-width:none}.header-row-2::-webkit-scrollbar{display:none}.tab-button{padding:8px 10px;font-size:12px;white-space:nowrap}.tab-button span{display:none}.tab-button{gap:0;padding:10px 12px}.app-content{padding:1rem}.single-panel-view{max-width:100%}.notification-form,.notification-list{padding:1rem;border-radius:10px}.notification-header{padding:.625rem .75rem}.notification-body,.notification-meta{padding-left:.75rem;padding-right:.75rem}.notif-timestamp{display:none}.usage-strip{flex-wrap:nowrap;overflow-x:auto}}@media (max-width: 480px){.app-content{padding:.75rem}.header-row-1{padding:0 10px}.user-role{display:none}.icon-button{width:30px;height:30px}}@media (max-width: 900px){.login-left{display:none}.login-right{width:100%;padding:1.5rem 1rem}.login-card{max-width:100%}}@media (max-width: 480px){.login-right{padding:1.25rem .875rem}.login-header h3{font-size:1.25rem}}@media (max-width: 640px){.cd-page-header{padding:1rem 1rem .875rem}.cd-stats-bar{margin:0 1rem 1rem}.cd-search-wrap{margin:0 1rem .75rem}.cd-table-wrap{margin:0 1rem;overflow-x:auto}.cd-table{min-width:480px}.cd-th-email,.cd-td-email{display:none}.cd-footer{padding:.5rem 1rem .875rem}.sch-page-header{flex-direction:column;align-items:stretch}.sch-row{grid-template-columns:1fr}.sch-card-right{flex-wrap:wrap}.admin-tabs{overflow-x:auto;scrollbar-width:none}.admin-tabs::-webkit-scrollbar{display:none}}@supports (padding-bottom: env(safe-area-inset-bottom)){.app-content{padding-bottom:calc(1.5rem + env(safe-area-inset-bottom))}.app-header{padding-top:env(safe-area-inset-top)}}button,a{-webkit-tap-highlight-color:transparent}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.break-all{word-break:break-all}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:solid}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
