:root{color-scheme:light;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5;font-weight:400;--bg: #f3f4f6;--panel-bg: #ffffff;--text: #111827;--muted: #6b7280;--border: #e5e7eb;--accent: #667eea;--success: #10b981;color:var(--text, #111827);background:var(--bg, #f3f4f6);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{height:100%}body{margin:0;color:var(--text);background:var(--bg)}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}#root{min-height:100%}.ql-toolbar.ql-snow{border-top-left-radius:8px;border-top-right-radius:8px;background:#f8f9fa}.ql-container.ql-snow{border-bottom-left-radius:8px;border-bottom-right-radius:8px;font-size:14px}.ql-editor{min-height:400px;line-height:1.6}.ql-editor h1,.ql-editor h2,.ql-editor h3{color:var(--text)}.ql-editor p{margin-bottom:.5em}:root{--brand-primary: #3b82f6;--brand-primary-hover: #2563eb;--brand-primary-light: #60a5fa;--brand-secondary: #8b5cf6;--brand-accent: #10b981;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-bg-hover: #f3f4f6;--color-bg-active: #e5e7eb;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-inverse: #ffffff;--color-border: #e5e7eb;--color-border-hover: #d1d5db;--color-border-focus: var(--brand-primary);--color-bg-primary-dark: #0f172a;--color-bg-secondary-dark: #1e293b;--color-bg-tertiary-dark: #334155;--color-bg-hover-dark: #1e293b;--color-bg-active-dark: #334155;--color-text-primary-dark: #f1f5f9;--color-text-secondary-dark: #cbd5e1;--color-text-tertiary-dark: #94a3b8;--color-border-dark: #334155;--color-border-hover-dark: #475569;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", "Cascadia Code", "Consolas", "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--chat-bubble-radius: var(--radius-lg);--chat-bubble-padding: var(--spacing-sm) var(--spacing-md);--chat-bubble-max-width: 70%;--chat-message-gap: var(--spacing-sm);--chat-input-height: 48px;--chat-gradient-outgoing: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--chat-gradient-incoming: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);--chat-gradient-broadcast: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);--chat-gradient-critical: linear-gradient(135deg, #ef4444 0%, #dc2626 100%)}[data-theme=dark]{--color-bg-primary: var(--color-bg-primary-dark);--color-bg-secondary: var(--color-bg-secondary-dark);--color-bg-tertiary: var(--color-bg-tertiary-dark);--color-bg-hover: var(--color-bg-hover-dark);--color-bg-active: var(--color-bg-active-dark);--color-text-primary: var(--color-text-primary-dark);--color-text-secondary: var(--color-text-secondary-dark);--color-text-tertiary: var(--color-text-tertiary-dark);--color-border: var(--color-border-dark);--color-border-hover: var(--color-border-hover-dark);--chat-gradient-incoming: linear-gradient(135deg, #1e293b 0%, #334155 100%)}.appShell{display:flex;min-height:100vh;width:100%;align-items:stretch}.sidebar{width:260px;flex:0 0 260px;background:var(--color-bg-secondary-dark);color:var(--color-text-inverse);padding:var(--spacing-md);min-width:200px;max-width:400px;position:sticky;top:0;height:100vh;box-sizing:border-box;display:flex;flex-direction:column;transition:width var(--transition-base),padding var(--transition-base);overflow:hidden}.sidebar--collapsed{width:64px;min-width:64px;max-width:64px;padding:var(--spacing-sm) var(--spacing-xs)}.sidebar--collapsed .nav-label{display:none}.sidebar--collapsed .navLink{justify-content:center;padding:var(--spacing-sm)}.sidebar--dark{background:var(--color-bg-secondary-dark);color:var(--color-text-inverse)}.sidebar--light{background:var(--color-bg-secondary);color:var(--color-text-primary)}.sidebar-resizer{width:6px;cursor:col-resize;background:linear-gradient(90deg,transparent,var(--color-border),transparent);transition:background-color var(--transition-fast);flex:0 0 6px;height:100vh}.sidebar-resizer:hover,.sidebar-resizer:active{background:var(--color-border-hover)}.sidebar-header{display:flex;justify-content:center;margin-bottom:var(--spacing-xs)}.sidebar-collapse-btn{width:36px;height:36px;padding:0;border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.sidebar-collapse-btn:hover{background:#ffffff1a;color:var(--color-border)}.sidebar--light .sidebar-collapse-btn{color:var(--color-text-secondary)}.sidebar--light .sidebar-collapse-btn:hover{background:#0000000d;color:var(--color-text-primary)}.brand{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);align-items:center}.brandTitle{font-weight:var(--font-weight-bold);letter-spacing:.2px;font-size:var(--font-size-lg);text-align:center}.brand-icon{display:flex;align-items:center;justify-content:center;margin:var(--spacing-xs) 0;color:var(--brand-primary-light);transition:all var(--transition-base)}.sidebar--dark .brand-icon{background-color:var(--color-bg-secondary);border-radius:var(--radius-full);padding:0}.sidebar--light .brand-icon{background-color:var(--color-bg-primary);border-radius:var(--radius-full);padding:0}.brand-icon:hover{color:var(--brand-primary);transform:scale(1.1)}.brand-icon svg{filter:drop-shadow(0 2px 4px rgba(96,165,250,.3))}.brandSub{color:var(--color-text-tertiary);font-size:var(--font-size-xs);text-align:center}.brand-logo-img{width:100%;height:100%;border-radius:var(--radius-lg);object-fit:contain;box-shadow:var(--shadow-md)}.nav{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1 1 auto;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.navLink{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary-dark);text-decoration:none;transition:all var(--transition-fast)}.navLink:hover{background:var(--color-bg-hover-dark);text-decoration:none}.navLinkActive{background:var(--color-bg-active-dark);color:var(--color-text-inverse)}.nav-icon{display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;width:28px}.nav-label{font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.navDivider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:var(--spacing-sm) 0}.sidebar--light .navDivider{border-top-color:var(--color-border)}.navDropdownToggle{width:100%;border:none;background:none;cursor:pointer;font:inherit;text-align:left}.nav-chevron{margin-left:auto;font-size:var(--font-size-xs);transition:transform var(--transition-fast);color:var(--color-text-tertiary)}.nav-chevron--open{transform:rotate(90deg)}.navPopup{min-width:200px;background:var(--color-bg-secondary-dark);border:1px solid var(--color-bg-active-dark);border-radius:var(--radius-md);padding:var(--spacing-xs);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:var(--spacing-xs)}.navPopupItem{border-radius:var(--radius-sm)}.navPopup--light{background:var(--color-bg-secondary);border-color:var(--color-border);box-shadow:var(--shadow-lg)}.navPopup--light .navLink{color:var(--color-text-primary)}.navPopup--light .navLink:hover,.navPopup--light .navLinkActive{background:var(--color-bg-active);color:var(--color-text-primary)}.sidebar--light .navLink{color:var(--color-text-primary)}.sidebar--light .navLink:hover,.sidebar--light .navLinkActive{background:var(--color-bg-active);color:var(--color-text-primary)}.sidebar--light .brandSub{color:var(--color-text-secondary)}.sidebar--light .brand-icon{color:var(--brand-primary-hover)}.main{flex:1;display:flex;flex-direction:column;min-width:0;width:100%;height:100vh;overflow:auto}.topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);background:var(--color-bg-primary);border-bottom:1px solid var(--color-border)}.topbar-datetime{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);border:2px solid var(--brand-primary);border-radius:var(--radius-md);background-color:#f8f9ff}.topbar-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.topbar-time{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:.5px;font-family:var(--font-family-base)}.page{padding:var(--spacing-md);width:100%;max-width:100%;flex:1 1 auto;overflow:auto}.h1{margin:0 0 var(--spacing-md);font-size:var(--font-size-xl)}.muted{color:var(--color-text-secondary)}.card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md)}.card+.card{margin-top:var(--spacing-md)}.row{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.rowBetween{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.table th{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.input,.select{height:36px;border:1px solid var(--color-border-hover);border-radius:var(--radius-md);padding:0 var(--spacing-md);background:var(--color-bg-primary);color:var(--color-text-primary);outline:none;font-size:var(--font-size-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input:focus,.select:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #3b82f626}.btn{height:36px;padding:0 var(--spacing-md);border-radius:var(--radius-md);border:1px solid transparent;background:var(--color-text-primary);color:var(--color-text-inverse);cursor:pointer;transition:background var(--transition-fast);font-weight:var(--font-weight-medium)}.btn:hover{background:var(--color-bg-primary-dark)}.btnSecondary{background:var(--color-bg-primary);color:var(--color-text-primary);border-color:var(--color-border-hover)}.btnSecondary:hover{background:var(--color-bg-secondary)}.btn-danger{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;border:none;font-weight:var(--font-weight-semibold);box-shadow:0 2px 4px #dc262633}.btn-danger:hover{background:linear-gradient(135deg,#b91c1c,#dc2626);box-shadow:0 4px 8px #dc26264d}.btn-danger:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed}.badge{display:inline-flex;align-items:center;height:22px;padding:0 var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);border:1px solid var(--color-border);background:var(--color-bg-secondary);white-space:nowrap}.badge--paid{border:2px solid var(--color-success);background:#d1fae5;color:#065f46}.badge--draft,.badge--issued,.badge--partially_paid{border:2px solid var(--color-warning);background:#fef3c7;color:#92400e}.badge--cancelled{border:2px solid var(--color-error);background:#fee2e2;color:#991b1b}.badge-success{background:#d1fae5;border-color:var(--color-success);color:#065f46}.badge-warning{background:#fef3c7;border-color:var(--color-warning);color:#92400e}.badge-error{background:#fee2e2;border-color:var(--color-error);color:#991b1b}.errorBox{background:#fef2f2;border:1px solid #fecaca;color:#7f1d1d;border-radius:var(--radius-lg);padding:var(--spacing-md)}@media(max-width:768px){.sidebar{min-width:180px;max-width:320px;padding:var(--spacing-md)}.topbar{padding:0 var(--spacing-md)}.page{padding:var(--spacing-md)}}@media(max-width:480px){.sidebar{position:sticky;top:0;width:100%;flex:0 0 auto}.appShell{flex-direction:column}.page{padding:var(--spacing-sm)}}.sidebar-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-sm);border-top:1px solid rgba(148,163,184,.4)}.sidebar--collapsed .sidebar-footer{display:none}.sidebar-settings-btn{width:100%;padding:var(--spacing-sm) var(--spacing-sm);border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-tertiary);font-size:var(--font-size-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);transition:color var(--transition-fast),transform var(--transition-fast)}.sidebar-settings-btn:hover{background:transparent;color:var(--color-border);transform:translateY(-1px)}.sidebar--light .sidebar-settings-btn{color:var(--color-text-secondary)}.sidebar--light .sidebar-settings-btn:hover{color:var(--color-text-primary)}.sidebar-settings-popup{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:#0f172afa;color:var(--color-border);box-shadow:var(--shadow-xl);font-size:var(--font-size-xs)}.sidebar--light .sidebar-settings-popup{background:var(--color-bg-primary);color:var(--color-text-primary);box-shadow:var(--shadow-lg)}.sidebar-settings-section+.sidebar-settings-section{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed rgba(148,163,184,.5)}.sidebar-settings-title{font-weight:var(--font-weight-semibold);margin-bottom:6px}.sidebar-settings-row{display:flex;gap:6px;flex-wrap:wrap}.sidebar-settings-row--logo{align-items:center;justify-content:space-between}.sidebar-theme-chip{padding:6px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:transparent;color:inherit;font-size:12px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.sidebar-theme-chip--active{border-color:#2563eb;background-color:#2563eb26}.sidebar-file-label{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;border:1px dashed rgba(148,163,184,.9);font-size:12px;cursor:pointer;background:#0f172a33;color:inherit}.sidebar--light .sidebar-file-label{background:#f9fafb}.sidebar-file-input{display:none}.sidebar-reset-logo-btn{padding:4px 8px;border-radius:999px;border:1px solid rgba(248,113,113,.9);background:transparent;color:#fecaca;font-size:11px;cursor:pointer}.sidebar--light .sidebar-reset-logo-btn{color:#b91c1c}.tabs{display:flex;gap:4px;border-bottom:2px solid #e5e7eb;margin-bottom:16px;padding-bottom:0}.tab{display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 16px;border:none;border-radius:10px 10px 0 0;background:transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;white-space:nowrap}.tab:hover{background:#f3f4f6;color:#374151}.tab.active{background:#111827;color:#fff}.tab.active:hover{background:#1f2937}.tab-icon{font-size:16px}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:12px;font-weight:600;background:#fff3}.tab:not(.active) .tab-badge{background:#e5e7eb;color:#6b7280}.tab.active .tab-badge{background:#ffffff40;color:#fff}.messages-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background:transparent;color:#6b7280;cursor:pointer;transition:all .2s ease;margin-right:.5rem}.messages-icon-btn:hover{background:#f3f4f6;color:#3b82f6}.messages-badge{position:absolute;top:4px;right:4px;display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#ef4444;color:#fff;font-size:11px;font-weight:600;line-height:1;box-shadow:0 2px 4px #0000001a}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:fit-content;height:fit-content;min-width:700px;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;overflow:hidden;box-sizing:border-box}.modal-content--compact{max-width:450px}.modal-header--danger{background:linear-gradient(135deg,#fee2e2,#fef2f2);border-bottom:2px solid #ef4444}.modal-header--danger .modal-title{color:#991b1b}.modal-header--warning{background:linear-gradient(135deg,#fef3c7,#fefce8);border-bottom:2px solid #f59e0b}.modal-header--warning .modal-title{color:#92400e}.modal-header--info{background:linear-gradient(135deg,#dbeafe,#eff6ff);border-bottom:2px solid #3b82f6}.modal-header--info .modal-title{color:#1e3a8a}} .modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0;background-color:#f9f9f9}.modal-title{margin:0;font-size:20px;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background-color:#e0e0e0;color:#333}.modal-body{padding:24px;white-space:normal;overflow-y:auto;overflow-x:hidden;flex:1 1 auto;min-height:0;color:#666;line-height:1.6;word-break:break-word;overflow-wrap:anywhere;-webkit-font-smoothing:antialiased}.modal-body p{margin:0 0 16px}.modal-body p:last-child{margin-bottom:0}.modal-body strong{color:#333;font-weight:600}.modal-body ul{margin:12px 0;padding-left:20px}.modal-body li{margin:8px 0}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e0e0e0;background-color:#f9f9f9}.modal-btn{padding:10px 24px;background-color:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.modal-btn:hover{background-color:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.modal-btn:active{transform:translateY(0)}.stats-modal-content{display:flex;flex-direction:column;gap:16px;color:#444;white-space:nowrap}.stats-overview{display:flex;gap:12px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start}.stats-item{background:#fff;border:1px solid #eef2ff;box-shadow:0 6px 18px #0f172a08;border-radius:8px;padding:12px 14px;min-width:140px;flex:1 1 220px;display:flex;flex-direction:column;gap:6px;box-sizing:border-box;max-height:none;overflow:visible}.stats-label{font-size:13px;color:#6b7280;display:flex;align-items:center;gap:8px}.stats-value{font-size:20px;font-weight:700;color:#111827}.stats-percent{font-size:12px;color:#6b7280}.stats-detail{display:flex;flex-direction:column;gap:12px}.stats-detail-header{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.stats-controls{width:100%;display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-start}.stats-controls label{display:flex;gap:6px;align-items:center;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.stats-controls select{height:36px;padding:6px 10px;border-radius:8px;border:1px solid #dfe3f0;background:#fff;color:#333;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.stats-controls select:hover{border-color:#cfd5ff;background-color:#fafbff}.stats-controls select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.stats-list{display:flex;flex-direction:column;gap:8px;max-height:calc(80vh - 200px);overflow:auto;padding-right:4px}.stats-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:10px;border-radius:6px;border:1px solid #f3f4f6;background:#fff}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px}.btn{padding:8px 12px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;color:#111827;cursor:pointer}.btn[disabled]{opacity:.5;cursor:not-allowed}.empty{padding:16px;text-align:center;color:#6b7280}@media(max-width:768px){.modal-content{width:95%;max-height:95vh}.modal-header,.modal-body{padding:16px}.modal-footer{padding:12px 16px}.modal-title{font-size:18px}.stats-detail-header{flex-direction:column;align-items:stretch;gap:8px}.stats-controls{flex-wrap:wrap}.stats-item{flex-direction:column}}@media(min-width:900px){.modal-content{width:fit-content;height:fit-content;max-width:95vw;max-height:95vh}}.stats-overview,.stats-list{min-width:0}.stats-item{min-width:120px;max-width:100%;box-sizing:border-box}.modal-body img,.modal-body svg,.modal-body table,.modal-body pre,.modal-body code{max-width:100%;height:auto}.stats-controls select,.modal-body select{max-width:220px}.stats-label,.stats-value,.modal-body p,.modal-body li{word-break:break-word;overflow-wrap:anywhere}.user-profile-widget{position:relative}.user-profile-trigger{display:flex;align-items:center;gap:12px;padding:8px 12px;background-color:#fff;border:1px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s}.user-profile-trigger:hover{background-color:#f9f9f9;border-color:#667eea;box-shadow:0 2px 8px #0000001a}.user-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0;box-shadow:0 2px 8px #00000026}.user-info{display:flex;flex-direction:column;gap:2px;min-width:0}.user-name{font-size:14px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-arrow{color:#999;flex-shrink:0;transition:transform .2s}.dropdown-arrow.open{transform:rotate(180deg)}.user-profile-overlay{position:fixed;inset:0;z-index:999}.user-profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 10px 40px #00000026;z-index:1000;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid #f0f0f0}.user-avatar-large{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700;flex-shrink:0;box-shadow:0 4px 12px #00000026}.user-details{flex:1;min-width:0}.user-fullname{font-size:16px;font-weight:600;color:#333;margin-bottom:4px;display:flex;flex-direction:column;line-height:1.3}.user-fullname-lastname,.user-fullname-firstmid{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-username{font-size:13px;color:#999;font-family:Courier New,monospace}.dropdown-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.user-contact-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background-color:#f9f9f9;border-radius:8px;font-size:13px;color:#666}.user-contact-item svg{color:#999;flex-shrink:0}.user-contact-item span,.user-contact-item a{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-contact-link{color:inherit;text-decoration:none}.user-contact-link:hover{color:#1976d2;text-decoration:underline}.dropdown-actions{display:flex;flex-direction:column;gap:4px;padding:12px;border-top:1px solid #f0f0f0}.dropdown-action-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;background:none;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#333;text-align:left}.dropdown-action-btn:hover{background-color:#f0f0f0}.dropdown-action-btn svg{color:#666;flex-shrink:0}.dropdown-action-btn.logout{color:#d32f2f}.dropdown-action-btn.logout svg{color:#d32f2f}.dropdown-action-btn.logout:hover{background-color:#ffebee}.user-profile-trigger.role-admin{border-color:#d32f2f;background:linear-gradient(180deg,#fff6f6,#fff)}.user-profile-trigger.role-admin .user-avatar{background-color:#d32f2f!important}.user-profile-trigger.role-admin .user-role{color:#b71c1c}.user-profile-dropdown.role-admin{border-color:#b71c1c1f;box-shadow:0 10px 40px #b71c1c0f}.user-profile-dropdown.role-admin .dropdown-header{background:#fff6f6;border-bottom-color:#b71c1c1f}.user-profile-dropdown.role-admin .dropdown-action-btn.logout{color:#b71c1c}.user-profile-dropdown.role-admin .dropdown-action-btn.logout svg{color:#b71c1c}.user-profile-trigger.role-superadmin{border-color:#111;background:linear-gradient(180deg,#fff6f6,#fff)}.user-profile-trigger.role-superadmin .user-avatar{background-color:#111!important}.user-profile-trigger.role-superadmin .user-role{color:#111}.user-profile-dropdown.role-superadmin{border-color:#0000001f;box-shadow:0 10px 40px #0000000f}.user-profile-dropdown.role-superadmin .dropdown-header{background:#fff6f6;border-bottom-color:#0000001f}.user-profile-dropdown.role-superadmin .dropdown-action-btn.logout{color:#111}.user-profile-dropdown.role-superadmin .dropdown-action-btn.logout svg{color:#111}.user-profile-trigger.role-doctor{border-color:#1976d2;background:linear-gradient(180deg,#eaf4ff,#fff)}.user-profile-trigger.role-doctor .user-avatar{background-color:#1976d2!important}.user-profile-trigger.role-doctor .user-role{color:#1565c0}.user-profile-dropdown.role-doctor{border-color:#1565c01f;box-shadow:0 10px 40px #1565c00f}.user-profile-dropdown.role-doctor .dropdown-header{background:#eef7ff;border-bottom-color:#1565c01f}.user-profile-trigger.role-receptionist{border-color:#7b1fa2;background:linear-gradient(180deg,#fbf3ff,#fff)}.user-profile-trigger.role-receptionist .user-avatar{background-color:#7b1fa2!important}.user-profile-trigger.role-receptionist .user-role{color:#6a1b9a}.user-profile-dropdown.role-receptionist{border-color:#7c1fa21f;box-shadow:0 10px 40px #7c1fa20f}.user-profile-dropdown.role-receptionist .dropdown-header{background:#fcf5ff;border-bottom-color:#7c1fa21f}.user-profile-trigger.role-billing{border-color:#388e3c;background:linear-gradient(180deg,#f3fff4,#fff)}.user-profile-trigger.role-billing .user-avatar{background-color:#388e3c!important}.user-profile-trigger.role-billing .user-role{color:#2e7d32}.user-profile-dropdown.role-billing{border-color:#388e3c1f;box-shadow:0 10px 40px #388e3c0f}.user-profile-dropdown.role-billing .dropdown-header{background:#f6fff7;border-bottom-color:#388e3c1f}.user-profile-trigger.role-analyst{border-color:#f57c00;background:linear-gradient(180deg,#fff7ec,#fff)}.user-profile-trigger.role-analyst .user-avatar{background-color:#f57c00!important}.user-profile-trigger.role-analyst .user-role{color:#e65100}.user-profile-dropdown.role-analyst{border-color:#f57c001f;box-shadow:0 10px 40px #f57c000f}.user-profile-dropdown.role-analyst .dropdown-header{background:#fff8ef;border-bottom-color:#f57c001f}@media(max-width:768px){.user-profile-dropdown{width:280px}.user-info{max-width:120px}}.patient-tooltip{position:fixed;transform:translate(-50%);background:#fff;border-radius:.75rem;box-shadow:0 10px 40px #00000026;border:1px solid #e5e7eb;width:320px;z-index:10000;animation:fadeIn .2s ease-out;pointer-events:none}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.patient-tooltip-loading,.patient-tooltip-error{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}.patient-tooltip-error{color:#ef4444}.patient-tooltip-header{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#f9fafb,#fff);border-radius:.75rem .75rem 0 0}.patient-tooltip-avatar{width:56px;height:56px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid #e5e7eb}.patient-tooltip-avatar img{width:100%;height:100%;object-fit:cover}.patient-tooltip-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:1.25rem}.patient-tooltip-info{flex:1;min-width:0}.patient-tooltip-name{font-weight:600;font-size:.9375rem;color:#1f2937;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.patient-tooltip-card{font-size:.8125rem;color:#6b7280}.patient-tooltip-body{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.patient-tooltip-item{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem}.patient-tooltip-label{font-weight:500;color:#6b7280;font-size:.8125rem}.patient-tooltip-value{color:#1f2937}.patient-tooltip-appointments{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.patient-tooltip-appointment{display:flex;flex-direction:column;gap:.125rem;padding:.5rem .625rem;background:linear-gradient(135deg,#dbeafe,#e0e7ff);border-radius:.5rem;border-left:3px solid #3b82f6;font-size:.8125rem}.patient-tooltip-appointment-date{font-weight:600;color:#1e40af}.patient-tooltip-appointment-doctor{color:#3730a3;font-size:.75rem}.patient-tooltip-diagnoses{margin:0;padding-left:1.25rem;color:#1f2937}.patient-tooltip-diagnoses li{margin-bottom:.25rem;line-height:1.4}.patient-tooltip-diagnoses li:last-child{margin-bottom:0}.skeleton{background:linear-gradient(90deg,#f0f0f0,#e0e0e0 20%,#f0f0f0 40% 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--text{height:1em;margin-bottom:.5rem}.skeleton--circular{border-radius:50%}.skeleton--rectangular{border-radius:4px}.skeleton-users-list{padding:.5rem 0}.skeleton-user-item{display:flex;align-items:center;padding:.75rem 1rem;gap:.75rem;border-bottom:1px solid #e5e7eb}.skeleton-user-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.skeleton-messages-list{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.skeleton-message{display:flex;gap:.75rem;max-width:70%}.skeleton-message.incoming{align-self:flex-start}.skeleton-message.outgoing{align-self:flex-end;flex-direction:row-reverse}.skeleton-message-bubble{flex:1;display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;background:#00000008;border-radius:1rem}.skeleton-message.incoming .skeleton-message-bubble{border-bottom-left-radius:.25rem}.skeleton-message.outgoing .skeleton-message-bubble{border-bottom-right-radius:.25rem}.skeleton-message-time{align-self:flex-end;margin-top:.25rem}.messages-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.messages-modal-content{background:#fff;border-radius:8px;width:90%;max-width:1200px;height:80vh;max-height:800px;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.messages-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.messages-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#1f2937}.messages-modal-header-actions{display:flex;align-items:center;gap:.75rem}.messages-broadcast-header-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.messages-broadcast-header-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6d28d94d}.messages-broadcast-header-btn.active{background:linear-gradient(135deg,#7c3aed,#5b21b6);box-shadow:inset 0 2px 4px #0003;transform:none}.messages-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.messages-modal-close:hover{color:#1f2937}.messages-broadcast-panel{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-bottom:1px solid #c4b5fd;padding:0}.messages-broadcast-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#8b5cf61a;border-bottom:1px solid rgba(139,92,246,.2)}.messages-broadcast-panel-header h3{margin:0;font-size:.9375rem;font-weight:600;color:#5b21b6}.messages-broadcast-panel-close{background:none;border:none;font-size:1.125rem;color:#7c3aed;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s;border-radius:.25rem}.messages-broadcast-panel-close:hover{background:#8b5cf633}.messages-broadcast-panel-body{padding:1rem}.messages-broadcast-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.messages-broadcast-priority{display:flex;align-items:center;gap:.625rem}.messages-broadcast-formatting{display:flex;align-items:center;gap:.25rem}.messages-format-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:all .2s;color:#4b5563}.messages-format-btn:hover{background:#f3f4f6;border-color:#9ca3af}.messages-format-btn.active{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.messages-broadcast-animated-label{display:flex;align-items:center;gap:.375rem;cursor:pointer;font-size:.875rem;color:#4b5563;-webkit-user-select:none;user-select:none}.messages-broadcast-animated-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#8b5cf6}.messages-broadcast-priority label{font-size:.875rem;font-weight:500;color:#4b5563}.messages-broadcast-priority select{padding:.375rem .625rem;border:1px solid #c4b5fd;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;outline:none;transition:border-color .2s}.messages-broadcast-priority select:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.messages-broadcast-warning{padding:.5rem .75rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:.375rem;font-size:.8125rem;color:#92400e;margin-bottom:.75rem}.messages-broadcast-textarea{width:100%;padding:.75rem;border:1px solid #c4b5fd;border-radius:.5rem;font-size:.875rem;resize:vertical;min-height:80px;outline:none;transition:border-color .2s;box-sizing:border-box}.messages-broadcast-textarea:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.messages-broadcast-actions{display:flex;justify-content:flex-end;gap:.625rem;margin-top:.75rem}.messages-broadcast-cancel-btn{padding:.5rem 1rem;background:#fff;color:#6b7280;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.messages-broadcast-cancel-btn:hover{background:#f3f4f6;border-color:#9ca3af}.messages-broadcast-send-btn{padding:.5rem 1rem;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.messages-broadcast-send-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6d28d94d}.messages-broadcast-send-btn:disabled{opacity:.6;cursor:not-allowed}.messages-modal-body{flex:1;display:flex;overflow:hidden}.messages-users-list{width:300px;min-width:200px;max-width:500px;border-right:1px solid #e5e7eb;overflow-y:auto;background:#f9fafb;display:flex;flex-direction:column;flex-shrink:0}.messages-users-resizer{width:4px;cursor:col-resize;background:transparent;transition:background-color .2s;flex-shrink:0}.messages-users-resizer:hover,.messages-users-resizer.active{background:#3b82f6}.messages-search-section{padding:1rem;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.messages-search-input-wrapper{position:relative;margin-bottom:.75rem}.messages-search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.messages-search-input{width:100%;padding:.5rem 2.5rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;outline:none;transition:border-color .2s}.messages-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.messages-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#9ca3af;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.messages-search-clear:hover{background:#f3f4f6;color:#6b7280}.messages-filter-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none}.messages-filter-checkbox input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:#3b82f6}.messages-filter-checkbox:hover span{color:#1f2937}.messages-users-list-scroll{flex:1;overflow-y:auto}.messages-user-item{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #e5e7eb;position:relative}.messages-user-item:hover{background-color:#f3f4f6}.messages-user-item.active{background-color:#eff6ff;border-left:3px solid #3b82f6}.messages-user-avatar{width:48px;height:48px;border-radius:50%;margin-right:.75rem;overflow:visible;flex-shrink:0;position:relative}.messages-user-avatar img,.messages-user-avatar .messages-user-avatar-placeholder{border-radius:50%;overflow:hidden}.messages-user-avatar img{width:100%;height:100%;object-fit:cover}.messages-user-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:1.25rem;text-transform:uppercase}.messages-online-indicator{position:absolute;bottom:1px;right:1px;width:12px;height:12px;background:#22c55e;border:2px solid white;border-radius:50%;z-index:1;box-shadow:0 0 4px #22c55e80}.messages-user-info{flex:1;min-width:0}.messages-user-name{font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-user-role{font-size:.875rem;color:#6b7280;margin-top:.125rem}.messages-unread-badge{background:#ef4444;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;margin-left:.5rem;flex-shrink:0}.messages-chat-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.messages-chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:#6b7280;font-size:1.125rem}.messages-chat-header{display:flex;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background:#fff;flex-shrink:0}.messages-chat-user-avatar{width:48px;height:48px;border-radius:50%;margin-right:1rem;overflow:visible;flex-shrink:0;position:relative}.messages-chat-user-avatar img,.messages-chat-user-avatar .messages-user-avatar-placeholder{border-radius:50%;overflow:hidden}.messages-chat-user-avatar img{width:100%;height:100%;object-fit:cover}.messages-chat-user-info{flex:1;min-width:0}.messages-chat-user-name{font-weight:600;color:#1f2937;font-size:1.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-chat-user-role{font-size:.875rem;color:#6b7280;margin-top:.125rem;display:flex;align-items:center;gap:.75rem}.messages-user-status{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem}.messages-user-status.online{color:#22c55e;font-weight:500}.messages-user-status.offline{color:#9ca3af}.messages-status-dot{display:inline-block;width:8px;height:8px;background:#22c55e;border-radius:50%;flex-shrink:0}.messages-chat-actions{display:flex;gap:.5rem;margin-left:1rem;flex-shrink:0}.messages-chat-action-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:.5rem;background:#f3f4f6;color:#6b7280;cursor:pointer;transition:all .2s}.messages-chat-action-btn:hover:not(:disabled){background:#e5e7eb;color:#374151}.messages-chat-action-btn:disabled{opacity:.5;cursor:not-allowed}.messages-chat-action-btn--danger:hover:not(:disabled){background:#fef2f2;color:#ef4444}.messages-chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem;background:#f9fafb}.messages-date-separator{text-align:center;color:#6b7280;font-size:.875rem;margin:1rem 0;position:relative}.messages-date-separator:before,.messages-date-separator:after{content:"";position:absolute;top:50%;width:calc(50% - 60px);height:1px;background:#e5e7eb}.messages-date-separator:before{left:0}.messages-date-separator:after{right:0}.messages-chat-message{display:flex;flex-direction:column;margin-bottom:.75rem;max-width:70%;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.messages-chat-message.incoming{align-items:flex-start}.messages-chat-message.outgoing{align-items:flex-end;margin-left:auto}.messages-chat-message.incoming.unread-pulse .messages-chat-message-content{animation:unreadPulse .75s ease-in-out 4}@keyframes unreadPulse{0%,to{box-shadow:0 0 #ef444400;transform:scale(1)}50%{box-shadow:0 0 0 4px #ef444466,0 0 25px #ef444459,0 0 45px #ef444440;transform:scale(1.015)}}.messages-chat-message-content{padding:.5rem .75rem;border-radius:.75rem;word-wrap:break-word;white-space:pre-wrap}.messages-chat-message.incoming .messages-chat-message-content{background:#fff;color:#1f2937;border-bottom-left-radius:.25rem}.messages-chat-message.outgoing .messages-chat-message-content{background:#3b82f6;color:#fff;border-bottom-right-radius:.25rem}.messages-chat-message-content.emoji-only{background:transparent!important;padding:.25rem}.messages-chat-message-content.emoji-only span{font-size:2.5rem;line-height:1.2}.messages-chat-message-time{font-size:.75rem;color:#9ca3af;margin-top:.25rem;padding:0 .5rem;display:flex;align-items:center;gap:.25rem}.messages-read-indicator{color:#3b82f6;font-weight:700}.messages-delete-btn{position:absolute;top:4px;right:4px;display:none;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:50%;background:#0000001a;color:#ffffffb3;cursor:pointer;transition:all .2s}.messages-chat-message-content{position:relative}.messages-chat-message.outgoing .messages-chat-message-content{padding-right:24px}.messages-chat-message.outgoing .messages-chat-message-content:hover .messages-delete-btn{display:flex}.messages-delete-btn:hover{background:#ef4444e6;color:#fff}.messages-delete-btn:disabled{opacity:.5;cursor:not-allowed}.messages-chat-form{display:flex;align-items:flex-end;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#fff}.messages-chat-form-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.messages-chat-input{flex:1;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s;resize:none;overflow-y:auto;min-height:42px;max-height:150px;line-height:1.4;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.messages-chat-input::-webkit-scrollbar{width:6px}.messages-chat-input::-webkit-scrollbar-track{background:transparent}.messages-chat-input::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.messages-chat-input::-webkit-scrollbar-thumb:hover{background:#94a3b8}.messages-chat-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.messages-chat-input:disabled{background:#f3f4f6;cursor:not-allowed}.messages-chat-send-btn{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap;flex-shrink:0;align-self:flex-end;height:42px}.messages-chat-send-btn:hover:not(:disabled){background:#2563eb}.messages-chat-send-btn:disabled{background:#9ca3af;cursor:not-allowed}.messages-loading,.messages-empty{padding:2rem;text-align:center;color:#6b7280}.messages-context-menu{position:fixed;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.5rem 0;z-index:1100;min-width:180px}.messages-context-menu button{display:block;width:100%;padding:.5rem 1rem;text-align:left;border:none;background:none;cursor:pointer;font-size:.875rem;color:#374151;transition:background-color .2s}.messages-context-menu button:hover{background-color:#f3f4f6}.messages-muted-icon{font-size:.875rem;margin-left:.25rem;opacity:.6}.messages-user-item.muted{opacity:.7}.messages-user-item.root-user .messages-user-avatar-placeholder{background:linear-gradient(135deg,#ef4444,#dc2626)}.messages-users-separator{display:flex;align-items:center;padding:.75rem 1rem;margin:.5rem 0;position:relative}.messages-users-separator:before,.messages-users-separator:after{content:"";flex:1;height:1px;background:#d1d5db}.messages-users-separator span{padding:0 .75rem;font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.messages-emoji-wrapper{position:relative}.messages-emoji-picker{position:absolute;bottom:100%;left:0;margin-bottom:8px;z-index:1000}.messages-btn-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:background-color .2s}.messages-btn-icon:hover:not(:disabled){background-color:#f3f4f6}.messages-btn-icon:disabled{opacity:.5;cursor:not-allowed}.messages-attachments-preview{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.messages-attachment-preview{position:relative;display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fff;border-radius:.5rem;border:1px solid #e5e7eb}.messages-attachment-preview img{width:48px;height:48px;object-fit:cover;border-radius:.25rem}.messages-attachment-preview span{font-size:.875rem;color:#374151;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messages-attachment-remove{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:#ef4444;color:#fff;border:none;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;line-height:1}.messages-attachment-remove:hover{background:#dc2626}.messages-attachments,.messages-attachment{margin-top:.25rem}.messages-attachment-image-wrapper{position:relative;display:inline-block}.messages-attachment-image{max-width:280px;max-height:280px;border-radius:.375rem;cursor:pointer;transition:opacity .2s;display:block}.messages-attachment-image:hover{opacity:.9}.messages-attachment-download{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;transition:all .2s;flex-shrink:0}.messages-attachment-download:hover{background:#000c;transform:scale(1.1)}.messages-attachment-image-wrapper .messages-attachment-download{position:absolute;bottom:4px;right:4px;opacity:0}.messages-attachment-image-wrapper:hover .messages-attachment-download{opacity:1}.messages-attachment-file-wrapper{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff3;border-radius:.5rem;min-width:180px;max-width:100%}.messages-chat-message.incoming .messages-attachment-file-wrapper{background:#f3f4f6}.messages-attachment-file-icon{flex-shrink:0;opacity:.7}.messages-attachment-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.messages-attachment-file-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-attachment-file-size{font-size:.75rem;opacity:.7}.messages-attachment-file-wrapper .messages-attachment-download{background:#3b82f6cc}.messages-attachment-file-wrapper .messages-attachment-download:hover{background:#3b82f6}.messages-chat-message.incoming .messages-attachment-file-wrapper .messages-attachment-download{background:#6b7280cc}.messages-chat-message.incoming .messages-attachment-file-wrapper .messages-attachment-download:hover{background:#6b7280}.messages-read-indicator{cursor:help;transition:color .2s}.messages-read-indicator:hover{color:#2563eb}.messages-patient-picker-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1200;border-radius:.75rem}.messages-patient-picker{background:#fff;border-radius:.75rem;width:400px;max-height:500px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;overflow:hidden}.messages-patient-picker-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.messages-patient-picker-header h3{margin:0;font-size:1rem;font-weight:600;color:#1f2937}.messages-patient-picker-header button{background:none;border:none;font-size:1.25rem;cursor:pointer;color:#6b7280;padding:.25rem;border-radius:.25rem;transition:background-color .2s}.messages-patient-picker-header button:hover{background:#f3f4f6;color:#1f2937}.messages-patient-picker-search{padding:.75rem 1.25rem;border-bottom:1px solid #e5e7eb}.messages-patient-picker-search input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;outline:none;transition:border-color .2s;box-sizing:border-box}.messages-patient-picker-search input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.messages-patient-picker-list{flex:1;overflow-y:auto;padding:.5rem 0}.messages-patient-picker-list .messages-loading,.messages-patient-picker-list .messages-empty{padding:1.5rem;font-size:.875rem}.messages-patient-picker-item{display:flex;flex-direction:column;gap:.125rem;padding:.625rem 1.25rem;cursor:pointer;transition:background-color .15s}.messages-patient-picker-item:hover{background:#f3f4f6}.messages-patient-picker-name{font-size:.875rem;font-weight:500;color:#1f2937}.messages-patient-picker-card{font-size:.75rem;color:#6b7280}.messages-patient-chips{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1.5rem 0;background:#fff}.messages-patient-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:1rem;font-size:.875rem;font-weight:500;line-height:1.2;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #3b82f633;transition:all .2s}.messages-patient-chip:hover{box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.messages-patient-chip svg{flex-shrink:0;opacity:.9}.messages-patient-chip-name{flex-shrink:0}.messages-patient-chip-card{opacity:.85;font-size:.8125rem;font-weight:400}.messages-patient-chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:.125rem;padding:0;border:none;background:#fff3;color:#fff;border-radius:50%;font-size:.75rem;line-height:1;cursor:pointer;transition:all .2s;flex-shrink:0}.messages-patient-chip-remove:hover{background:#ffffff4d;transform:scale(1.1)}.messages-patient-link{display:inline-flex;align-items:center;gap:.25rem;color:inherit;text-decoration:none;font-weight:500;cursor:pointer;border-bottom:1px dashed currentColor;padding:2px 0;margin:2px 0;transition:opacity .2s}.messages-patient-link:hover{opacity:.8}.messages-patient-link svg{flex-shrink:0}.messages-chat-message.outgoing .messages-patient-link{color:#fff}.messages-chat-message.incoming .messages-patient-link{color:#3b82f6}.messages-chat-message.priority-critical .messages-chat-message-content{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important;border:none}.messages-chat-message.priority-important .messages-chat-message-content{background:linear-gradient(135deg,#f59e0b,#d97706)!important;color:#fff!important;border:none}.messages-chat-message.priority-standard.is-broadcast .messages-chat-message-content{background:linear-gradient(135deg,#22c55e,#16a34a)!important;color:#fff!important;border:none}.messages-priority-label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:.25rem .5rem;border-radius:.25rem;margin-bottom:.5rem;text-align:center;border:1.5px solid currentColor;background:transparent}.messages-priority-label.critical{color:#fef2f2;border-color:#ffffffb3}.messages-priority-label.important{color:#fefce8;border-color:#ffffffb3}.messages-priority-label.standard{color:#f0fdf4;border-color:#ffffffb3}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.messages-chat-message.animated-gradient .messages-chat-message-content{background-size:200% 200%!important;animation:gradientShift 3s ease infinite}.messages-chat-message.animated-gradient.priority-critical .messages-chat-message-content{background:linear-gradient(135deg,#ef4444,#dc2626,#b91c1c,#dc2626,#ef4444)!important;background-size:400% 400%!important}.messages-chat-message.animated-gradient.priority-important .messages-chat-message-content{background:linear-gradient(135deg,#f59e0b,#d97706,#b45309,#d97706,#f59e0b)!important;background-size:400% 400%!important}.messages-chat-message.animated-gradient.priority-standard.is-broadcast .messages-chat-message-content{background:linear-gradient(135deg,#22c55e,#16a34a,#15803d,#16a34a,#22c55e)!important;background-size:400% 400%!important}.messages-chat-message.animated-gradient.outgoing:not(.priority-critical):not(.priority-important):not(.is-broadcast) .messages-chat-message-content{background:linear-gradient(135deg,#3b82f6,#2563eb,#1d4ed8,#2563eb,#3b82f6)!important;background-size:400% 400%!important}.messages-acknowledge-btn{display:inline-flex;align-items:center;gap:.25rem;margin-top:.5rem;padding:.375rem .625rem;border:none;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.messages-chat-message.priority-critical .messages-acknowledge-btn{background:#ef4444;color:#fff}.messages-chat-message.priority-critical .messages-acknowledge-btn:hover{background:#dc2626}.messages-chat-message.priority-important .messages-acknowledge-btn{background:#f59e0b;color:#fff}.messages-chat-message.priority-important .messages-acknowledge-btn:hover{background:#d97706}.messages-acknowledge-btn:disabled{opacity:.6;cursor:not-allowed}.messages-acknowledged-info{display:flex;align-items:center;gap:.25rem;margin-top:.375rem;font-size:.6875rem;opacity:.8}.messages-acknowledged-info svg{color:#22c55e}.messages-priority-selector{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.messages-priority-selector label{font-size:.8125rem;font-weight:500;color:#4b5563}.messages-priority-selector select{padding:.375rem .625rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.8125rem;background:#fff;cursor:pointer;outline:none;transition:border-color .2s}.messages-priority-selector select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.messages-broadcast-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;border:none;border-radius:.375rem;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s}.messages-broadcast-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6d28d94d}.messages-broadcast-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.messages-acknowledgment-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000}.messages-acknowledgment-modal{background:#fff;border-radius:.75rem;width:420px;max-width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.messages-acknowledgment-modal.critical{border-top:4px solid #ef4444}.messages-acknowledgment-modal.important{border-top:4px solid #f59e0b}.messages-acknowledgment-modal.animated{animation:modalPulse 2s ease-in-out infinite}@keyframes modalPulse{0%,to{box-shadow:0 20px 60px #0000004d}50%{box-shadow:0 20px 60px #ef444480,0 0 30px #ef44444d}}.messages-acknowledgment-modal.animated.important{animation:modalPulseImportant 2s ease-in-out infinite}@keyframes modalPulseImportant{0%,to{box-shadow:0 20px 60px #0000004d}50%{box-shadow:0 20px 60px #f59e0b80,0 0 30px #f59e0b4d}}.messages-acknowledgment-modal-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.messages-acknowledgment-modal-header.critical{background:#fef2f2}.messages-acknowledgment-modal-header.important{background:#fffbeb}.messages-acknowledgment-modal-header svg{flex-shrink:0}.messages-acknowledgment-modal-header.critical svg{color:#ef4444}.messages-acknowledgment-modal-header.important svg{color:#f59e0b}.messages-acknowledgment-modal-header h3{flex:1;margin:0;font-size:1rem;font-weight:600}.messages-acknowledgment-modal-header.critical h3{color:#dc2626}.messages-acknowledgment-modal-header.important h3{color:#b45309}.messages-acknowledgment-modal-body{padding:1.25rem;overflow-y:auto}.messages-acknowledgment-modal-sender{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;color:#6b7280}.messages-acknowledgment-modal-sender strong{color:#1f2937}.messages-acknowledgment-modal-text{font-size:.9375rem;line-height:1.6;color:#1f2937;white-space:pre-wrap}.messages-acknowledgment-modal-time{margin-top:1rem;font-size:.75rem;color:#9ca3af}.messages-acknowledgment-modal-footer{padding:1rem 1.25rem;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.messages-acknowledgment-modal-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.messages-acknowledgment-modal-btn.critical{background:#ef4444;color:#fff}.messages-acknowledgment-modal-btn.critical:hover{background:#dc2626}.messages-acknowledgment-modal-btn.important{background:#f59e0b;color:#fff}.messages-acknowledgment-modal-btn.important:hover{background:#d97706}.messages-acknowledgment-modal-btn:disabled{opacity:.6;cursor:not-allowed}.messages-acknowledgment-stack{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem}.messages-acknowledgment-counter{animation:slideDown .3s ease-out}.messages-acknowledgment-counter-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#fffffff2,#ffffffd9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:2rem;font-size:.875rem;font-weight:600;color:#374151;box-shadow:0 4px 20px #00000026}.messages-acknowledgment-cards{position:relative;width:420px;max-width:90vw;height:auto;min-height:200px}.messages-acknowledgment-card{position:absolute;top:0;left:0;right:0;background:#fff;border-radius:1rem;box-shadow:0 10px 40px #0003;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);transform-origin:top center}.messages-acknowledgment-card.active{position:relative}.messages-acknowledgment-card.critical{border-left:4px solid #ef4444}.messages-acknowledgment-card.important{border-left:4px solid #f59e0b}.messages-acknowledgment-card.animated.critical{animation:cardPulseCritical 2s ease-in-out infinite}.messages-acknowledgment-card.animated.important{animation:cardPulseImportant 2s ease-in-out infinite}@keyframes cardPulseCritical{0%,to{box-shadow:0 10px 40px #0003}50%{box-shadow:0 10px 50px #ef444466,0 0 20px #ef444433}}@keyframes cardPulseImportant{0%,to{box-shadow:0 10px 40px #0003}50%{box-shadow:0 10px 50px #f59e0b66,0 0 20px #f59e0b33}}.messages-acknowledgment-card-header{display:flex;align-items:center;gap:.625rem;padding:.875rem 1rem;border-bottom:1px solid #e5e7eb}.messages-acknowledgment-card-header.critical{background:linear-gradient(135deg,#fef2f2,#fee2e2)}.messages-acknowledgment-card-header.important{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.messages-acknowledgment-card-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%}.messages-acknowledgment-card-header.critical .messages-acknowledgment-card-icon{background:#ef444426;color:#ef4444}.messages-acknowledgment-card-header.important .messages-acknowledgment-card-icon{background:#f59e0b26;color:#f59e0b}.messages-acknowledgment-card-header h4{flex:1;margin:0;font-size:.9375rem;font-weight:600}.messages-acknowledgment-card-header.critical h4{color:#dc2626}.messages-acknowledgment-card-header.important h4{color:#b45309}.messages-acknowledgment-card-time{font-size:.75rem;color:#9ca3af;font-weight:500}.messages-acknowledgment-card-body{padding:1rem;max-height:250px;overflow-y:auto}.messages-acknowledgment-card-sender{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8125rem;font-weight:500;color:#6b7280}.messages-acknowledgment-card-sender svg{color:#9ca3af}.messages-acknowledgment-card-text{font-size:.9375rem;line-height:1.6;color:#1f2937;white-space:pre-wrap}.messages-acknowledgment-card-footer{padding:.875rem 1rem;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.messages-acknowledgment-card-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.messages-acknowledgment-card-btn.critical{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.messages-acknowledgment-card-btn.critical:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.messages-acknowledgment-card-btn.important{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.messages-acknowledgment-card-btn.important:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b66}.messages-acknowledgment-card-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.messages-acknowledgment-more{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:1rem;font-size:.8125rem;font-weight:500;color:#6b7280;margin-top:.5rem}@media(max-width:768px){.messages-modal-content{width:95%;height:90vh}.messages-users-list{width:250px}.messages-chat-message{max-width:85%}.messages-emoji-picker{left:auto;right:0}}.photo-preview-overlay{position:fixed;inset:0;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:calc(var(--z-modal-backdrop) + 10);animation:fadeIn var(--transition-base);cursor:zoom-out}.photo-preview-content{display:flex;flex-direction:column;align-items:center;max-width:90vw;max-height:90vh;cursor:default;animation:zoomIn var(--transition-base)}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.photo-preview-close{position:absolute;top:var(--spacing-xl);right:var(--spacing-xl);background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:28px;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:1}.photo-preview-close:hover{background:#fff3;transform:scale(1.1)}.photo-preview-image{max-width:100%;max-height:calc(90vh - 80px);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);object-fit:contain;cursor:zoom-in}.photo-preview-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);margin-top:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);min-width:300px}.photo-preview-name{color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-preview-download{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--brand-primary);color:#fff;text-decoration:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.photo-preview-download:hover{background:var(--brand-primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.login-page{min-height:100vh;background:linear-gradient(135deg,#2a2a4e,#263156,#1f4470);background-attachment:fixed;display:flex;align-items:center;justify-content:center;padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;position:relative;overflow:hidden}.login-container{width:100%;max-width:400px}.login-card{background:#ffffffeb;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid rgba(200,200,220,.5);border-radius:16px;box-shadow:0 20px 60px #00000026,0 0 40px #7c5af00f;overflow:visible;animation:slideUp .4s ease-out;position:relative;z-index:10}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{background:linear-gradient(135deg,#7c5af0,#6b4dd1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:40px 24px 58px;text-align:center;border-bottom:1px solid rgba(124,90,240,.08);position:relative;border-radius:16px 16px 0 0;overflow:visible}.login-header-avatar{position:absolute;bottom:0;left:50%;transform:translate(-50%,50%);width:96px;height:96px;border-radius:50%;border:none;box-shadow:0 4px 16px #0003;overflow:hidden;background:#e8e4f4;z-index:20;transition:transform .3s ease}.login-header-avatar__img{width:100%;height:100%;object-fit:cover;display:block}.login-header-avatar__placeholder{width:100%;height:100%;background:linear-gradient(135deg,#9b7bf7,#7c5af0);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.login-header-avatar__empty{width:100%;height:100%;background:#e8e4f4;color:#b0a4d4;display:flex;align-items:center;justify-content:center}.login-header h1{margin:0;font-size:32px;font-weight:700;letter-spacing:-.5px}.login-header p{margin:8px 0 0;font-size:14px;opacity:.9;font-weight:500}.login-form{padding:56px 24px 32px}.form-group{margin-bottom:20px}.form-group:last-of-type{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px;letter-spacing:-.3px}.form-group input{width:100%;padding:12px 14px;border:1px solid #d0d0d8;border-radius:8px;font-size:15px;font-family:inherit;transition:all .3s ease;background-color:#f8f8fa;color:#333}.form-group input:focus{outline:none;border-color:#7c5af0;background-color:#fff;box-shadow:0 0 0 3px #7c5af026}.form-group input:disabled{background-color:#eee;color:#999;cursor:not-allowed;opacity:.6}.login-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#1a1a2ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(124,90,240,.3);border-radius:8px;box-shadow:0 8px 24px #0006;max-height:300px;overflow-y:auto;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.login-suggestion-item{padding:10px 14px;cursor:pointer;transition:background-color .15s ease;border-bottom:1px solid rgba(124,90,240,.1);display:flex;align-items:center;gap:10px}.login-suggestion-item:last-child{border-bottom:none}.login-suggestion-item:hover,.login-suggestion-item.selected{background-color:#7c5af033}.suggestion-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.suggestion-avatar--placeholder{background:linear-gradient(135deg,#7c5af0,#6b4dd1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600}.suggestion-text{min-width:0}.suggestion-fullname{font-size:15px;font-weight:600;color:#e0e0e0;margin-bottom:1px}.suggestion-username{font-size:12px;color:#a0a0a0}.login-selected-user{display:flex;align-items:center;gap:10px;margin-top:8px;padding:10px 12px;background:#7c5af014;border:1px solid rgba(124,90,240,.2);border-radius:8px}.login-selected-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}.login-selected-avatar--placeholder{background:linear-gradient(135deg,#7c5af0,#6b4dd1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}.login-selected-info{flex:1;min-width:0}.login-selected-name{font-size:14px;font-weight:600;color:#333}.login-selected-username{font-size:12px;color:#888}.login-selected-clear{background:none;border:none;color:#999;cursor:pointer;font-size:16px;padding:4px 6px;border-radius:4px;transition:all .15s;line-height:1}.login-selected-clear:hover{background:#00000014;color:#666}.error-message{background-color:#d32f2f26;color:#ff6b6b;padding:12px 14px;border-radius:8px;font-size:14px;margin-bottom:20px;border-left:4px solid #ff6b6b;animation:slideDown .3s ease-out}.login-button{width:100%;padding:12px 16px;background:linear-gradient(135deg,#7c5af0,#6b4dd1);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 20px #7c5af066;letter-spacing:-.3px}.login-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 30px #7c5af099}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.8;cursor:not-allowed}.login-footer{background-color:#f5f5f8;padding:20px 24px;border-top:1px solid #e0e0e8;text-align:center;border-radius:0 0 16px 16px}.login-footer .hint{margin:0 0 12px;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.credentials-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.credentials-list li{font-size:13px;color:#555;padding:8px 12px;background-color:#eeeef4;border-radius:6px;border-left:3px solid #7c5af0;font-family:Courier New,monospace}.credentials-list strong{color:#7c5af0;font-weight:600}.login-welcome-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;animation:welcomeFadeIn .5s ease-out}.login-welcome-card{text-align:center;animation:welcomeScale .5s ease-out}.login-welcome-avatar{width:100px;height:100px;border-radius:50%;object-fit:cover;margin:0 auto 20px;display:block;box-shadow:0 8px 30px #7c5af066}.login-welcome-avatar--placeholder{background:linear-gradient(135deg,#9b7bf7,#7c5af0);color:#fff;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700}.login-welcome-text{font-size:24px;font-weight:700;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);letter-spacing:-.3px}@keyframes welcomeFadeIn{0%{opacity:0}to{opacity:1}}@keyframes welcomeScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(max-width:480px){.login-card{border-radius:12px}.login-header{padding:32px 20px}.login-header h1{font-size:28px}.login-form{padding:24px 20px}.form-group{margin-bottom:16px}.login-footer{padding:16px 20px}}@media(prefers-color-scheme:dark){.login-card{background-color:#1e1e1e}.login-header{background:linear-gradient(135deg,#667eea,#764ba2)}.login-form{background-color:#1e1e1e}.form-group label{color:#e0e0e0}.form-group input{background-color:#2a2a2a;border-color:#3a3a3a;color:#e0e0e0}.form-group input:focus{background-color:#333;border-color:#667eea}.login-footer{background-color:#252525;border-top-color:#3a3a3a}.login-footer .hint{color:#999}.credentials-list li{background-color:#2a2a2a;color:#aaa;border-left-color:#667eea}.credentials-list strong{color:#667eea}}.dashboard-page{display:flex;flex-direction:column;min-height:100%;width:100%;margin:0;padding:0 16px}.dashboard-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:16px;flex-shrink:0}.dashboard-toolbar{display:flex;gap:12px;flex-wrap:wrap;padding:12px;background:#f8f9fa;border-radius:12px;margin-bottom:16px;box-shadow:0 1px 3px #0000000d;flex-shrink:0}.dashboard-title{margin:0;font-size:32px;font-weight:700;color:#333}.dashboard-subtitle{margin:4px 0 0;font-size:14px;color:#999;text-transform:capitalize}.dashboard-role-badge{display:inline-block;padding:4px 12px;border:2px solid currentColor;border-radius:8px;font-size:28px;font-weight:600;background-color:#fffc;transition:transform .2s ease,box-shadow .2s ease}.dashboard-role-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.dashboard-datetime{display:flex;flex-direction:row;align-items:center;gap:6px;padding:8px 14px;border:2px solid #667eea;border-radius:12px;background-color:#f8f9ff;max-width:280px;animation:datetime-pulse-normal 2s ease-in-out infinite;cursor:default;-webkit-user-select:none;user-select:none}@keyframes datetime-pulse-normal{0%,to{box-shadow:0 0 #667eea66}50%{box-shadow:0 0 0 6px #667eea00}}@keyframes datetime-pulse-warning{0%,to{box-shadow:0 0 #f59e0b80}50%{box-shadow:0 0 0 8px #f59e0b00}}@keyframes datetime-pulse-danger{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 8px #ef444400}}.dashboard-datetime--normal{border-color:#667eea;animation:datetime-pulse-normal 2s ease-in-out infinite}.dashboard-datetime--warning{border-color:#f59e0b;background-color:#fffbeb;animation:datetime-pulse-warning 1.5s ease-in-out infinite}.dashboard-datetime--danger{border-color:#ef4444;background-color:#fef2f2;animation:datetime-pulse-danger 1s ease-in-out infinite}.dashboard-datetime:hover{transform:scale(1.02)}.dashboard-date{font-size:15px;color:#666;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-time{font-size:22px;font-weight:700;color:#333;letter-spacing:.5px;font-family:inherit;flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .3s}.stat-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-icon{font-size:36px;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-label{font-size:13px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.stat-value{font-size:32px;font-weight:700;color:#333;line-height:1}.stat-percent{font-size:14px;font-weight:600;color:#4caf50;margin-top:4px}.stat-link{position:absolute;bottom:12px;right:16px;font-size:12px;color:#667eea;text-decoration:none;font-weight:600;transition:color .2s}.stat-link:hover{color:#5568d3}.stat-total{border-left:4px solid #667eea}.stat-completed{border-left:4px solid #4caf50}.stat-in-progress{border-left:4px solid #9c27b0}.stat-confirmed{border-left:4px solid #2196f3}.stat-pending{border-left:4px solid #ff9800}.stat-patients{border-left:4px solid #00bcd4}.unpaid-invoices-section{box-shadow:0 2px 8px #0a0a0a08;transition:transform .15s ease,box-shadow .15s ease;border-left:4px solid #f59e0b}.unpaid-invoices-section:hover{box-shadow:0 6px 18px #f59e0b26;transform:translateY(-2px)}.summary-section{margin-bottom:16px;flex-shrink:0}.summary-title{margin:0 0 12px;font-size:18px;font-weight:600;color:#333}.summary-items{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}.summary-item{background:#fff;border:1px solid #e8e8ef;border-radius:8px;padding:8px 10px;display:flex;flex-direction:column;justify-content:space-between;min-width:140px;min-height:85px;flex:1 1 160px;box-shadow:0 1px 3px #0a0a0a0d;transition:transform .15s ease,box-shadow .15s ease;position:relative}.summary-item:hover{transform:translateY(-3px);box-shadow:0 10px 24px #00000014;cursor:pointer}.summary-completed{border-left:4px solid #4caf50;border-top:3px solid #4caf50}.summary-inprogress{border-left:4px solid #9c27b0;border-top:3px solid #9c27b0}.summary-confirmed{border-left:4px solid #2196f3;border-top:3px solid #2196f3}.summary-pending{border-left:4px solid #ff9800;border-top:3px solid #ff9800}.summary-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#3b3b3b}.summary-bar{height:4px;background:#f3f4f6;border-radius:999px;overflow:hidden;margin-top:4px}.bar-fill{height:100%;border-radius:inherit;transition:width .2s ease}.bar-fill.completed{background-color:#4caf50}.bar-fill.in-progress{background-color:#9c27b0}.bar-fill.confirmed{background-color:#2196f3}.bar-fill.pending{background-color:#ff9800}.summary-row{display:flex;justify-content:space-between;align-items:center;gap:4px;margin-bottom:4px}.summary-empty-message{font-size:13px;color:#9ca3af;font-style:italic;margin-top:4px}.summary-number{font-size:16px;font-weight:700;color:#222}.summary-percent{font-size:11px;color:#666;font-weight:500}.appointment-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px;cursor:grab;transition:all .2s}.appointment-card:active{cursor:grabbing;opacity:.7}.appointment-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.appointment-time{font-size:16px;font-weight:700;color:#667eea;margin-bottom:8px}.appointment-patient{font-size:14px;font-weight:600;color:#333;margin-bottom:4px}.appointment-doctor{font-size:12px;color:#999;margin-bottom:8px}.appointment-reason{font-size:12px;color:#666;background-color:#f9f9f9;padding:6px 8px;border-radius:4px;margin-top:8px}.quick-actions{display:flex;gap:16px;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;text-decoration:none;font-size:14px;font-weight:600;transition:all .2s ease;white-space:nowrap;min-height:36px}.action-icon{font-size:18px;flex-shrink:0}.action-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea59}.action-primary:hover{box-shadow:0 6px 18px #667eea80;transform:translateY(-1px)}.action-secondary{background:#fff;color:#667eea;border:1px solid #667eea}.action-secondary:hover{background-color:#667eea;color:#fff;transform:translateY(-1px)}.action-refresh{background:#fff;color:#10b981;border:1px solid #10b981}.action-refresh:hover{background-color:#10b981;color:#fff;transform:translateY(-1px)}.action-new-appointment,a.action-new-appointment,a.action-new-appointment:visited,a.action-new-appointment:link{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b98159;text-decoration:none}.action-new-appointment:hover,a.action-new-appointment:hover{box-shadow:0 6px 18px #10b98180;transform:translateY(-1px);text-decoration:none}.new-appointment-dropdown-wrapper{position:relative}.dropdown-chevron{margin-left:2px;opacity:.7;transition:transform .2s ease}.new-appointment-dropdown-wrapper:hover .dropdown-chevron{transform:rotate(180deg)}.new-appointment-dropdown{position:absolute;top:100%;left:0;margin-top:4px;min-width:200px;background:#fff;border-radius:10px;box-shadow:0 8px 24px #0000001f,0 2px 8px #0000000f;border:1px solid #e5e7eb;padding:6px 0;z-index:1000;animation:dropdown-appear .15s ease-out}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.new-appointment-dropdown__item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 14px;border:none;background:none;font-size:14px;font-weight:500;color:#374151;cursor:pointer;white-space:nowrap;transition:background-color .12s ease;position:relative;text-align:left}.new-appointment-dropdown__item:hover{background-color:#f3f4f6;color:#111827}.new-appointment-dropdown__item--has-submenu{padding-right:10px}.new-appointment-dropdown__item--has-submenu .submenu-arrow{margin-left:auto;opacity:.5;flex-shrink:0}.new-appointment-dropdown__item--disabled{color:#9ca3af;cursor:default;font-style:italic}.new-appointment-dropdown__item--disabled:hover{background:none}.new-appointment-dropdown__divider{height:1px;background-color:#e5e7eb;margin:4px 8px}.new-appointment-dropdown__submenu{position:absolute;left:100%;top:-6px;margin-left:4px;min-width:200px;max-height:320px;overflow-y:auto;background:#fff;border-radius:10px;box-shadow:0 8px 24px #0000001f,0 2px 8px #0000000f;border:1px solid #e5e7eb;padding:6px 0;z-index:1001;animation:dropdown-appear .15s ease-out}.new-appointment-dropdown__submenu .new-appointment-dropdown__item:hover{background-color:#ecfdf5;color:#059669}.action-close-day{background:#fff;color:#dc2626;border:1px solid #fecaca}.action-close-day:hover{background-color:#dc2626;color:#fff;transform:translateY(-1px)}.action-close-day:disabled{color:#d1d5db;border-color:#e5e7eb;cursor:not-allowed}.action-close-day:disabled:hover{background-color:#fff;color:#d1d5db;transform:none}.toolbar-btn-wrapper{display:contents}.toolbar-btn-editable{display:inline-flex;border-radius:10px;cursor:grab;position:relative;outline:2px dashed transparent;outline-offset:2px;transition:outline-color .2s ease,opacity .2s ease,transform .15s ease}.toolbar-btn-editable:hover{outline-color:#667eea}.toolbar-btn-dragging{opacity:.4;transform:scale(.95)}.toolbar-btn-drag-over{outline-color:#10b981!important;outline-style:solid!important;transform:scale(1.03)}.dashboard-toolbar--edit{background:#eff6ff;border:2px dashed #667eea}.action-edit-toolbar{background:#fff;color:#9ca3af;border:1px solid #e5e7eb;padding:10px;margin-left:auto}.action-edit-toolbar:hover{color:#667eea;border-color:#667eea;transform:translateY(-1px)}.action-edit-toolbar--active{background:#667eea;color:#fff;border-color:#667eea}.action-edit-toolbar--active:hover{background:#5a6fd6;color:#fff;border-color:#5a6fd6}.summary-actions{display:flex;gap:8px;flex-wrap:nowrap;align-items:center;margin:8px 0 0;overflow-x:auto;padding-bottom:4px}.kanban-section{display:flex;flex-direction:column;flex:1}.kanban-title{margin:0 0 12px;font-size:24px;font-weight:700;color:#333;flex-shrink:0}.kanban-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;width:100%;flex:1}.kanban-column{background-color:#f5f5f5;border-radius:12px;overflow:hidden;min-height:400px;display:flex;flex-direction:column;transition:background-color .2s ease,box-shadow .2s ease}.kanban-column--drag-over{background-color:#e8eef7;box-shadow:0 0 0 3px #667eea33}.kanban-header{padding:10px 14px;color:#fff;display:flex;justify-content:space-between;align-items:center;font-weight:600}.kanban-header-title{font-size:12px;text-transform:uppercase;letter-spacing:.3px}.kanban-header-count{background-color:#ffffff4d;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700}.kanban-body{padding:12px;flex:1;display:flex;flex-direction:column;gap:12px;overflow-y:auto;overflow-x:hidden;min-height:0}.kanban-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;color:#999;font-size:14px}.kanban-filters{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin:0 0 12px;padding:12px;background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000000d;transition:box-shadow .2s ease;flex-shrink:0}.kanban-filters:hover{box-shadow:0 4px 12px #00000014}.kanban-filter{display:flex;align-items:center;gap:8px}.kanban-filter label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.3px}.kanban-filter select,.kanban-filter input[type=date]{height:36px;padding:6px 10px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;color:#333;background:#fff;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.kanban-filter select:hover,.kanban-filter input[type=date]:hover{border-color:#cfd5ff;background-color:#fafbff}.kanban-filter select:focus,.kanban-filter input[type=date]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.kanban-today-btn{padding:6px 12px;border-radius:6px;border:1px solid #667eea;background:#fff;color:#667eea;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-left:8px}.kanban-today-btn:hover{background:#667eea;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.date-nav-group{display:flex;gap:4px;align-items:center}.date-nav-btn{width:32px;height:36px;padding:0;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#6b7280;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.date-nav-btn:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.date-nav-btn:active{background:#e5e7eb}@media(max-width:1200px){.kanban-board{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.dashboard-toolbar{padding:10px}.action-btn{font-size:13px;padding:8px 12px}.summary-items{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-header-top{flex-direction:column;align-items:flex-start;gap:12px}.dashboard-datetime{width:100%;max-width:none}.kanban-board{grid-template-columns:1fr}}@media(max-width:720px){.summary-items{flex-direction:column}.summary-item{flex:1 1 auto;min-width:0}.kanban-filters{flex-direction:column;align-items:stretch}.kanban-filter,.kanban-filter input,.kanban-filter select{width:100%}}@media(max-width:480px){.dashboard-title{font-size:24px}.chart-card{padding:16px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stat-card,.kanban-column{animation:fadeIn .5s ease-out}.dashboard-footer{display:flex;justify-content:center;align-items:center;margin-top:auto;padding:24px;border-top:1px solid #e0e0e0;background-color:#fafafa;border-radius:12px;position:relative;gap:24px}.footer-content{display:flex;justify-content:center;flex:1}.footer-version{font-size:14px;color:#999;font-weight:500}.footer-menu{position:relative}.menu-button{padding:8px 12px;background-color:#f0f0f0;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:20px;color:#666;transition:all .2s;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.menu-button:hover{background-color:#667eea;color:#fff;border-color:#667eea;transform:scale(1.05)}.menu-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:200px;z-index:100;overflow:hidden;animation:slideDown .2s ease-out}.menu-item{display:block;width:100%;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;color:#333;cursor:pointer;transition:all .2s}.menu-item:hover{background-color:#f5f5f5;color:#667eea}.menu-item:active{background-color:#efefef}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.visit-feedback-container{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background-color:#f9fafb;border-radius:.5rem;border-left:3px solid #e5e7eb}.visit-feedback-badge{display:inline-flex;align-items:center;padding:.375rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;width:fit-content}.visit-feedback-badge--loading{background-color:#f3f4f6;color:#6b7280}.visit-feedback-badge--excellent{background-color:#d1fae5;color:#065f46;border-left-color:#10b981}.visit-feedback-badge--good{background-color:#dbeafe;color:#1e40af;border-left-color:#3b82f6}.visit-feedback-badge--average{background-color:#fef3c7;color:#92400e;border-left-color:#f59e0b}.visit-feedback-badge--poor{background-color:#fed7aa;color:#9a3412;border-left-color:#f97316}.visit-feedback-badge--bad{background-color:#fee2e2;color:#991b1b;border-left-color:#ef4444}.visit-feedback-comment{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background-color:#fff;border-radius:.375rem;border:1px solid #e5e7eb}.visit-feedback-comment__label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase}.visit-feedback-comment__text{font-size:.875rem;color:#1f2937;line-height:1.5;white-space:pre-wrap}.visit-feedback-source{font-size:.75rem;color:#9ca3af;font-style:italic}.patient-info-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.patient-info-stat-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:6px;transition:box-shadow .2s ease,transform .2s ease;position:relative;overflow:hidden}.patient-info-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .2s ease}.patient-info-stat-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-1px)}.patient-info-stat-card:hover:before{opacity:1}.patient-info-stat-header{display:flex;align-items:center;gap:8px}.patient-info-stat-icon{width:18px;height:18px;flex:0 0 18px;color:#6b7280}.patient-info-stat-label{font-size:12px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.patient-info-stat-value{font-size:18px;font-weight:700;color:#111827;line-height:1.2}.patient-info-stat-card--primary{border-left:4px solid #667eea}.patient-info-stat-card--secondary{border-left:4px solid #00bcd4}.patient-info-stat-card--muted{border-left:4px solid #9ca3af}.patient-registration-layout{display:flex;gap:16px;align-items:flex-start}.patient-photo-col{width:120px;flex:0 0 120px}.patient-photo{width:120px;height:120px;border-radius:12px;object-fit:cover;border:1px solid #e5e7eb;background:#fff}.patient-photo-placeholder{width:120px;height:120px;border-radius:12px;border:1px dashed #d1d5db;background:#f3f4f6;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:12px;text-align:center;padding:8px}.visit-row-hover:hover{background-color:#f0f9ff!important;transition:background-color .15s ease}.visit-row-hover:hover td{color:#1976d2}.schedule-time-select{width:60px;font-size:10px;padding:2px 4px;border:1px solid #d1d5db;borderRadius:6px;background-color:#fff;cursor:pointer;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.schedule-time-select:hover{border-color:#a5b4fc;box-shadow:0 0 0 3px #a5b4fc1a}.schedule-time-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.schedule-columns-select{padding:4px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;cursor:pointer;background-color:#fff;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.schedule-columns-select:hover{border-color:#a5b4fc;box-shadow:0 0 0 3px #a5b4fc1a}.schedule-columns-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.billing-page-container{width:100%;box-sizing:border-box;padding:16px}.billing-table-wrapper{width:100%;overflow:visible}.billing-table-wrapper table{width:100%;table-layout:auto}.billing-table-wrapper table th,.billing-table-wrapper table td{word-break:break-word;overflow-wrap:break-word}.billing-tabs-container{display:flex;gap:8px;border-bottom:1px solid #ccc;padding-bottom:8px;flex-wrap:wrap}.billing-tabs-container .tab{white-space:nowrap;font-size:13px}@media(max-width:768px){.billing-header-row{display:flex;flex-direction:column;gap:16px}.billing-filter-group,.billing-filter-row{display:flex;flex-direction:column;gap:8px}.billing-table-wrapper table{font-size:12px}.billing-table-wrapper table th,.billing-table-wrapper table td{padding:6px 4px!important;font-size:11px}.billing-table-col-doctor{display:none}}@media(max-width:600px){.billing-page-container{padding:10px}.billing-tabs-container .tab{font-size:11px;padding:6px 8px}.billing-group-header{flex-direction:column!important;gap:8px!important;padding:8px 10px!important}.billing-group-stats{display:grid!important;grid-template-columns:1fr 1fr!important;gap:6px!important;font-size:10px!important}.billing-group-stats span{word-break:break-word;white-space:normal}.billing-table-wrapper table th,.billing-table-wrapper table td{padding:4px 2px!important;font-size:10px}.billing-table-wrapper table th{font-weight:600}.billing-table-col-patient,.billing-table-col-doctor{display:none}.billing-form-grid-2,.billing-form-grid-3{grid-template-columns:1fr!important}.billing-form-box{padding:8px!important}.billing-form-box h4{font-size:11px;margin-bottom:6px!important}}.billing-invoice-detail{width:100%;overflow:visible}.billing-invoice-detail table{width:100%}.billing-status-badge{display:inline-block;white-space:nowrap}.billing-action-btn{white-space:nowrap}.billing-date-filters{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.billing-date-filters input[type=date]{min-width:120px}.billing-quick-filter-btn{transition:all .15s ease;border-radius:5px}.billing-quick-filter-btn:active{transform:scale(.98)}@media(max-width:768px){.billing-date-filters{gap:8px!important;padding:10px!important}.billing-date-filters input[type=date]{min-width:100px;font-size:11px;padding:4px 6px!important}.billing-quick-filter-btn{font-size:11px;padding:4px 8px!important}}@media(max-width:600px){.billing-date-filters{flex-direction:column;gap:6px!important}.billing-date-filters>div{width:100%;display:flex!important;flex-direction:column!important}.billing-date-filters>div>*{width:100%!important}.billing-quick-filter-btn{font-size:11px;padding:6px 8px!important;width:100%}.billing-date-filters input[type=date]{min-width:100%!important;font-size:11px}.billing-date-filters label{width:100%;flex-direction:column!important}.billing-date-filters label span{font-size:11px!important}.billing-date-filters button[onclick]{width:100%}}@keyframes billingTotalsFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.billing-totals-content{animation:billingTotalsFadeIn .35s ease-out}@keyframes billingChartReveal{0%{clip-path:circle(0% at 50% 50%)}to{clip-path:circle(100% at 50% 50%)}}.billing-chart-svg{animation:billingChartReveal .7s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes billingLegendItemIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.billing-legend-item{opacity:0;animation:billingLegendItemIn .3s ease-out forwards}.billing-legend-item:nth-child(1){animation-delay:.15s}.billing-legend-item:nth-child(2){animation-delay:.25s}.billing-legend-item:nth-child(3){animation-delay:.35s}.billing-legend-item:nth-child(4){animation-delay:.45s}.billing-legend-item:nth-child(5){animation-delay:.55s}.billing-legend-item:nth-child(6){animation-delay:.65s}.billing-legend-item:nth-child(7){animation-delay:.75s}@media print{body *{visibility:hidden}#invoice-to-print,#invoice-to-print *,#invoices-table-print,#invoices-table-print *,#invoices-totals-print,#invoices-totals-print *{visibility:visible}#invoices-totals-print{position:fixed;top:0;left:0;width:100%;padding:14px 24px!important;margin:0;box-sizing:border-box;-webkit-print-color-adjust:exact;print-color-adjust:exact;z-index:10}#invoices-table-print{position:fixed;top:60px;left:0;width:100%;margin:0;padding:0 24px 24px!important;border:none!important;box-shadow:none!important;background:#fff;box-sizing:border-box}#invoice-to-print{position:fixed;top:0;left:0;width:100%;margin:0;padding:24px!important;border:none!important;box-shadow:none!important;background:#fff;box-sizing:border-box;z-index:20}#invoice-to-print~#invoices-table-print,#invoice-to-print~#invoices-table-print *{visibility:hidden}#invoice-to-print button,#invoices-table-print button{display:none!important}#invoice-to-print table,#invoices-table-print table{width:100%;border-collapse:collapse;page-break-inside:auto;margin:12px 0}#invoice-to-print table th,#invoice-to-print table td,#invoices-table-print table th,#invoices-table-print table td{border:1px solid #d1d5db;padding:8px 12px;text-align:left;font-size:12px}#invoice-to-print table th,#invoices-table-print table th{background-color:#f3f4f6!important;font-weight:600;-webkit-print-color-adjust:exact;print-color-adjust:exact}#invoice-to-print table tr,#invoices-table-print table tr{page-break-inside:avoid}#invoice-to-print table tbody tr:nth-child(2n),#invoices-table-print table tbody tr:nth-child(2n){background-color:#f9fafb!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}#invoice-to-print h3,#invoice-to-print h4{page-break-after:avoid}#invoice-to-print div>div{page-break-inside:avoid}#invoices-table-print .billing-group-header{-webkit-print-color-adjust:exact;print-color-adjust:exact}.sidebar,.sidebar-resizer,.topbar{display:none!important}.appShell{display:block!important}.main{margin:0!important;padding:0!important;width:100%!important}#invoices-table-print table th:last-child,#invoices-table-print table td:last-child{display:none!important}}:root{--tab-color: #667eea}.users-list{width:100%}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.users-header h2{margin:0;font-size:24px;font-weight:600;color:#333}.users-header .btn{padding:8px 16px;font-size:14px}.roles-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.role-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;border:2px solid #ddd;border-radius:8px;background-color:#f9f9f9;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.role-tab:hover{border-color:var(--tab-color, #667eea);background-color:#667eea0d}.role-tab.active{background-color:var(--tab-color, #667eea);border-color:var(--tab-color, #667eea);color:#fff;box-shadow:0 2px 8px #00000026}.role-label{display:block}.role-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;background-color:currentColor;opacity:.3;border-radius:12px;font-size:11px;font-weight:700}.role-tab.active .role-count{background-color:#fff6}.add-user-form{background:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:20px;margin-bottom:24px}.add-user-form h3{margin-top:0;margin-bottom:16px;font-size:16px;color:#333}.form-field{display:flex;flex-direction:column;gap:4px}.form-field input,.form-field select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}.form-field input:disabled{background-color:#f0f0f0;color:#999}.form-actions{display:flex;gap:12px;margin-top:16px}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.empty-state{grid-column:1 / -1;text-align:center;padding:40px 20px;color:#999;font-size:16px}.user-card-list-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:all .2s}.user-card-list-item:hover{box-shadow:0 2px 8px #0000001a;border-color:#007bff}.user-card-list-item.superadmin-card{border-color:#111;background:linear-gradient(180deg,#fff6f6,#fff);box-shadow:0 2px 12px #0000000f}.user-card-list-item.admin-card{border-color:#d32f2f;background:linear-gradient(180deg,#fff6f6,#fff);box-shadow:0 2px 12px #d32f2f0f}.user-card-list-item.doctor-card{border-color:#1976d2;background:linear-gradient(180deg,#eaf4ff,#fff);box-shadow:0 2px 12px #1565c00f}.user-card-list-item.receptionist-card{border-color:#7b1fa2;background:linear-gradient(180deg,#fbf3ff,#fff);box-shadow:0 2px 12px #7c1fa20d}.user-card-list-item.billing-card{border-color:#388e3c;background:linear-gradient(180deg,#f3fff4,#fff);box-shadow:0 2px 12px #388e3c0d}.user-card-list-item.analyst-card{border-color:#f57c00;background:linear-gradient(180deg,#fff7ec,#fff);box-shadow:0 2px 12px #f57c000d}.user-card-list-item.superadmin-card .user-names h4{color:#111}.user-card-list-item.admin-card .user-names h4{color:#b71c1c}.user-card-list-item.doctor-card .user-names h4{color:#1565c0}.user-card-list-item.receptionist-card .user-names h4{color:#6a1b9a}.user-card-list-item.billing-card .user-names h4{color:#2e7d32}.user-card-list-item.analyst-card .user-names h4{color:#e65100}.user-card-list-item.superadmin-card .username,.user-card-list-item.superadmin-card .email,.user-card-list-item.superadmin-card .user-status,.user-card-list-item.superadmin-card .meta-value{color:#666}.user-card-list-item.superadmin-card .role-badge{background-color:#f6f6f6;color:#111;border:1px solid rgba(0,0,0,.06)}.user-card-list-item.admin-card .role-badge{background-color:#ffecec;color:#b71c1c;border:1px solid rgba(183,28,28,.06)}.user-card-list-item.doctor-card .role-badge{background-color:#e7f3ff;color:#1565c0;border:1px solid rgba(21,101,192,.06)}.user-card-list-item.receptionist-card .role-badge{background-color:#f6eefe;color:#6a1b9a;border:1px solid rgba(124,31,162,.05)}.user-card-list-item.billing-card .role-badge{background-color:#eef9ee;color:#2e7d32;border:1px solid rgba(56,142,60,.05)}.user-card-list-item.analyst-card .role-badge{background-color:#fff4e6;color:#e65100;border:1px solid rgba(245,124,0,.05)}.user-info{padding:16px;cursor:pointer;border-bottom:1px solid #f0f0f0}.user-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.user-names h4{margin:0 0 4px;font-size:16px;font-weight:600;color:#333}.username{margin:0;font-size:13px;color:#999}.role-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;white-space:nowrap}.role-badge.role-admin{background-color:#ffe0e0;color:#d32f2f}.role-badge.role-doctor{background-color:#e3f2fd;color:#1976d2}.role-badge.role-receptionist{background-color:#f3e5f5;color:#7b1fa2}.role-badge.role-billing{background-color:#e8f5e9;color:#388e3c}.role-badge.role-analyst{background-color:#fff3e0;color:#f57c00}.role-badge.role-guest{background-color:#f5f5f5;color:#666}.email{margin:0 0 12px;font-size:13px;color:#666}.user-status{display:flex;gap:8px;flex-wrap:wrap;font-size:12px}.status-active{color:#4caf50;font-weight:600}.status-inactive{color:#f44336;font-weight:600}.status-locked{color:#ff9800;font-weight:600}.user-actions{padding:12px 16px;display:flex;gap:8px}.user-actions .btn{flex:1;font-size:12px;padding:6px 12px}.btn-danger{background-color:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover{background-color:#c82333;border-color:#c82333}.btn-sm{padding:6px 12px;font-size:12px}.user-card-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000}.user-card-overlay{position:absolute;inset:0;background:#00000080;cursor:pointer}.user-card-content{position:relative;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.user-card-content.admin-modal{background:linear-gradient(180deg,#fff6f6,#fff);box-shadow:0 12px 36px #b71c1c14;border:1px solid rgba(183,28,28,.12)}.user-card-content.admin-modal .user-card-header{background:#fff6f6;border-bottom-color:#b71c1c1f}.user-card-content.admin-modal .user-card-header h2{color:#b71c1c}.user-card-content.admin-modal .close-btn{color:#8a1a1a}.user-card-content.admin-modal .form-field input:focus,.user-card-content.admin-modal .form-field select:focus{border-color:#b71c1c;box-shadow:0 0 0 4px #b71c1c0f}.user-card-content.admin-modal .card-section h3{border-bottom-color:#b71c1c}.user-card-content.admin-modal .btn-primary{background-color:#b71c1c;border-color:#b71c1c}.user-card-content.admin-modal .btn-primary:hover{background-color:#8a1a1a;border-color:#8a1a1a}.user-card-content.doctor-modal{background:linear-gradient(180deg,#eaf4ff,#fff);box-shadow:0 12px 36px #1565c014;border:1px solid rgba(21,101,192,.12)}.user-card-content.doctor-modal .user-card-header{background:#eef7ff;border-bottom-color:#1565c01f}.user-card-content.doctor-modal .user-card-header h2{color:#1565c0}.user-card-content.doctor-modal .close-btn{color:#114b80}.user-card-content.doctor-modal .form-field input:focus,.user-card-content.doctor-modal .form-field select:focus{border-color:#1565c0;box-shadow:0 0 0 4px #1565c00f}.user-card-content.doctor-modal .card-section h3{border-bottom-color:#1565c0}.user-card-content.doctor-modal .btn-primary{background-color:#1565c0;border-color:#1565c0}.user-card-content.doctor-modal .btn-primary:hover{background-color:#0e4773;border-color:#0e4773}.user-card-content.receptionist-modal{background:linear-gradient(180deg,#fbf3ff,#fff);box-shadow:0 12px 36px #7c1fa20f;border:1px solid rgba(124,31,162,.12)}.user-card-content.receptionist-modal .user-card-header{background:#fcf5ff;border-bottom-color:#7c1fa21f}.user-card-content.receptionist-modal .user-card-header h2{color:#6a1b9a}.user-card-content.receptionist-modal .close-btn{color:#4f146f}.user-card-content.receptionist-modal .form-field input:focus,.user-card-content.receptionist-modal .form-field select:focus{border-color:#6a1b9a;box-shadow:0 0 0 4px #7c1fa20f}.user-card-content.receptionist-modal .card-section h3{border-bottom-color:#6a1b9a}.user-card-content.receptionist-modal .btn-primary{background-color:#6a1b9a;border-color:#6a1b9a}.user-card-content.receptionist-modal .btn-primary:hover{background-color:#4f146f;border-color:#4f146f}.user-card-content.billing-modal{background:linear-gradient(180deg,#f3fff4,#fff);box-shadow:0 12px 36px #388e3c0f;border:1px solid rgba(56,142,60,.12)}.user-card-content.billing-modal .user-card-header{background:#f6fff7;border-bottom-color:#388e3c1f}.user-card-content.billing-modal .user-card-header h2{color:#2e7d32}.user-card-content.billing-modal .close-btn{color:#23592a}.user-card-content.billing-modal .form-field input:focus,.user-card-content.billing-modal .form-field select:focus{border-color:#2e7d32;box-shadow:0 0 0 4px #388e3c0f}.user-card-content.billing-modal .card-section h3{border-bottom-color:#2e7d32}.user-card-content.billing-modal .btn-primary{background-color:#2e7d32;border-color:#2e7d32}.user-card-content.billing-modal .btn-primary:hover{background-color:#23592a;border-color:#23592a}.user-card-content.analyst-modal{background:linear-gradient(180deg,#fff7ec,#fff);box-shadow:0 12px 36px #f57c000f;border:1px solid rgba(245,124,0,.12)}.user-card-content.analyst-modal .user-card-header{background:#fff8ef;border-bottom-color:#f57c001f}.user-card-content.analyst-modal .user-card-header h2{color:#e65100}.user-card-content.analyst-modal .close-btn{color:#b04200}.user-card-content.analyst-modal .form-field input:focus,.user-card-content.analyst-modal .form-field select:focus{border-color:#e65100;box-shadow:0 0 0 4px #f57c000f}.user-card-content.analyst-modal .card-section h3{border-bottom-color:#e65100}.user-card-content.analyst-modal .btn-primary{background-color:#e65100;border-color:#e65100}.user-card-content.analyst-modal .btn-primary:hover{background-color:#b04200;border-color:#b04200}.user-card-content.superadmin-modal{background:linear-gradient(180deg,#fff6f6,#fff);box-shadow:0 12px 36px #0000000f;border:1px solid rgba(0,0,0,.12)}.user-card-content.superadmin-modal .user-card-header{background:#fff6f6;border-bottom-color:#0000001f}.user-card-content.superadmin-modal .user-card-header h2{color:#111}.user-card-content.superadmin-modal .close-btn{color:#333}.user-card-content.superadmin-modal .user-card-body,.user-card-content.superadmin-modal .card-section,.user-card-content.superadmin-modal .meta-info,.user-card-content.superadmin-modal .permissions-grid{color:inherit}.user-card-content.superadmin-modal .form-field input,.user-card-content.superadmin-modal .form-field select{background:transparent;color:inherit;border:1px solid #ddd}.user-card-content.superadmin-modal .form-field input:focus,.user-card-content.superadmin-modal .form-field select:focus{border-color:#111;box-shadow:0 0 0 4px #0000000f}.user-card-content.superadmin-modal .card-section h3{border-bottom-color:#111;color:#111}.user-card-content.superadmin-modal .btn-primary{background-color:#111;border-color:#111;color:#fff}.user-card-content.superadmin-modal .btn-primary:hover{background-color:#0d0d0d;border-color:#0d0d0d}.user-card-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0;background:#fafafa}.user-card-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.close-btn{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background-color:#0000001a;color:#333}.user-card-content.superadmin-modal .close-btn{color:#ddd}.user-card-body{padding:24px;flex:1;overflow-y:auto}.card-section{margin-bottom:28px}.card-section:last-child{margin-bottom:0}.card-section h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#333;border-bottom:2px solid #007bff;padding-bottom:8px}.card-section-meta h3{border-bottom-color:#ccc}.form-field label{font-size:13px;font-weight:500;color:#666}.form-field input,.form-field select{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-field input:focus,.form-field select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-field input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-field small{font-size:12px;color:#999}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 0}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#007bff}.checkbox-label span{font-size:14px;color:#333}.permissions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;background:#f9f9f9;padding:16px;border-radius:8px}.permission-checkbox{display:flex;align-items:flex-start;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px;border-radius:4px;transition:background-color .2s}.permission-checkbox:hover{background-color:#f0f0f0}.permission-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:#007bff}.permission-name{font-size:13px;color:#333;line-height:1.4}.meta-info{background:#f9f9f9;padding:16px;border-radius:8px;display:grid;gap:12px}.meta-item{display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:center}.meta-label{font-size:13px;font-weight:600;color:#666}.meta-value{font-size:13px;color:#333;font-family:Courier New,monospace}.user-card-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;background:#fafafa}.user-card-footer button{padding:10px 24px;font-size:14px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-weight:500;color:#333;background-color:#f5f5f5;cursor:pointer;transition:all .2s}.btn-primary{background-color:#007bff;color:#fff;border-color:#007bff}.btn-primary:hover{background-color:#0056b3;border-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff;border-color:#6c757d}.btn-secondary:hover{background-color:#545b62;border-color:#545b62}@media(max-width:768px){.user-card-content{max-width:95%;max-height:95vh}.form-row,.permissions-grid{grid-template-columns:1fr}.meta-item{grid-template-columns:1fr;gap:4px}.meta-label{font-weight:600}.meta-value{color:#666}}.integrations-container{display:flex;flex-direction:column;gap:20px}.integrations-header{margin-bottom:8px}.integrations-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#111827}.integrations-subtitle{margin:0;font-size:14px;color:#6b7280}.integrations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:20px}.integration-card{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid #e5e7eb;border-radius:8px;background-color:#fff;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.integration-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px #0000001a}.integration-logo{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:8px;color:#fff;font-size:28px;font-weight:600}.logo-emoji{display:inline-block}.integration-info{display:flex;flex-direction:column;gap:4px}.integration-name{margin:0;font-size:15px;font-weight:600;color:#111827}.integration-description{margin:0;font-size:13px;color:#6b7280;line-height:1.4}.integration-status{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500}.status-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;background-color:#9ca3af}.status-text{color:#6b7280}.integration-status.status-not-configured{color:#9ca3af}.integration-status.status-not-configured .status-indicator{background-color:#9ca3af}.integration-status.status-configured{color:#16a34a}.integration-status.status-configured .status-indicator{background-color:#16a34a}.integration-status.status-error{color:#dc2626}.integration-status.status-error .status-indicator{background-color:#dc2626}.integration-action-btn{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;color:#111827;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;align-self:flex-start}.integration-action-btn:hover{background-color:#f3f4f6;border-color:#9ca3af}.integration-action-btn:active{background-color:#e5e7eb}.integration-action-btn:disabled{opacity:.5;cursor:not-allowed}.integrations-info-block{display:flex;gap:12px;padding:12px 16px;border:1px solid #dbeafe;border-radius:8px;background-color:#f0f9ff;margin-top:12px}.info-icon{display:flex;align-items:flex-start;font-size:18px;flex-shrink:0;margin-top:2px}.info-content{display:flex;flex-direction:column;gap:4px}.info-title{margin:0;font-size:14px;font-weight:600;color:#1e40af}.info-text{margin:0;font-size:13px;color:#1e40af;line-height:1.5}@media(max-width:768px){.integrations-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:480px){.integrations-grid{grid-template-columns:1fr}.integration-card{gap:10px}}.notification-settings{padding:1rem}.notification-settings__loading{padding:2rem;text-align:center;color:var(--color-text-secondary)}.notification-settings__header{margin-bottom:1.5rem}.notification-settings__header h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.notification-settings__description{margin:0;color:var(--color-text-secondary);font-size:.875rem}.notification-settings__stats{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--color-bg-secondary);border-radius:8px}.notification-settings__stat{flex:1;text-align:center;padding:.75rem;background:var(--color-bg-primary);border-radius:6px}.notification-settings__stat-value{display:block;font-size:1.5rem;font-weight:600;color:var(--color-text-primary)}.notification-settings__stat-label{display:block;font-size:.75rem;color:var(--color-text-secondary);margin-top:.25rem}.notification-settings__stat--success .notification-settings__stat-value{color:var(--color-success)}.notification-settings__stat--error .notification-settings__stat-value{color:var(--color-error)}.notification-settings__section{margin-bottom:1.5rem;padding:1rem;background:var(--color-bg-secondary);border-radius:8px}.notification-settings__section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.notification-settings__hint{margin:0 0 1rem;font-size:.75rem;color:var(--color-text-secondary);font-family:monospace;background:var(--color-bg-tertiary);padding:.5rem;border-radius:4px}.notification-settings__row{margin-bottom:1rem}.notification-settings__row:last-child{margin-bottom:0}.notification-settings__row>label{display:block;margin-bottom:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.notification-settings__row--time{display:flex;gap:1rem}.notification-settings__row--time>*{flex:1}.notification-settings__toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.875rem}.notification-settings__toggle input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer}.notification-settings__chips{display:flex;gap:.5rem;flex-wrap:wrap}.notification-settings__chip{padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:20px;background:var(--color-bg-primary);color:var(--color-text-secondary);font-size:.875rem;cursor:pointer;transition:all .15s ease}.notification-settings__chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.notification-settings__chip--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.notification-settings__chip--active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.notification-settings__textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.875rem;font-family:monospace;resize:vertical;min-height:100px}.notification-settings__textarea:focus{outline:none;border-color:var(--color-primary)}.notification-settings__actions{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.notification-history{padding:1rem;background:var(--color-bg-secondary, #f9fafb);border-radius:8px}.notification-history__header{margin-bottom:.75rem}.notification-history__header h4{margin:0 0 .25rem;font-size:.95rem;font-weight:600}.notification-history__description{margin:0;font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.notification-history__filters{display:flex;justify-content:space-between;align-items:flex-end;gap:.75rem;margin-bottom:.75rem}.notification-history__filters-left{display:flex;gap:.75rem;flex-wrap:wrap}.notification-history__filters-right{display:flex;align-items:center}.notification-history__filter-field{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.notification-history__filter-field select{min-width:120px;padding:.35rem .5rem;border-radius:4px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-bg-primary, #ffffff);font-size:.8rem}.notification-history__state{padding:.75rem .25rem;font-size:.8rem;color:var(--color-text-secondary, #6b7280)}.notification-history__state--error{color:var(--color-error, #dc2626)}.notification-history__table-wrapper{max-height:360px;overflow:auto;border-radius:6px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-bg-primary, #ffffff)}.notification-history__table{width:100%;border-collapse:collapse;font-size:.78rem}.notification-history__table thead{position:sticky;top:0;background:var(--color-bg-secondary, #f9fafb);z-index:1}.notification-history__table th,.notification-history__table td{padding:.4rem .5rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.notification-history__table th{text-align:left;font-weight:500;color:var(--color-text-secondary, #6b7280)}.notification-history__recipient{font-family:monospace;font-size:.75rem}.notification-history__patient-name{font-weight:500}.notification-history__patient-appointment{display:block;font-size:.7rem;color:var(--color-text-secondary, #6b7280)}.notification-history__status{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .4rem;border-radius:12px;font-size:.65rem;text-transform:uppercase;background:var(--color-bg-tertiary, #f3f4f6);color:var(--color-text-secondary, #6b7280)}.notification-history__status--success{background:var(--color-success-bg, #dcfce7);color:var(--color-success, #16a34a)}.notification-history__status--error{background:var(--color-error-bg, #fee2e2);color:var(--color-error, #dc2626)}.notification-history__error{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text-secondary, #6b7280)}.notification-history__pagination{margin-top:.5rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.notification-history__pagination-info{font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.notification-history__pagination-controls{display:flex;gap:.5rem}@media(max-width:768px){.notification-history{padding:.75rem}.notification-history__filters{flex-direction:column;align-items:stretch}.notification-history__filters-right{justify-content:flex-end}}.notification-stats{padding:.75rem 1rem 1rem;background:var(--color-bg-secondary, #f9fafb);border-radius:8px}.notification-stats__state{padding:.75rem .5rem;font-size:.8rem;color:var(--color-text-secondary, #6b7280)}.notification-stats__state--error{color:var(--color-error, #dc2626)}.notification-stats__cards{display:flex;gap:.75rem;margin-bottom:.75rem}.notification-stats__card{flex:1;padding:.5rem .75rem;border-radius:6px;background:var(--color-bg-primary, #ffffff);border:1px solid var(--color-border, #e5e7eb)}.notification-stats__card-label{font-size:.7rem;color:var(--color-text-secondary, #6b7280);margin-bottom:.25rem}.notification-stats__card-value{font-size:1.1rem;font-weight:600}.notification-stats__card--success .notification-stats__card-value{color:var(--color-success, #16a34a)}.notification-stats__card--error .notification-stats__card-value{color:var(--color-error, #dc2626)}.notification-stats__table-wrapper{border-radius:6px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-bg-primary, #ffffff);max-height:220px;overflow:auto}.notification-stats__table{width:100%;border-collapse:collapse;font-size:.78rem}.notification-stats__table th,.notification-stats__table td{padding:.35rem .5rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.notification-stats__table th{text-align:left;font-weight:500;color:var(--color-text-secondary, #6b7280)}@media(max-width:768px){.notification-stats__cards{flex-direction:column}}.tg-settings{margin-top:24px;padding:16px;border-radius:8px;background:#fff;box-shadow:0 1px 3px #0f172a14}.tg-settings__header{margin-bottom:16px;display:flex;flex-direction:column;gap:4px}.tg-settings__description{font-size:.9rem;color:#6b7280}.tg-settings__status{font-size:.85rem;margin-top:4px}.tg-settings__status--ok{color:#15803d}.tg-settings__status--error{color:#b91c1c}.tg-settings__status--warn{color:#b45309}.tg-settings__status--unknown{color:#6b7280}.tg-settings__section{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.tg-settings__actions{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.tg-settings__hint{font-size:.8rem;color:#6b7280;margin-top:4px}.tg-settings__error{font-size:.8rem;color:#b91c1c}.tg-settings__help{font-size:.85rem;color:#4b5563}.tg-settings__help h5{margin:0 0 4px;font-size:.9rem;font-weight:600}.tg-settings__help ol{padding-left:20px;margin:4px 0 0}.tg-settings__loading{padding:8px 0;font-size:.9rem;color:#6b7280}.max-settings{display:flex;flex-direction:column;gap:1.5rem}.max-settings__header{display:flex;flex-direction:column;gap:.5rem}.max-settings__header h4{margin:0;font-size:1.125rem;font-weight:600}.max-settings__description{margin:0;color:var(--color-text-secondary, #6b7280);font-size:.875rem;line-height:1.5}.max-settings__status{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500;margin-top:.5rem}.max-settings__status--ok{background-color:#d1fae5;color:#065f46}.max-settings__status--error{background-color:#fee2e2;color:#991b1b}.max-settings__status--warn{background-color:#fef3c7;color:#92400e}.max-settings__status--unknown{background-color:#e5e7eb;color:#374151}.max-settings__section{display:flex;flex-direction:column;gap:1rem;padding:1rem;background-color:var(--color-bg-secondary, #f9fafb);border-radius:.5rem}.max-settings__hint{margin-top:.5rem;font-size:.75rem;color:var(--color-text-tertiary, #9ca3af);line-height:1.4}.max-settings__actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.max-settings__error{padding:.75rem;background-color:#fee2e2;border-left:3px solid #dc2626;border-radius:.25rem;font-size:.875rem;color:#991b1b}.max-settings__help{padding:1rem;background-color:var(--color-bg-tertiary, #f3f4f6);border-radius:.5rem}.max-settings__help h5{margin:0 0 .75rem;font-size:1rem;font-weight:600}.max-settings__help ol{margin:0;padding-left:1.5rem;display:flex;flex-direction:column;gap:.5rem}.max-settings__help li{font-size:.875rem;line-height:1.6;color:var(--color-text-secondary, #6b7280)}.max-settings__help code{padding:.125rem .375rem;background-color:#e5e7eb;border-radius:.25rem;font-size:.8125rem;font-family:Courier New,monospace;color:#1f2937}.max-settings__help a{color:#2563eb;text-decoration:underline}.max-settings__help a:hover{color:#1d4ed8}.max-settings__loading{padding:2rem;text-align:center;color:var(--color-text-secondary, #6b7280)}.max-templates{display:flex;flex-direction:column;gap:1.5rem}.max-templates__header{display:flex;flex-direction:column;gap:.5rem}.max-templates__header h4{margin:0;font-size:1.125rem;font-weight:600}.max-templates__description{margin:0;color:var(--color-text-secondary, #6b7280);font-size:.875rem;line-height:1.5}.max-templates__tabs{display:flex;gap:.5rem;border-bottom:2px solid #e5e7eb;overflow-x:auto}.max-templates__tab{padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;white-space:nowrap;transition:all .2s}.max-templates__tab:hover{color:#374151;background-color:#f9fafb}.max-templates__tab--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.max-templates__content{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:1024px){.max-templates__content{grid-template-columns:1fr}}.max-templates__editor{display:flex;flex-direction:column;gap:1rem}.max-templates__textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-family:inherit;font-size:.875rem;line-height:1.5;resize:vertical;transition:border-color .2s}.max-templates__textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.max-templates__variables{padding:1rem;background-color:#f9fafb;border-radius:.5rem}.max-templates__variables-header{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:#374151}.max-templates__variables-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.max-templates__variable-btn{padding:.375rem .75rem;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.75rem;font-family:Courier New,monospace;color:#2563eb;cursor:pointer;transition:all .2s}.max-templates__variable-btn:hover{background-color:#eff6ff;border-color:#2563eb}.max-templates__variables-hint{font-size:.75rem;color:#9ca3af;font-style:italic}.max-templates__preview{padding:1rem;background-color:#f9fafb;border-radius:.5rem;display:flex;flex-direction:column;gap:1rem}.max-templates__preview-header{font-size:.875rem;font-weight:600;color:#374151}.max-templates__preview-content{padding:1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;min-height:150px;white-space:pre-wrap;font-size:.875rem;line-height:1.6;color:#1f2937}.max-templates__preview-hint{font-size:.75rem;color:#9ca3af;font-style:italic}.max-templates__actions{display:flex;gap:.75rem}.max-templates__tips{padding:1rem;background-color:#eff6ff;border-radius:.5rem;border-left:4px solid #2563eb}.max-templates__tips h5{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#1e40af}.max-templates__tips ul{margin:0;padding-left:1.5rem;display:flex;flex-direction:column;gap:.5rem}.max-templates__tips li{font-size:.8125rem;line-height:1.5;color:#1e3a8a}.max-templates__loading{padding:2rem;text-align:center;color:var(--color-text-secondary, #6b7280)}.max-agent{display:flex;flex-direction:column;gap:1.5rem}.max-agent__header{display:flex;flex-direction:column;gap:.5rem}.max-agent__header h4{margin:0;font-size:1.125rem;font-weight:600}.max-agent__description{margin:0;color:var(--color-text-secondary, #6b7280);font-size:.875rem;line-height:1.5}.max-agent__section{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;background-color:var(--color-bg-secondary, #f9fafb);border-radius:.5rem}.max-agent__toggle{display:flex;flex-direction:column;gap:.5rem}.max-agent__checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.max-agent__checkbox-label input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer}.max-agent__checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.max-agent__checkbox-label span{font-size:.9375rem;font-weight:500;color:#1f2937}.max-agent__toggle-hint{margin:0 0 0 1.75rem;font-size:.8125rem;color:var(--color-text-tertiary, #9ca3af);font-style:italic}.max-agent__divider{height:1px;background-color:#e5e7eb}.max-agent__hint{margin-top:.5rem;font-size:.75rem;color:var(--color-text-tertiary, #9ca3af);line-height:1.4}.max-agent__tasks{display:flex;flex-direction:column;gap:1rem}.max-agent__tasks h5{margin:0;font-size:1rem;font-weight:600;color:#1f2937}.max-agent__tasks-description{margin:0;font-size:.875rem;color:#6b7280}.max-agent__task{padding:1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;flex-direction:column;gap:.5rem}.max-agent__task-header{display:flex;align-items:center;gap:.75rem}.max-agent__task-badge{padding:.125rem .5rem;background-color:#f3f4f6;border-radius:.25rem;font-size:.6875rem;font-weight:500;color:#6b7280;text-transform:uppercase}.max-agent__task-description{margin:0 0 0 1.75rem;font-size:.8125rem;color:#6b7280;line-height:1.5}.max-agent__task-field{margin-left:1.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.max-agent__actions{display:flex;gap:.75rem}.max-agent__info{padding:1rem;background-color:#ecfdf5;border-radius:.5rem;border-left:4px solid #10b981}.max-agent__info h5{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#065f46}.max-agent__info ul{margin:0;padding-left:1.5rem;display:flex;flex-direction:column;gap:.5rem}.max-agent__info li{font-size:.8125rem;line-height:1.5;color:#047857}.max-agent__loading{padding:2rem;text-align:center;color:var(--color-text-secondary, #6b7280)}.settings-tabs{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:8px;margin-bottom:20px}.settings-tabs-left{display:flex;gap:8px;flex:1;min-width:0}.settings-tab-right{margin-left:auto}.settings-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:6px;background-color:transparent;color:#666;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap}.settings-tab:hover{background-color:#f5f5f5;color:#333}.settings-tab.active{background-color:#667eea;color:#fff;font-weight:600}.settings-tab.active:hover{background-color:#5568d3}.tab-icon{font-size:18px;display:flex;align-items:center;justify-content:center;width:20px}.tab-label{display:inline}.settings-sidebar{display:flex;flex-direction:column;gap:8px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px;min-width:200px;height:fit-content}.settings-sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;border-radius:6px;background-color:transparent;color:#666;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;text-align:left}.settings-sidebar-item:hover{background-color:#f5f5f5;color:#333}.settings-sidebar-item.active{background-color:#667eea;color:#fff;font-weight:600}.settings-sidebar-item.active:hover{background-color:#5568d3}.sidebar-icon{font-size:18px;display:flex;align-items:center;justify-content:center;width:24px}.settings-content{min-height:400px}.settings-notifications-layout{display:flex;gap:16px;align-items:flex-start}.settings-notifications-layout__main{flex:2;min-width:0}.settings-notifications-layout__side{flex:1;min-width:280px;display:flex;flex-direction:column;gap:16px}@media(max-width:768px){.settings-tab{padding:8px 12px;font-size:13px;gap:6px}.tab-icon{font-size:16px;width:18px}.settings-sidebar{flex-direction:row;min-width:auto;flex-wrap:wrap;margin-bottom:16px}.settings-sidebar-item{flex:1;min-width:150px}}.profile-page{max-width:1200px;margin:0 auto}.profile-container{display:grid;grid-template-columns:300px 1fr;gap:24px;margin-top:24px}.profile-sidebar{display:flex;flex-direction:column;gap:20px}.profile-avatar-section{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:32px;text-align:center}.profile-avatar-large{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:48px;font-weight:700;margin:0 auto 16px;box-shadow:0 4px 16px #00000026}.profile-avatar-clickable{border:none;padding:0;cursor:pointer;background:transparent}.profile-avatar-clickable:hover{box-shadow:0 0 0 3px #667eea59}.profile-username{margin:0 0 8px;font-size:20px;font-weight:600;color:#333;font-family:Courier New,monospace}.profile-role-badge{display:inline-block;padding:6px 16px;background-color:#f0f0f0;border-radius:20px;font-size:13px;font-weight:600;color:#666;border:1px solid transparent}.profile-avatar-section.role-admin{border-color:#d32f2f;box-shadow:0 8px 24px #d32f2f14}.profile-role-badge.role-admin{background-color:#fff6f6;color:#b71c1c;border-color:#d32f2f66}.profile-avatar-section.role-superadmin{border-color:#111;box-shadow:0 8px 24px #00000014}.profile-role-badge.role-superadmin{background-color:#f7f7f7;color:#111;border-color:#0006}.profile-avatar-section.role-doctor{border-color:#1976d2;box-shadow:0 8px 24px #1976d214}.profile-role-badge.role-doctor{background-color:#eaf4ff;color:#1565c0;border-color:#1976d266}.profile-avatar-section.role-receptionist{border-color:#7b1fa2;box-shadow:0 8px 24px #7b1fa214}.profile-role-badge.role-receptionist{background-color:#fbf3ff;color:#6a1b9a;border-color:#7b1fa266}.profile-avatar-section.role-billing{border-color:#388e3c;box-shadow:0 8px 24px #388e3c14}.profile-role-badge.role-billing{background-color:#f3fff4;color:#2e7d32;border-color:#388e3c66}.profile-avatar-section.role-analyst{border-color:#f57c00;box-shadow:0 8px 24px #f57c0014}.profile-role-badge.role-analyst{background-color:#fff7ec;color:#e65100;border-color:#f57c0066}.profile-stats{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:16px}.profile-stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:14px;font-weight:600;color:#333}.stat-value.active{color:#4caf50}.stat-value.inactive{color:#f44336}.profile-main{display:flex;flex-direction:column;gap:20px}.profile-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden}.profile-card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #f0f0f0;background-color:#fafafa}.profile-card-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.profile-card-body{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-row:last-child{margin-bottom:0}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:13px;font-weight:600;color:#666}.form-field input{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-field input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-field select{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s;background-color:#fff;cursor:pointer;min-height:40px}.form-field select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.field-value{padding:10px 12px;background-color:#f9f9f9;border-radius:6px;font-size:14px;color:#333;min-height:40px;display:flex;align-items:center}.form-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #f0f0f0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background-color:#f5f5f5;color:#333}.btn:hover{background-color:#e8e8e8;border-color:#ccc}.btn-primary{background-color:#667eea;color:#fff;border-color:#667eea}.btn-primary:hover{background-color:#5568d3;border-color:#5568d3}.btn-secondary{background-color:#fff;color:#666;border-color:#ddd}.btn-secondary:hover{background-color:#f9f9f9;border-color:#ccc}.password-field{display:flex;align-items:center;gap:12px}.password-field .field-value{flex:1}.btn-sm{padding:6px 12px;font-size:13px}.field-value-readonly{background-color:#f5f5f5;color:#666;border:1px solid #e0e0e0;border-radius:6px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:480px;width:90%;animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #f0f0f0}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#333}.modal-body{padding:24px}.password-warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px 16px;margin-bottom:20px;text-align:center}.password-warning strong{color:#856404;display:block;margin-bottom:8px}.password-warning p{margin:6px 0;font-size:13px;color:#856404}.password-warning p:first-of-type{margin-top:0}.modal-error{background-color:#fee;color:#d32f2f;padding:12px 14px;border-radius:8px;font-size:14px;margin-bottom:20px;border-left:4px solid #d32f2f}.modal-success{background-color:#e8f5e9;color:#2e7d32;padding:12px 14px;border-radius:8px;font-size:14px;margin-bottom:20px;border-left:4px solid #4caf50;text-align:center}.modal-body .form-field{margin-bottom:16px}.modal-body .form-field input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.modal-body .form-field input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-footer{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #f0f0f0;justify-content:flex-end}.modal-footer .btn{padding:10px 20px}@media(max-width:768px){.profile-container{grid-template-columns:1fr}.profile-sidebar{order:2}.profile-main{order:1}.form-row{grid-template-columns:1fr}}.patient-notification-prefs{padding:1rem;background:var(--color-bg-secondary);border-radius:8px}.patient-notification-prefs__loading{padding:1rem;text-align:center;color:var(--color-text-secondary)}.patient-notification-prefs__header{margin-bottom:1rem}.patient-notification-prefs__header h4{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.patient-notification-prefs__toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;margin-bottom:.25rem}.patient-notification-prefs__toggle input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.patient-notification-prefs__toggle--warning span{color:var(--color-warning)}.patient-notification-prefs__badge{margin-left:.5rem;padding:.125rem .5rem;background:var(--color-success);color:#fff;font-size:.625rem;border-radius:10px;text-transform:uppercase}.patient-notification-prefs__channels{margin-bottom:1rem;padding-left:.5rem}.patient-notification-prefs__row{margin-bottom:1rem}.patient-notification-prefs__row>label{display:block;margin-bottom:.25rem;font-size:.75rem;color:var(--color-text-secondary)}.patient-notification-prefs__row select{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.875rem}.patient-notification-prefs__telegram{margin:1rem 0;padding:.75rem;background:var(--color-bg-tertiary);border-radius:6px}.patient-notification-prefs__telegram p{margin:0 0 .5rem;font-size:.75rem;color:var(--color-text-secondary)}.patient-notification-prefs__telegram-link{display:flex;gap:.5rem}.patient-notification-prefs__telegram-link input{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.75rem;font-family:monospace}.patient-notification-prefs__actions,.patient-notification-prefs__history{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.patient-notification-prefs__history-toggle{background:none;border:none;color:var(--color-primary);font-size:.75rem;cursor:pointer;padding:0}.patient-notification-prefs__history-toggle:hover{text-decoration:underline}.patient-notification-prefs__history-list{margin-top:.75rem}.patient-notification-prefs__history-item{padding:.5rem;margin-bottom:.5rem;background:var(--color-bg-primary);border-radius:4px;font-size:.75rem}.patient-notification-prefs__history-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.patient-notification-prefs__history-channel{font-weight:500;color:var(--color-text-primary)}.patient-notification-prefs__history-status{padding:.125rem .375rem;border-radius:4px;font-size:.625rem;text-transform:uppercase;background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.patient-notification-prefs__history-status--success{background:var(--color-success-bg);color:var(--color-success)}.patient-notification-prefs__history-status--error{background:var(--color-error-bg);color:var(--color-error)}.patient-notification-prefs__history-date{color:var(--color-text-secondary)}.patient-notification-prefs__history-error{margin-top:.25rem;color:var(--color-error);font-size:.625rem}.user-schedule-page{width:100%;max-width:1600px;margin:0 auto;padding:16px 16px 20px;box-sizing:border-box;height:100%;display:flex;flex-direction:column}.user-schedule-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.1fr);gap:24px;align-items:stretch;flex:1 1 auto;min-height:0}@media(max-width:1200px){.user-schedule-layout{grid-template-columns:minmax(0,1fr)}}.user-schedule-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.user-schedule-month-nav{display:flex;gap:8px;flex-wrap:wrap}.user-schedule-btn,.user-schedule-btn-primary,.user-schedule-btn-link{border-radius:999px;border:1px solid #e5e7eb;padding:6px 14px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;cursor:pointer;background:#fff;color:#374151;box-shadow:0 1px 2px #0000000a;transition:background-color .15s ease,box-shadow .15s ease,border-color .15s ease,transform .1s ease}.user-schedule-btn:hover,.user-schedule-btn-link:hover{background-color:#f3f4ff;border-color:#c7d2fe;box-shadow:0 2px 6px #818cf82e;transform:translateY(-1px)}.user-schedule-btn-primary{background:linear-gradient(90deg,#667eea,#764ba2);color:#fff;border-color:transparent}.user-schedule-btn-primary:hover{box-shadow:0 3px 10px #667eea73;transform:translateY(-1px)}.user-schedule-month-title{font-size:16px;font-weight:600;text-transform:capitalize;color:#111827}.user-schedule-links{margin-top:12px}.user-schedule-btn-link{border-radius:999px;padding:6px 14px;background:#ecfdf5;border-color:#6ee7b7;color:#047857}.user-schedule-btn-link:hover{background:#d1fae5;border-color:#34d399}.calendar-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0f172a14;padding:16px 16px 14px;margin-bottom:0;min-width:0;display:flex;flex-direction:column}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-header{margin-bottom:4px}.calendar-header-cell{color:#6b7280;font-weight:600;font-size:15px;text-align:center;padding-bottom:6px}.calendar-body{flex:1 1 auto;min-height:0}.calendar-cell{min-height:72px;border-radius:6px;text-align:right;padding:8px 10px 6px 2px;font-size:15px;color:#222;background:none;transition:background .15s,box-shadow .15s,transform .1s}.calendar-cell:hover{background:#f3f4f6}.calendar-day-cell{position:relative;cursor:pointer}.calendar-day-has-appointments{box-shadow:inset 0 0 0 1px #d1fae5;background:#ecfdf5}.calendar-day-off{background:#fef2f2;color:#991b1b;box-shadow:inset 0 0 0 1px #fca5a5}.calendar-day-selected{box-shadow:inset 0 0 0 2px #6366f1;background:#e0e7ff}.calendar-day-off.calendar-day-selected{box-shadow:inset 0 0 0 2px #6366f1}.calendar-day-badge{position:absolute;left:6px;bottom:4px;font-size:11px;padding:2px 6px;border-radius:999px;background:#10b9811f;color:#065f46;font-weight:500}.calendar-day-sub{position:absolute;left:6px;top:30px;font-size:11px}.calendar-day-sub-off{color:#b91c1c}.calendar-cell-empty{background:none;pointer-events:none}.calendar-day-num{font-weight:600;font-size:15px}.user-schedule-details{display:flex;flex-direction:column;gap:16px;min-height:0}.user-schedule-metrics.card{padding:16px 16px 14px}.user-schedule-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px 16px;margin-top:8px}.metrics-label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;margin-bottom:2px}.metrics-value{font-size:22px;font-weight:700;color:#111827}.metrics-bars{margin-top:10px;display:flex;gap:10px;align-items:flex-end}.metrics-bar{flex:1;min-width:0}.metrics-bar-track{height:60px;border-radius:6px;background:#f3f4f6;display:flex;align-items:flex-end;overflow:hidden}.metrics-bar-fill{width:100%;border-radius:6px 6px 0 0}.metrics-bar-fill-working{background:linear-gradient(180deg,#4ade80,#16a34a)}.metrics-bar-fill-weekend{background:linear-gradient(180deg,#fecaca,#ef4444)}.metrics-bar-label{margin-top:4px;font-size:11px;color:#4b5563;text-align:center}.metrics-bar-value{font-size:12px;font-weight:600;text-align:center;color:#111827}.day-metrics{margin:10px 0 6px}.day-metrics-bars{display:flex;gap:10px;align-items:center}.day-metrics-track{flex:1;height:10px;border-radius:999px;background:#f3f4f6;overflow:hidden;display:flex}.day-metrics-fill-total{background:#93c5fd}.day-metrics-fill-completed{background:#4ade80}.day-metrics-labels{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px 12px;margin-top:4px;font-size:11px;color:#4b5563}.day-metrics-labels span{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.day-metrics-dot-total{width:8px;height:8px;border-radius:999px;background:#60a5fa}.day-metrics-dot-completed{width:8px;height:8px;border-radius:999px;background:#22c55e}.user-schedule-hint{margin-top:8px;font-size:12px}.user-schedule-day.card{padding:16px;flex:1 1 auto;min-height:auto;display:flex;flex-direction:column}.user-schedule-day h2{word-break:break-word;margin-bottom:8px}.user-schedule-day-table th,.user-schedule-day-table td{font-size:13px}@media(max-width:900px){.user-schedule-toolbar{flex-direction:column;align-items:flex-start;gap:12px}.user-schedule-month-title{text-align:left}.calendar-card{padding:12px}.calendar-body{min-height:0}.calendar-cell{min-height:56px;font-size:14px}.user-schedule-details{gap:12px}.day-metrics-labels{gap:6px 10px;font-size:10px}.metrics-value{font-size:18px}}@media(max-width:600px){.user-schedule-page{padding:16px 10px 24px}.calendar-header-cell{font-size:13px}.user-schedule-month-title{font-size:14px}}.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{list-style-type:none;padding-left:1.5em;position:relative}.ql-editor li>.ql-ui:before{display:inline-block;margin-left:-1.5em;margin-right:.3em;text-align:right;white-space:nowrap;width:1.2em}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"•"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"☑"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"☐"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0,decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{margin-left:.3em;margin-right:-1.5em;text-align:left}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media(pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor .ql-code-block-container{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{right:5px;top:5px}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}@keyframes float{0%,to{transform:translateY(0);opacity:.1}50%{transform:translateY(-30px);opacity:.15}}@keyframes glow{0%,to{box-shadow:0 0 20px #7c5af04d}50%{box-shadow:0 0 50px #7c5af099}}@keyframes slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{transform:scale(1);opacity:.05}50%{transform:scale(1.1);opacity:.1}}.electron-gate-bg{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);background-attachment:fixed;color:#e0e0e0;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden;position:relative}.electron-gate-glow{position:fixed;border-radius:50%;pointer-events:none;z-index:-1}.electron-gate-glow-1{width:400px;height:400px;top:-100px;left:-100px;background:radial-gradient(circle,rgba(124,90,240,.15) 0%,transparent 70%);animation:float 20s ease-in-out infinite}.electron-gate-glow-2{width:300px;height:300px;bottom:-50px;right:-50px;background:radial-gradient(circle,rgba(139,92,246,.12) 0%,transparent 70%);animation:float 25s ease-in-out infinite reverse}.electron-gate-glow-3{width:250px;height:250px;top:50%;right:10%;background:radial-gradient(circle,rgba(52,211,153,.08) 0%,transparent 70%);animation:float 30s ease-in-out infinite}.electron-gate-container{max-width:550px;text-align:center;position:relative;z-index:10;animation:slide-in .8s ease-out}.electron-gate-logo{font-size:60px;margin-bottom:40px;color:#7c5af0;display:inline-block;filter:drop-shadow(0 0 20px rgba(124,90,240,.3))}.electron-gate-logo svg{display:block;animation:pulse-glow 4s ease-in-out infinite}.electron-gate-title{font-size:32px;font-weight:700;margin-bottom:20px;color:#fff;animation:slide-in .8s ease-out .1s both;background:linear-gradient(135deg,#fff,#a0a0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.electron-gate-text{font-size:16px;line-height:1.8;margin-bottom:40px;color:#b0b0c0;animation:slide-in .8s ease-out .2s both;max-width:450px;margin-left:auto;margin-right:auto}.electron-gate-btn{display:inline-block;background:linear-gradient(135deg,#7c5af0,#6b4dd1);color:#fff;padding:14px 40px;border-radius:10px;text-decoration:none;font-weight:600;font-size:15px;border:none;cursor:pointer;transition:all .4s cubic-bezier(.23,1,.32,1);animation:slide-in .8s ease-out .3s both;box-shadow:0 8px 20px #7c5af033;position:relative;overflow:hidden}.electron-gate-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s;z-index:-1}.electron-gate-btn:hover{transform:translateY(-3px);box-shadow:0 12px 30px #7c5af066}.electron-gate-btn:active{transform:translateY(-1px)}.electron-gate-alt-link{animation:slide-in .8s ease-out .4s both;margin-top:20px}.electron-gate-alt-link a{display:inline-block;color:#8b9dc3;text-decoration:none;font-size:13px;transition:all .3s ease;padding:8px 0;border-bottom:1px solid transparent}.electron-gate-alt-link a:hover{color:#7c5af0;border-bottom-color:#7c5af0}@media(max-width:600px){.electron-gate-container{padding:0 10px}.electron-gate-title{font-size:24px}.electron-gate-text{font-size:14px}.electron-gate-btn{padding:12px 28px;font-size:13px;width:100%}.electron-gate-glow-1{width:300px;height:300px}.electron-gate-glow-2{width:250px;height:250px}.electron-gate-glow-3{width:200px;height:200px}}
