:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--text-tertiary: #94a3b8;--border-color: #e2e8f0;--border-hover: #cbd5e1;--accent-primary: #4169E1;--accent-primary-hover: #3557c4;--accent-primary-light: rgba(65, 105, 225, .08);--accent-primary-muted: rgba(65, 105, 225, .12);--accent-secondary: #00BFA6;--accent-secondary-hover: #009688;--success: #10b981;--success-bg: #ecfdf5;--success-text: #065f46;--warning: #f59e0b;--warning-bg: #fffbeb;--warning-text: #92400e;--error: #ef4444;--error-bg: #fef2f2;--error-text: #991b1b;--info: #3b82f6;--info-bg: #eff6ff;--info-text: #1e40af;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-md: 15px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 20px;--font-size-3xl: 24px;--font-size-4xl: 28px;--font-size-5xl: 32px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--spacing-4xl: 40px;--spacing-5xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .06), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-ring: 0 0 0 3px rgba(65, 105, 225, .15);--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 0 0 1px rgba(0, 0, 0, .02);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04);--glass-bg: rgba(255, 255, 255, .8);--glass-border: rgba(255, 255, 255, .6);--glass-blur: blur(16px);--glass-saturate: saturate(180%);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--color-surface: var(--bg-primary);--color-surface-elevated: var(--bg-primary);--color-hover: var(--bg-tertiary);--color-text: var(--text-primary);--color-border: var(--border-color);--color-primary: var(--accent-primary);--color-primary-rgb: 65, 105, 225;--color-primary-alpha: rgba(65, 105, 225, .08);--color-error-alpha: rgba(239, 68, 68, .08);--color-success: var(--success);--color-warning: var(--warning);--color-error: var(--error);--color-info: var(--info);--color-background-elevated: var(--bg-primary);--color-background-hover: var(--bg-tertiary);--color-text-primary: var(--text-primary);--color-text-secondary: var(--text-secondary)}[data-theme=dark]{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-tertiary: #252936;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--border-color: #2a2f3e;--border-hover: #3b4253;--accent-primary: #60a5fa;--accent-primary-hover: #3b82f6;--accent-primary-light: rgba(96, 165, 250, .1);--accent-primary-muted: rgba(96, 165, 250, .15);--accent-secondary: #34d399;--accent-secondary-hover: #10b981;--success: #34d399;--success-bg: #052e1f;--success-text: #d1fae5;--warning: #fbbf24;--warning-bg: #3d2800;--warning-text: #fef3c7;--error: #f87171;--error-bg: #3b1111;--error-text: #fee2e2;--info: #60a5fa;--info-bg: #0c1e3e;--info-text: #dbeafe;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -4px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 8px 10px -6px rgba(0, 0, 0, .3);--shadow-ring: 0 0 0 3px rgba(96, 165, 250, .2);--shadow-card: 0 1px 3px rgba(0, 0, 0, .2), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .3), 0 2px 8px rgba(0, 0, 0, .2);--glass-bg: rgba(15, 17, 23, .8);--glass-border: rgba(255, 255, 255, .06);--glass-blur: blur(16px);--glass-saturate: saturate(180%);--color-surface: var(--bg-primary);--color-surface-elevated: var(--bg-secondary);--color-surface-dark: var(--bg-secondary);--color-hover: var(--bg-tertiary);--color-border-dark: var(--border-color);--color-primary-rgb: 96, 165, 250;--color-primary-alpha: rgba(96, 165, 250, .12);--color-error-alpha: rgba(248, 113, 113, .12);--color-success-rgb: 52, 211, 153;--color-warning-rgb: 251, 191, 36;--color-error-rgb: 248, 113, 113;--color-info-rgb: 96, 165, 250;--color-background-elevated: var(--bg-secondary);--color-background-hover: var(--bg-tertiary);--color-text-primary: var(--text-primary);--color-text-secondary: var(--text-secondary)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{margin:0;font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);min-width:320px;min-height:100vh;font-feature-settings:"cv02","cv03","cv04","cv11"}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--accent-primary-hover)}button{font-family:inherit;cursor:pointer;transition:all var(--transition-base)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit}h1,h2,h3,h4,h5,h6{margin:0;font-family:var(--font-family);font-weight:600;line-height:1.2;color:var(--text-primary);letter-spacing:-.02em}h1{font-size:var(--font-size-4xl);font-weight:700}h2{font-size:var(--font-size-3xl);font-weight:700}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p{margin:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background-color:var(--accent-primary-muted);color:var(--text-primary)}.tfa-container{display:flex;flex-direction:column;gap:20px}.tfa-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:var(--text-secondary, #6b7280);font-size:14px}.tfa-spinner{animation:tfa-spin 1s linear infinite}@keyframes tfa-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tfa-status-header{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--surface, #f9fafb);border-radius:12px;border:1px solid var(--border, #e5e7eb)}.tfa-status-icon-wrapper{flex-shrink:0}.tfa-status-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center}.tfa-status-icon.tfa-enabled{background:#d1fae5;color:#059669}.tfa-status-icon.tfa-disabled{background:#fef3c7;color:#d97706}.tfa-status-info{flex:1}.tfa-status-title{font-size:16px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 4px}.tfa-status-description{font-size:14px;color:var(--text-secondary, #6b7280);margin:0;line-height:1.5}.tfa-enabled-date{display:flex;align-items:center;gap:6px;font-size:12px;color:#059669;margin:8px 0 0;font-weight:500}.tfa-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px}.tfa-error-dismiss{margin-left:auto;background:none;border:none;color:#dc2626;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.tfa-success{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#d1fae5;border:1px solid #a7f3d0;border-radius:8px;color:#065f46;font-size:13px;font-weight:500;animation:slideDown .3s ease}.tfa-enabled-section{display:flex;flex-direction:column;gap:16px}.tfa-method-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1d4ed8;font-size:13px;font-weight:500;width:fit-content}.tfa-disable-confirm{padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px}.tfa-disable-warning{display:flex;align-items:flex-start;gap:8px;color:#991b1b;font-size:13px;margin:0 0 12px;line-height:1.5}.tfa-disable-warning svg{flex-shrink:0;margin-top:2px}.tfa-disable-actions{display:flex;gap:10px}.btn-disable-2fa{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #fecaca;border-radius:8px;background:#fff;color:#dc2626;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-disable-2fa:hover{background:#fef2f2;border-color:#f87171}.btn-cancel-disable{padding:8px 16px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:var(--text-primary, #374151);font-size:13px;cursor:pointer;transition:background .2s}.btn-cancel-disable:hover{background:#f3f4f6}.btn-confirm-disable{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;background:#dc2626;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.btn-confirm-disable:hover{background:#b91c1c}.btn-confirm-disable:disabled{opacity:.6;cursor:not-allowed}.tfa-setup-prompt{display:flex;flex-direction:column;gap:20px}.tfa-benefits h4{font-size:14px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 12px}.tfa-benefits ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.tfa-benefits li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text-secondary, #6b7280);line-height:1.5}.tfa-benefits li svg{flex-shrink:0;color:#059669;margin-top:2px}.btn-enable-2fa{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:10px;background:linear-gradient(135deg,#4169e1,#3b5fd9);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%;max-width:320px}.btn-enable-2fa:hover{background:linear-gradient(135deg,#3b5fd9,#3050c0);box-shadow:0 4px 12px #4169e14d;transform:translateY(-1px)}.tfa-setup-flow{display:flex;flex-direction:column;gap:20px}.tfa-step-indicator{display:flex;align-items:center;gap:0;padding:0 20px}.tfa-step{display:flex;flex-direction:column;align-items:center;gap:4px}.tfa-step-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;background:#e5e7eb;color:#6b7280;transition:all .3s}.tfa-step.active .tfa-step-num{background:#4169e1;color:#fff}.tfa-step.completed .tfa-step-num{background:#059669;color:#fff}.tfa-step-label{font-size:11px;font-weight:500;color:#6b7280}.tfa-step.active .tfa-step-label{color:#4169e1}.tfa-step.completed .tfa-step-label{color:#059669}.tfa-step-line{flex:1;height:2px;background:#e5e7eb;margin:0 8px 20px;transition:background .3s}.tfa-step-line.active{background:#4169e1}.tfa-scan-section{text-align:center}.tfa-scan-section h4{font-size:16px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 4px}.tfa-instruction{font-size:13px;color:var(--text-secondary, #6b7280);margin:0 0 20px;line-height:1.5}.tfa-qr-wrapper{display:flex;justify-content:center;margin-bottom:20px}.tfa-qr-code{padding:16px;background:#fff;border-radius:12px;border:2px solid #e5e7eb;display:inline-block;box-shadow:0 2px 8px #0000000a}.tfa-qr-code img{display:block;border-radius:4px}.tfa-manual-entry{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:14px;margin-bottom:20px}.tfa-manual-label{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--text-secondary, #6b7280);margin:0 0 8px}.tfa-manual-key{display:flex;align-items:center;justify-content:center;gap:8px}.tfa-manual-key code{font-family:SF Mono,Roboto Mono,Consolas,monospace;font-size:15px;font-weight:600;color:var(--text-primary, #111827);letter-spacing:2px;background:#fff;padding:8px 14px;border-radius:6px;border:1px solid #d1d5db}.tfa-copy-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;cursor:pointer;transition:all .2s}.tfa-copy-btn:hover{background:#f3f4f6;color:#4169e1}.tfa-verify-section{text-align:center}.tfa-verify-section h4{font-size:16px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 4px}.tfa-code-inputs{display:flex;justify-content:center;gap:8px;margin:24px 0}.tfa-code-input{width:48px;height:56px;border:2px solid #d1d5db;border-radius:10px;text-align:center;font-size:22px;font-weight:700;font-family:SF Mono,Roboto Mono,Consolas,monospace;color:var(--text-primary, #111827);background:#fff;outline:none;transition:all .2s;caret-color:#4169e1}.tfa-code-input:focus{border-color:#4169e1;box-shadow:0 0 0 3px #4169e126}.tfa-code-input:hover:not(:focus){border-color:#9ca3af}.tfa-flow-actions{display:flex;justify-content:center;gap:12px}.btn-cancel-setup,.btn-back-step{padding:10px 20px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:var(--text-primary, #374151);font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.btn-cancel-setup:hover,.btn-back-step:hover{background:#f3f4f6}.btn-next-step{padding:10px 24px;border:none;border-radius:8px;background:#4169e1;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-next-step:hover{background:#3b5fd9}.btn-verify-code{display:flex;align-items:center;gap:6px;padding:10px 24px;border:none;border-radius:8px;background:#059669;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-verify-code:hover{background:#047857}.btn-verify-code:disabled{opacity:.5;cursor:not-allowed}.tfa-error-section{display:flex;flex-direction:column;align-items:center;padding:30px;gap:12px;color:#dc2626}.tfa-error-section p{font-size:14px;margin:0;text-align:center}.btn-retry{padding:10px 20px;border:1px solid #fecaca;border-radius:8px;background:#fff;color:#dc2626;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.btn-retry:hover{background:#fef2f2}@media(max-width:640px){.tfa-status-header{flex-direction:column;align-items:center;text-align:center}.tfa-enabled-date{justify-content:center}.tfa-code-input{width:40px;height:48px;font-size:18px}.tfa-code-inputs{gap:6px}.tfa-flow-actions,.tfa-manual-key{flex-direction:column}.tfa-manual-key code{font-size:13px;letter-spacing:1px}.tfa-benefits li{font-size:12px}.btn-enable-2fa{max-width:100%}}.app-header{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 20px;background:var(--glass-bg, rgba(255, 255, 255, .8));backdrop-filter:var(--glass-blur, blur(16px));-webkit-backdrop-filter:var(--glass-blur, blur(16px));border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;transition:background var(--transition-base)}.header-left,.header-right{display:flex;align-items:center;gap:6px}.header-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1);line-height:1;white-space:nowrap}.header-btn:active{transform:scale(.97)}.header-btn svg{flex-shrink:0;opacity:.7;transition:opacity .15s ease}.header-btn:hover svg{opacity:1}.notification-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--error, #ef4444);color:#fff;border-radius:8px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-primary);line-height:1;animation:badge-pop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}.user-btn{padding:4px 10px 4px 4px;gap:8px;min-width:auto;border-color:transparent}.user-btn:hover{border-color:var(--border-color)}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary, #4169E1) 0%,var(--accent-secondary, #00BFA6) 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;font-weight:600}.user-avatar.large{width:44px;height:44px;font-size:16px}.user-info{display:flex;flex-direction:column;align-items:flex-start;min-width:0;gap:0}.user-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;line-height:1.3}.user-email{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;line-height:1.3}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl, 12px);box-shadow:0 10px 40px #00000014,0 2px 8px #0000000a;padding:6px;z-index:1000;animation:dropdown-enter .2s cubic-bezier(.4,0,.2,1);transform-origin:top right}@keyframes dropdown-enter{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-primary);text-align:left;transition:all .15s ease}.dropdown-item:hover{background:var(--bg-tertiary)}.dropdown-item.active{background:var(--accent-primary-light, rgba(65, 105, 225, .08));color:var(--accent-primary)}.dropdown-item svg{flex-shrink:0;color:var(--text-tertiary);transition:color .15s ease}.dropdown-item:hover svg{color:var(--text-secondary)}.logout-item{color:var(--error, #ef4444)}.logout-item:hover{background:var(--error-bg)}.logout-item svg{color:var(--error, #ef4444)}.user-menu{min-width:260px}.dropdown-header{display:flex;align-items:center;gap:12px;padding:10px}.user-details{flex:1;min-width:0}.user-details .user-name{font-size:14px;font-weight:600;max-width:100%}.user-details .user-email{font-size:12px;max-width:100%;color:var(--text-secondary)}.dropdown-divider{height:1px;background:var(--border-color);margin:4px 0}@media(max-width:768px){.app-header{padding:0 12px;height:52px}.user-info{display:none}.user-btn{padding:4px}.header-btn span{display:none}.header-btn{padding:7px;min-width:34px;height:34px;justify-content:center}}.landing-page{min-height:100vh;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text-primary, #0f172a);background:var(--bg-primary, #ffffff)}.landing-header{position:sticky;top:0;z-index:100;background:#ffffffd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(0,0,0,.05)}.landing-header-container{max-width:1200px;margin:0 auto;padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:baseline;gap:3px;font-size:1.375rem;font-weight:800;letter-spacing:-.03em}.landing-logo-cf{color:var(--accent-primary, #4169E1)}.landing-logo-hub{color:var(--accent-secondary, #00BFA6)}.landing-footer .landing-logo-cf{color:#fff}.landing-header-btn{padding:.5rem 1.25rem;background:var(--accent-primary, #4169E1);color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.landing-header-btn:hover{filter:brightness(.92);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.landing-hero{background:linear-gradient(135deg,var(--accent-primary, #4169E1) 0%,var(--accent-secondary, #00BFA6) 100%);color:#fff;padding:5rem 2rem;position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:-40%;right:-15%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07) 0%,transparent 70%);pointer-events:none}.landing-hero:after{content:"";position:absolute;bottom:-25%;left:-8%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);pointer-events:none}.landing-hero-container{max-width:1200px;margin:0 auto;position:relative;z-index:1}.landing-hero-content{display:grid;grid-template-columns:1.2fr .8fr;gap:4rem;align-items:center}.landing-badge{display:inline-flex;align-items:center;gap:6px;background:#ffffff1f;color:#fff;padding:.375rem 1rem;border-radius:100px;font-size:.8125rem;font-weight:600;letter-spacing:.01em;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.landing-hero-title{font-size:3rem;font-weight:800;line-height:1.1;margin:0 0 1.25rem;letter-spacing:-.03em;color:#fff}.landing-highlight{color:#ffffffb3}.landing-hero-tagline{font-size:1.125rem;line-height:1.7;opacity:.9;margin:0 0 .5rem;max-width:560px}.landing-hero-description{font-size:.9375rem;line-height:1.7;opacity:.65;margin:0 0 2rem;max-width:480px}.landing-hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}.landing-btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;background:#fff;color:var(--accent-primary, #4169E1);border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 12px #0000001a}.landing-btn-primary:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.landing-btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;background:#ffffff14;color:#fff;border:1.5px solid rgba(255,255,255,.25);border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.landing-btn-secondary:hover{border-color:#ffffff80;background:#ffffff24}.landing-stats-card{background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:2rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.landing-stats-title{font-size:1.125rem;font-weight:700;margin:0 0 1.5rem;text-align:center;opacity:.95}.landing-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.landing-stat-item{text-align:center;padding:.5rem}.landing-stat-value{display:block;font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:.125rem;letter-spacing:-.02em}.landing-stat-label{display:block;font-size:.75rem;opacity:.65;font-weight:500}.landing-features{padding:5rem 2rem;background:var(--bg-primary, #ffffff)}.landing-features-container{max-width:1200px;margin:0 auto}.landing-features-header{text-align:center;margin-bottom:3.5rem}.landing-section-title{font-size:2rem;font-weight:800;margin:0 0 .75rem;color:var(--text-primary, #0f172a);letter-spacing:-.03em}.landing-section-subtitle{font-size:1rem;color:var(--text-secondary, #64748b);max-width:560px;margin:0 auto;line-height:1.6}.landing-features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.landing-feature-card{background:var(--bg-primary, #ffffff);border-radius:14px;padding:1.75rem 1.25rem;text-align:center;border:1px solid var(--border-color, #e2e8f0);transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #00000008}.landing-feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014;border-color:var(--accent-primary-muted, rgba(65, 105, 225, .2))}.landing-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:var(--accent-primary-light, rgba(65, 105, 225, .08));color:var(--accent-primary, #4169E1);margin-bottom:1.25rem}.landing-feature-title{font-size:1rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary, #0f172a);letter-spacing:-.01em}.landing-feature-description{font-size:.8125rem;color:var(--text-secondary, #64748b);line-height:1.6;margin:0}.landing-benefits{padding:5rem 2rem;background:var(--bg-secondary, #f8fafc)}.landing-benefits-container{max-width:1200px;margin:0 auto}.landing-benefits-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.landing-benefits-text .landing-section-title{text-align:left}.landing-benefits-subtitle{font-size:1rem;color:var(--text-secondary, #64748b);line-height:1.6;margin:0 0 2rem}.landing-benefits-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.landing-benefit-item{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;color:var(--text-primary, #0f172a)}.benefit-check{flex-shrink:0;color:var(--accent-secondary, #00BFA6)}.landing-metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.landing-metric-card{background:var(--bg-primary, #ffffff);border-radius:12px;padding:1.5rem;text-align:center;border:1px solid var(--border-color, #e2e8f0);box-shadow:0 1px 3px #00000008;transition:all .25s cubic-bezier(.4,0,.2,1)}.landing-metric-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000f}.metric-icon{display:block;font-size:1.75rem;margin-bottom:.375rem}.metric-title{font-size:1rem;font-weight:700;margin:0 0 .125rem;color:var(--text-primary, #0f172a)}.metric-subtitle{font-size:.8125rem;color:var(--text-secondary, #64748b);margin:0}.landing-feedback-section{padding:5rem 2rem;background:var(--bg-primary, #ffffff)}.landing-feedback-container{max-width:1200px;margin:0 auto}.landing-section-header-center{text-align:center;margin-bottom:3rem}.landing-section-header-center .landing-section-subtitle{max-width:560px}.feedback-slider{max-width:720px;margin:0 auto;position:relative}.feedback-card{background:var(--bg-primary, #ffffff);border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000000d;border:1px solid var(--border-color, #e2e8f0);position:relative;min-height:220px;transition:transform .2s cubic-bezier(.4,0,.2,1)}.feedback-card:hover{transform:translateY(-1px)}.feedback-quote-icon{position:absolute;top:1rem;right:1.5rem;color:var(--accent-primary, #4169E1);opacity:.3}.feedback-subject{font-size:1.0625rem;font-weight:700;color:var(--accent-primary, #4169E1);margin:.5rem 0}.feedback-message{font-size:.9375rem;line-height:1.65;font-style:italic;color:var(--text-secondary, #64748b);min-height:50px;margin:0 0 1.25rem}.feedback-author-row{display:flex;align-items:center;justify-content:space-between}.feedback-author{display:flex;align-items:center;gap:.75rem}.feedback-avatar{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--accent-primary, #4169E1);color:#fff;font-size:.8125rem;font-weight:700}.feedback-name{display:block;font-weight:600;color:var(--text-primary, #0f172a);font-size:.875rem}.feedback-date{display:block;font-size:.75rem;color:var(--text-tertiary, #94a3b8)}.feedback-dots{display:flex;gap:.375rem;align-items:center}.feedback-dot{width:7px;height:7px;border-radius:50%;background:var(--border-color, #d1d5db);cursor:pointer;transition:all .2s ease}.feedback-dot.active{background:var(--accent-primary, #4169E1);width:20px;border-radius:4px}.feedback-arrow{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e2e8f0);box-shadow:0 2px 8px #00000014;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);color:var(--text-secondary, #64748b)}.feedback-arrow:hover{background:var(--accent-primary, #4169E1);border-color:var(--accent-primary, #4169E1);color:#fff;box-shadow:0 4px 12px #0000001f}.feedback-arrow-left{left:-18px}.feedback-arrow-right{right:-18px}.feedback-slider-skeleton{max-width:720px;margin:0 auto;background:var(--bg-primary, #ffffff);border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000000a;border:1px solid var(--border-color, #e2e8f0)}.skeleton-line{height:18px;background:linear-gradient(90deg,var(--bg-tertiary, #f1f5f9) 25%,var(--bg-secondary, #f8fafc) 50%,var(--bg-tertiary, #f1f5f9) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite;border-radius:6px;margin-bottom:.875rem}.skeleton-line.w60{width:60%}.skeleton-line.w30{width:30%}.skeleton-block{height:72px;background:linear-gradient(90deg,var(--bg-tertiary, #f1f5f9) 25%,var(--bg-secondary, #f8fafc) 50%,var(--bg-tertiary, #f1f5f9) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite;border-radius:6px;margin-bottom:.875rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.feedback-slider-empty{max-width:720px;margin:0 auto;text-align:center;padding:2rem;background:var(--info-bg, #eff6ff);border-radius:12px;color:var(--accent-primary, #4169E1);font-size:.875rem;border:1px solid var(--accent-primary-muted, rgba(65, 105, 225, .15))}.star-rating{display:inline-flex;align-items:center}.landing-public-feedback-section{padding:5rem 2rem;background:var(--bg-secondary, #f8fafc)}.landing-feedback-form-container{max-width:1200px;margin:0 auto}.feedback-form-card{max-width:560px;margin:0 auto;background:var(--bg-primary, #ffffff);border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000000d;border:1px solid var(--border-color, #e2e8f0)}.feedback-form-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;color:var(--accent-primary, #4169E1)}.feedback-form-header h3{font-size:1.125rem;font-weight:700;margin:0;color:var(--text-primary, #0f172a)}.feedback-form-desc{font-size:.875rem;color:var(--text-secondary, #64748b);line-height:1.6;margin:0 0 1.5rem}.feedback-alert{padding:.75rem 1rem;border-radius:8px;font-size:.8125rem;margin-bottom:1.25rem;font-weight:500}.feedback-alert-success{background:var(--success-bg, #ecfdf5);color:var(--success-text, #065f46);border:1px solid rgba(16,185,129,.2)}.feedback-alert-error{background:var(--error-bg, #fef2f2);color:var(--error-text, #991b1b);border:1px solid rgba(239,68,68,.2)}.feedback-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.375rem}.form-field label{font-size:.8125rem;font-weight:600;color:var(--text-primary, #0f172a)}.form-field input,.form-field textarea{padding:.625rem .875rem;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;font-family:inherit;font-size:.875rem;color:var(--text-primary, #0f172a);transition:border-color .2s ease,box-shadow .2s ease;background:var(--bg-primary, #ffffff)}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--accent-primary, #4169E1);box-shadow:0 0 0 3px var(--accent-primary-light, rgba(65, 105, 225, .08))}.form-field input:disabled,.form-field textarea:disabled{opacity:.6;cursor:not-allowed}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-tertiary, #94a3b8)}.field-error{font-size:.75rem;color:var(--error, #ef4444)}.feedback-submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;background:var(--accent-primary, #4169E1);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000001a;margin-top:.25rem}.feedback-submit-btn:hover:not(:disabled){filter:brightness(.92);transform:translateY(-1px);box-shadow:0 4px 16px #00000026}.feedback-submit-btn:disabled{opacity:.6;cursor:not-allowed}.landing-cta{padding:5rem 2rem;background:linear-gradient(135deg,var(--accent-primary, #4169E1) 0%,var(--accent-secondary, #00BFA6) 100%);color:#fff;text-align:center;position:relative;overflow:hidden}.landing-cta:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(255,255,255,.06),transparent 60%);pointer-events:none}.landing-cta-container{max-width:600px;margin:0 auto;position:relative;z-index:1}.landing-cta-title{font-size:2rem;font-weight:800;margin:0 0 .875rem;letter-spacing:-.03em;color:#fff}.landing-cta-description{font-size:1rem;color:#ffffffd9;margin:0 0 2rem;line-height:1.6}.landing-cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;background:#fff;color:var(--accent-primary, #4169E1);border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 12px #0000001a}.landing-cta-btn:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.landing-footer{background:#0f172a;color:#94a3b8;padding:1.75rem 2rem;margin-top:auto}.landing-footer-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.landing-footer-brand{display:flex;align-items:center;gap:1.5rem}.landing-logo-footer{font-size:1.125rem}.landing-footer-text{font-size:.8125rem;margin:0;color:#ffffff80}.landing-footer-links{display:flex;gap:1.5rem}.landing-footer-link{color:#64748b;text-decoration:none;font-size:.8125rem;transition:color .2s ease}.landing-footer-link:hover{color:#fff}@media(max-width:1024px){.landing-hero-content{grid-template-columns:1fr;gap:3rem}.landing-features-grid{grid-template-columns:repeat(2,1fr)}.landing-hero-title{font-size:2.5rem}.landing-benefits-grid{grid-template-columns:1fr;gap:3rem}.feedback-arrow-left{left:-10px}.feedback-arrow-right{right:-10px}}@media(max-width:640px){.landing-hero{padding:3rem 1.25rem}.landing-hero-title{font-size:2rem}.landing-hero-actions{flex-direction:column}.landing-btn-primary,.landing-btn-secondary{width:100%;justify-content:center}.landing-features{padding:3rem 1.25rem}.landing-features-grid{grid-template-columns:1fr}.landing-benefits{padding:3rem 1.25rem}.landing-metrics-grid{grid-template-columns:1fr 1fr}.landing-cta{padding:3rem 1.25rem}.landing-cta-title,.landing-section-title{font-size:1.75rem}.landing-footer-container{flex-direction:column;text-align:center}.landing-footer-brand{flex-direction:column;gap:.5rem}.landing-header-container{padding:.75rem 1.25rem}.landing-feedback-section,.landing-public-feedback-section{padding:3rem 1.25rem}.feedback-card,.feedback-form-card{padding:1.5rem}.feedback-arrow{display:none}}.notifications-overlay{position:fixed;inset:0;background:transparent;z-index:999}.notifications-popup{position:fixed;top:70px;right:16px;width:400px;max-width:calc(100vw - 32px);max-height:500px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;z-index:1000;animation:slideDown .2s ease-out}.notifications-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-border)}.notifications-title{display:flex;align-items:center;gap:8px}.notifications-title h3{margin:0;font-size:16px;font-weight:600;color:var(--color-text)}.notification-count{background:var(--color-error);color:#fff;font-size:12px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.icon-btn{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--color-text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center}.notifications-body{flex:1;overflow-y:auto;min-height:200px}.notifications-loading,.notifications-error,.notifications-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--color-text-secondary)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.notifications-error svg,.notifications-empty svg{color:var(--color-text-secondary);margin-bottom:12px}.notifications-list{display:flex;flex-direction:column}.notification-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color .2s;position:relative}.notification-item:hover{background:var(--color-hover)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background:rgba(var(--color-primary-rgb),.05)}.notification-message{margin:0 0 6px;font-size:14px;color:var(--color-text);line-height:1.4}.notification-item.read .notification-message{color:var(--color-text-secondary)}.notification-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-secondary)}.notification-category{padding:2px 8px;background:var(--color-hover);border-radius:4px;font-size:11px;text-transform:capitalize}.unread-dot{position:absolute;top:16px;right:16px;width:8px;height:8px;background:var(--color-primary);border-radius:50%}.notifications-footer{padding:12px 16px;border-top:1px solid var(--color-border)}.view-all-btn{width:100%;padding:8px;background:transparent;border:1px solid var(--color-border);border-radius:6px;color:var(--color-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.view-all-btn:hover{background:var(--color-hover);border-color:var(--color-primary)}[data-theme=dark] .notifications-popup{background:var(--color-surface-dark);border-color:var(--color-border-dark)}[data-theme=dark] .notification-item.unread{background:rgba(var(--color-primary-rgb),.1)}@media(max-width:768px){.notifications-popup{width:calc(100vw - 32px);right:16px}}.dashboard-layout{display:flex;min-height:100vh;background:var(--bg-secondary)}.sidebar{width:260px;background:var(--bg-primary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;height:100vh;position:sticky;top:0;overflow-y:auto;overflow-x:hidden;transition:width .3s cubic-bezier(.4,0,.2,1)}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:transparent;border-radius:3px}.sidebar:hover::-webkit-scrollbar-thumb{background:var(--border-color)}.sidebar-header{padding:20px 16px 16px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-primary);z-index:10}.brand{display:flex;align-items:center;gap:10px}.org-logo{width:38px;height:38px;border-radius:10px;border:1px solid var(--border-color);object-fit:cover;background:#fff;flex-shrink:0}.brand-text{display:flex;flex-direction:column;min-width:0;gap:1px}.brand-name{font-size:14px;font-weight:700;color:var(--text-primary);line-height:1.2;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}.brand-tagline{font-size:10px;color:var(--text-tertiary);font-weight:600;letter-spacing:.06em;text-transform:uppercase;line-height:1.3;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logo{display:flex;align-items:center;gap:10px;margin-bottom:2px}.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.logo-text{display:flex;flex-direction:column}.logo-hub{font-size:18px;font-weight:700;color:var(--accent-secondary);letter-spacing:.3px;line-height:1.2}.logo-subtitle{font-size:10px;color:var(--text-tertiary);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-top:1px}.user-card{padding:14px;background:var(--bg-secondary);margin:12px 12px 4px;border-radius:10px;border:1px solid var(--border-color)}.user-welcome{font-size:11px;color:var(--text-tertiary);margin-bottom:2px;font-weight:500}.user-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px;letter-spacing:-.01em}.user-badge{display:inline-flex;align-items:center;padding:3px 10px;background:var(--accent-primary-light, rgba(65, 105, 225, .08));color:var(--accent-primary);font-size:11px;font-weight:600;border-radius:6px;letter-spacing:.01em}.sidebar-nav{padding:8px;flex:1}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:1px;border-radius:8px;color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all .15s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary-light, rgba(65, 105, 225, .08));color:var(--accent-primary);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 3px 3px 0;background:var(--accent-primary)}.nav-item.active .nav-icon{color:var(--accent-primary)}.nav-icon{flex-shrink:0;opacity:.7;transition:opacity .15s ease}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}.nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-section{padding:12px 8px;border-top:1px solid var(--border-color);margin-top:4px}.section-title{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:0 12px 6px}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-color);margin-top:auto;position:sticky;bottom:0;background:var(--bg-primary);z-index:10}.footer-logo{font-size:10px;color:var(--text-tertiary);text-align:center;font-weight:500}.powered-by-text{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:6px;opacity:.7}.footer-logo img{max-width:100px;height:auto;max-height:28px;object-fit:contain;opacity:.6;transition:opacity .2s ease}.footer-logo img:hover{opacity:.9}.sidebar.collapsed{width:64px}.sidebar.collapsed .sidebar-header{padding:16px 12px}.sidebar.collapsed .brand-text,.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar.collapsed .nav-item.active:before{top:8px;bottom:8px}.sidebar.collapsed .user-card{padding:10px;margin:8px 6px 4px}.sidebar.collapsed .user-welcome,.sidebar.collapsed .user-name{display:none}.sidebar.collapsed .user-badge{font-size:9px;padding:2px 6px}.sidebar.collapsed .logo-text,.sidebar.collapsed .section-title{display:none}.sidebar.collapsed .sidebar-section{padding:0 4px 8px}.sidebar.collapsed .footer-logo .powered-by-text{display:none}.sidebar.collapsed .footer-logo img{max-width:32px}.main-content{flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0}.top-header{height:56px;background:var(--glass-bg, rgba(255, 255, 255, .8));backdrop-filter:var(--glass-blur, blur(16px));-webkit-backdrop-filter:var(--glass-blur, blur(16px));border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:10}.header-left{flex:1}.header-right{display:flex;align-items:center;gap:6px}.header-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.header-btn:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary)}.header-btn.icon-only{padding:7px;min-width:34px;height:34px;justify-content:center}.notification-btn{position:relative}.notification-badge{position:absolute;top:2px;right:2px;background:var(--error);color:#fff;font-size:10px;font-weight:700;padding:0 4px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:2px solid var(--bg-primary)}.user-menu{margin-left:4px}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:12px}.user-avatar:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.page-content{flex:1;padding:24px;overflow-y:auto}@media(max-width:1024px){.sidebar{width:240px}}@media(max-width:768px){.sidebar{position:fixed;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1);box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:0 0 60px #00000026}.page-content{padding:16px}.top-header{padding:0 16px}}.dashboard-page{max-width:1400px;margin:0 auto}.page-header{margin-bottom:28px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.025em}.page-subtitle{font-size:14px;color:var(--text-secondary)}.activity-overview{margin-bottom:28px}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--text-primary)}.section-header h2,.section-header h3{font-size:16px;font-weight:600;margin:0;letter-spacing:-.01em}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:var(--bg-primary);padding:20px;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.04));transition:all .2s cubic-bezier(.4,0,.2,1)}.stat-card:hover{box-shadow:var(--shadow-card-hover, 0 8px 24px rgba(0,0,0,.08));transform:translateY(-2px)}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.03em}.stat-label{font-size:13px;color:var(--text-secondary);font-weight:500}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.view-all-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;padding:4px 8px;border-radius:6px}.view-all-btn:hover{color:var(--accent-primary-hover);background:var(--accent-primary-light, rgba(65, 105, 225, .06))}.quick-actions{background:var(--bg-primary);padding:20px;border-radius:12px;border:1px solid var(--border-color);margin-bottom:20px;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.04))}.section-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.01em}.actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.action-card{display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:10px;border:none;text-align:left;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.action-card.action-primary{background:var(--accent-secondary);color:#fff}.action-card.action-info{background:var(--info-bg);color:var(--info-text)}.action-card.action-warning{background:var(--warning-bg);color:var(--warning-text)}.action-card.action-error{background:var(--error-bg);color:var(--error-text)}.action-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-card:active{transform:translateY(0)}.action-icon{flex-shrink:0}.action-content h4{font-size:14px;font-weight:600;margin:0 0 3px}.action-content p{font-size:12px;opacity:.85;margin:0;line-height:1.4}.recent-shipments{background:var(--bg-primary);padding:20px;border-radius:12px;border:1px solid var(--border-color);margin-bottom:20px;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.04))}.shipments-list{display:flex;flex-direction:column;gap:8px}.shipment-item{display:flex;align-items:center;gap:14px;padding:12px;background:var(--bg-secondary);border-radius:8px;transition:background .15s ease}.shipment-item:hover{background:var(--bg-tertiary)}.shipment-icon{flex-shrink:0;width:36px;height:36px;background:var(--info-bg);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--info-text)}.shipment-info{flex:1;min-width:0}.shipment-id{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:3px}.shipment-status{display:inline-flex;align-items:center;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:600;margin-bottom:3px}.status-info{background:var(--info-bg);color:var(--info-text)}.status-primary{background:var(--success-bg);color:var(--success-text)}.shipment-company{font-size:12px;color:var(--text-tertiary)}.shipment-view{flex-shrink:0;width:32px;height:32px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-primary);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.shipment-view:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-primary)}.notifications-section{background:var(--bg-primary);padding:20px;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.04))}.notifications-list{display:flex;flex-direction:column;gap:8px}.dashboard-notification-item{width:100%;display:flex;flex-direction:column;gap:3px;padding:12px 14px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);text-align:left;cursor:pointer;transition:all .15s ease}.dashboard-notification-item:hover{background:var(--bg-tertiary);border-color:var(--accent-primary-muted, rgba(65, 105, 225, .2))}.dashboard-notification-item.unread{border-left:3px solid var(--accent-primary);box-shadow:none}.dashboard-notification-message{font-size:13px;color:var(--text-primary);line-height:1.4}.dashboard-notification-item.read .dashboard-notification-message{color:var(--text-secondary)}.dashboard-notification-time{font-size:11px;color:var(--text-tertiary)}.empty-state{padding:32px 16px;text-align:center;color:var(--text-tertiary);font-size:13px}.profile-summary{background:var(--bg-primary);padding:20px;border-radius:12px;border:1px solid var(--border-color);margin-bottom:20px;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.04))}.profile-card{display:flex;flex-direction:column;align-items:center;text-align:center}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary, #4169E1) 0%,var(--accent-secondary, #00BFA6) 100%);color:#fff;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:14px}.profile-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:3px;letter-spacing:-.01em}.profile-email{font-size:13px;color:var(--text-secondary);margin-bottom:10px}.profile-badge{display:inline-flex;align-items:center;padding:3px 10px;background:var(--success-bg);color:var(--success-text);font-size:11px;font-weight:600;border-radius:6px;margin-bottom:20px}.profile-completeness{width:100%;margin-bottom:16px}.completeness-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px}.completeness-header span:first-child{color:var(--text-secondary);font-weight:500}.completeness-value{color:var(--text-primary);font-weight:600}.progress-bar{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary, #4169E1) 0%,var(--accent-secondary, #00BFA6) 100%);border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1)}.completeness-missing{margin-top:6px;font-size:11px;color:var(--text-tertiary)}.btn-update-profile{width:100%;padding:9px 16px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-update-profile:hover{filter:brightness(.92);transform:translateY(-1px);box-shadow:0 2px 8px #0000001f}.recent-ratings{background:var(--bg-primary);padding:20px;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.04))}.ratings-list{display:flex;flex-direction:column;gap:10px}.rating-item{padding:14px;background:var(--bg-secondary);border-radius:8px;transition:background .15s ease}.rating-item:hover{background:var(--bg-tertiary)}.rating-company{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.rating-published{display:inline-flex;align-items:center;padding:2px 8px;background:var(--success-bg);color:var(--success-text);font-size:10px;font-weight:600;border-radius:5px;margin-bottom:6px}.rating-stars{display:flex;gap:2px;margin-bottom:6px}.star-filled{color:var(--warning)}.star-empty{color:var(--border-color)}.rating-date{font-size:11px;color:var(--text-tertiary);margin-bottom:6px}.rating-comment{font-size:12px;color:var(--text-secondary);font-style:italic;line-height:1.5}@media(max-width:1200px){.dashboard-grid,.actions-grid{grid-template-columns:1fr}}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.page-content{padding:16px}}.loading-stats{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--text-secondary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;color:var(--text-secondary)}.loading-state p,.loading-stats p{margin-top:10px;font-size:13px}.spin-icon{animation:spin 1s linear infinite;color:var(--accent-primary)}.search-companies-page{max-width:1400px;margin:0 auto}.page-header{margin-bottom:var(--spacing-3xl)}.page-title{font-size:var(--font-size-4xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:var(--font-size-md);color:var(--text-secondary)}.search-section{background:var(--bg-primary);padding:var(--spacing-2xl);border-radius:var(--radius-lg);border:1px solid var(--border-color);margin-bottom:var(--spacing-2xl)}.search-bar{position:relative;margin-bottom:var(--spacing-xl)}.search-icon{position:absolute;left:var(--spacing-lg);top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-lg) var(--spacing-md) var(--spacing-5xl);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-md);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-base)}.search-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-primary)}.filter-section{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.filter-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.filter-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.filter-btn{padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base)}.filter-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.results-summary{margin-bottom:var(--spacing-xl);color:var(--text-secondary);font-size:var(--font-size-sm)}.results-summary strong{color:var(--text-primary);font-weight:600}.companies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--spacing-2xl)}.company-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-2xl);transition:all var(--transition-base)}.company-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.company-header{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.company-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.company-info{flex:1}.company-name-row{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.company-name{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0}.verified-badge{color:var(--success);flex-shrink:0}.company-registration{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0}.company-status{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;flex-shrink:0}.status-active{background:var(--success-bg);color:var(--success-text)}.status-suspended{background:var(--warning-bg);color:var(--warning-text)}.status-inactive{background:var(--error-bg);color:var(--error-text)}.company-details{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.detail-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-size-sm)}.detail-item svg{color:var(--accent-primary)}.company-services{margin-bottom:var(--spacing-xl)}.services-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.services-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.service-tag{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:500}.company-actions{display:flex;gap:var(--spacing-md)}.btn-primary,.btn-secondary{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base);border:none}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.empty-state{text-align:center;padding:var(--spacing-5xl);color:var(--text-tertiary)}.empty-state svg{margin-bottom:var(--spacing-xl);opacity:.5}.empty-state h3{font-size:var(--font-size-xl);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.empty-state p{font-size:var(--font-size-md)}@media(max-width:768px){.companies-grid{grid-template-columns:1fr}.filter-section{flex-direction:column;align-items:flex-start}.filter-buttons{width:100%}.filter-btn{flex:1;text-align:center}.company-actions{flex-direction:column}}.sf-page{max-width:1200px;margin:0 auto;padding:24px}.sf-header{margin-bottom:24px}.sf-header h1{font-size:1.75rem;font-weight:700;margin:0 0 4px;color:var(--text-primary, #1a1a2e)}.sf-header p{color:var(--text-secondary, #64748b);margin:0}.sf-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border-color, #e2e8f0);margin-bottom:24px;overflow-x:auto}.sf-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary, #64748b);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .2s}.sf-tab:hover{color:var(--primary, #3b82f6);background:var(--bg-hover, #f1f5f9);border-radius:8px 8px 0 0}.sf-tab.active{color:var(--primary, #3b82f6);border-bottom-color:var(--primary, #3b82f6);font-weight:600}.sf-tab-content{min-height:400px}.sf-section-header{margin-bottom:20px}.sf-section-header h2{display:flex;align-items:center;gap:8px;font-size:1.25rem;font-weight:600;margin:0}.sf-alert{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.sf-alert.success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.sf-alert.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.sf-loading{display:flex;justify-content:center;align-items:center;padding:60px 0}.sf-loading-sm{display:flex;justify-content:center;padding:20px}.sf-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;color:var(--text-secondary, #94a3b8);text-align:center}.sf-empty p{font-size:1.1rem;font-weight:500;margin:0}.sf-empty span{font-size:.875rem}.sf-muted{color:var(--text-secondary, #64748b);font-size:.9rem;margin:4px 0 16px}.sf-rate-selection h2{font-size:1.25rem;font-weight:600;margin:0 0 4px}.sf-entity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:20px}.sf-entity-card{border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s;background:var(--bg-card, #fff)}.sf-entity-card:hover{border-color:var(--primary, #3b82f6);box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.sf-entity-name{font-weight:600;font-size:1.05rem;margin-bottom:8px}.sf-entity-meta{display:flex;align-items:center;gap:8px;color:var(--text-secondary, #64748b);font-size:.85rem;margin-bottom:8px}.sf-entity-rating{display:flex;align-items:center;gap:4px;font-weight:600;color:#f59e0b}.sf-entity-services{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.sf-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;font-size:.75rem;background:var(--bg-chip, #f1f5f9);color:var(--text-secondary, #475569)}.sf-chip svg{cursor:pointer;opacity:.6}.sf-chip svg:hover{opacity:1}.sf-rate-form{max-width:700px}.sf-rate-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.sf-rate-form-header h2{font-size:1.25rem;font-weight:600;margin:0}.sf-btn-link{background:none;border:none;color:var(--primary, #3b82f6);cursor:pointer;font-size:.9rem}.sf-btn-link:hover{text-decoration:underline}.sf-categories h3{font-size:1rem;font-weight:600;margin:20px 0 12px}.sf-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.sf-cat-item{display:flex;flex-direction:column;gap:6px}.sf-cat-item label{font-size:.85rem;font-weight:500;color:var(--text-secondary, #64748b)}.sf-overall{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg-highlight, #eff6ff);border-radius:10px;margin:20px 0}.sf-overall span{font-weight:600}.sf-overall-value{display:flex;align-items:center;gap:12px}.sf-overall-value strong{font-size:1.5rem;color:var(--primary, #3b82f6)}.sf-stars{display:flex;gap:2px}.sf-form-group{margin-bottom:16px}.sf-form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary, #374151);margin-bottom:6px}.sf-form-group input,.sf-form-group select,.sf-form-group textarea{width:100%;padding:10px 14px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;font-size:.9rem;background:var(--bg-input, #fff);color:var(--text-primary, #1f2937);transition:border-color .2s;box-sizing:border-box}.sf-form-group input:focus,.sf-form-group select:focus,.sf-form-group textarea:focus{outline:none;border-color:var(--primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.sf-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.sf-form-row-3{grid-template-columns:1fr 1fr 1fr}.sf-file-upload{display:flex;flex-direction:column;gap:8px}.sf-file-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:2px dashed var(--border-color, #d1d5db);border-radius:8px;background:var(--bg-card, #f9fafb);cursor:pointer;color:var(--text-secondary, #64748b);font-size:.9rem;transition:all .2s}.sf-file-btn:hover{border-color:var(--primary, #3b82f6);color:var(--primary, #3b82f6)}.sf-file-list{display:flex;flex-wrap:wrap;gap:6px}.sf-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.sf-btn.primary{background:var(--primary, #3b82f6);color:#fff}.sf-btn.primary:hover:not(:disabled){background:var(--primary-dark, #2563eb)}.sf-btn.primary:disabled{opacity:.5;cursor:not-allowed}.sf-btn.secondary{background:var(--bg-secondary, #f1f5f9);color:var(--text-primary, #374151)}.sf-btn.secondary:hover{background:var(--bg-hover, #e2e8f0)}.sf-btn.danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.sf-btn.danger:hover:not(:disabled){background:#fee2e2}.sf-filters{display:flex;gap:12px;margin-bottom:20px}.sf-search{display:flex;align-items:center;gap:8px;flex:1;padding:8px 14px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;background:var(--bg-input, #fff)}.sf-search input{border:none;outline:none;flex:1;font-size:.9rem;background:transparent;color:var(--text-primary, #1f2937)}.sf-filter-select{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;background:var(--bg-input, #fff)}.sf-filter-select select{border:none;outline:none;font-size:.9rem;background:transparent;color:var(--text-primary, #1f2937)}.sf-rating-stats{display:grid;grid-template-columns:200px 1fr;gap:20px;margin-bottom:24px;padding:20px;border:1px solid var(--border-color, #e2e8f0);border-radius:12px;background:var(--bg-card, #fff)}.sf-stat-avg{display:flex;flex-direction:column;align-items:center;gap:8px}.sf-avg-num{font-size:2.5rem;font-weight:700;color:var(--primary, #3b82f6)}.sf-avg-label{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.sf-stat-dist h3{font-size:.9rem;font-weight:600;margin:0 0 8px}.sf-dist-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:.8rem}.sf-dist-bar{flex:1;height:8px;background:var(--bg-secondary, #f1f5f9);border-radius:4px;overflow:hidden}.sf-dist-fill{height:100%;background:#f59e0b;border-radius:4px;transition:width .3s}.sf-dist-count{min-width:24px;text-align:right;color:var(--text-secondary, #94a3b8)}.sf-rating-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.sf-rating-card{border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:16px;background:var(--bg-card, #fff);transition:box-shadow .2s}.sf-rating-card:hover{box-shadow:0 2px 8px #0000000f}.sf-rating-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.sf-company-name{font-weight:600;font-size:.95rem}.sf-service-type{font-size:.8rem;color:var(--text-secondary, #94a3b8)}.sf-card-actions{display:flex;gap:4px}.sf-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:var(--bg-secondary, #f1f5f9);color:var(--text-secondary, #64748b);cursor:pointer;transition:all .2s}.sf-icon-btn:hover{background:var(--bg-hover, #e2e8f0);color:var(--primary, #3b82f6)}.sf-icon-btn.danger:hover{background:#fef2f2;color:#dc2626}.sf-rating-card-rating{display:flex;align-items:center;gap:8px;margin-bottom:8px}.sf-rating-badge{font-size:.8rem;font-weight:600;padding:2px 8px;border-radius:10px;background:#fffbeb;color:#d97706}.sf-rating-comment{font-size:.85rem;color:var(--text-secondary, #64748b);margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sf-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--text-secondary, #94a3b8)}.sf-status{padding:2px 8px;border-radius:10px;font-weight:500;font-size:.75rem;text-transform:capitalize}.sf-status.published{background:#f0fdf4;color:#15803d}.sf-status.pending{background:#fffbeb;color:#d97706}.sf-status.removed{background:#fef2f2;color:#dc2626}.sf-complaint-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.sf-stat{padding:16px;border-radius:10px;background:var(--bg-card, #fff);border:1px solid var(--border-color, #e2e8f0)}.sf-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1a1a2e)}.sf-stat-label{font-size:.8rem;color:var(--text-secondary, #64748b)}.sf-table-wrap{overflow-x:auto;border:1px solid var(--border-color, #e2e8f0);border-radius:12px}.sf-table{width:100%;border-collapse:collapse;font-size:.875rem}.sf-table th{text-align:left;padding:12px 16px;background:var(--bg-secondary, #f8fafc);font-weight:600;color:var(--text-secondary, #64748b);border-bottom:1px solid var(--border-color, #e2e8f0);white-space:nowrap}.sf-table td{padding:12px 16px;border-bottom:1px solid var(--border-color, #f1f5f9)}.sf-table tbody tr:hover{background:var(--bg-hover, #f8fafc)}.sf-ref{font-family:monospace;font-weight:500;font-size:.8rem}.sf-subject{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sf-date{white-space:nowrap;font-size:.8rem;color:var(--text-secondary, #94a3b8)}.sf-priority{padding:2px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.sf-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.sf-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px 0;font-size:.9rem}.sf-pagination button{display:flex;align-items:center;padding:6px 12px;border:1px solid var(--border-color, #d1d5db);border-radius:6px;background:var(--bg-card, #fff);cursor:pointer;color:var(--text-primary, #374151)}.sf-pagination button:disabled{opacity:.4;cursor:not-allowed}.sf-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.sf-modal{background:var(--bg-card, #fff);border-radius:16px;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;padding:24px}.sf-modal.wide{max-width:700px}.sf-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sf-modal-header h2{font-size:1.15rem;font-weight:600;margin:0}.sf-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.sf-detail-grid .full-width{grid-column:1 / -1}.sf-detail-grid label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.sf-detail-grid p{margin:0;font-size:.9rem}.sf-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.sf-edit-form{display:flex;flex-direction:column;gap:12px}.sf-edit-company{font-weight:600;font-size:1rem}.sf-edit-stars{padding:8px 0}.sf-edit-form textarea{width:100%;padding:10px 14px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;font-size:.9rem;resize:vertical;box-sizing:border-box}.sf-timeline-section{margin:20px 0;padding-top:16px;border-top:1px solid var(--border-color, #e2e8f0)}.sf-timeline-section h3{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;margin:0 0 16px}.sf-timeline{position:relative;padding-left:20px}.sf-timeline:before{content:"";position:absolute;left:5px;top:0;bottom:0;width:2px;background:var(--border-color, #e2e8f0)}.sf-timeline-item{position:relative;padding-bottom:16px;padding-left:16px}.sf-timeline-dot{position:absolute;left:-16px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--primary, #3b82f6);border:2px solid var(--bg-card, #fff)}.sf-timeline-status{font-weight:600;font-size:.85rem;text-transform:capitalize}.sf-timeline-msg{font-size:.85rem;color:var(--text-secondary, #64748b);margin:2px 0}.sf-timeline-date{font-size:.75rem;color:var(--text-secondary, #94a3b8)}.sf-dispute-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color, #e2e8f0)}.sf-dispute-form{display:flex;flex-direction:column;gap:12px}.sf-dispute-form textarea{width:100%;padding:10px 14px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;font-size:.9rem;resize:vertical;box-sizing:border-box}.sf-dispute-actions{display:flex;gap:12px}@media(max-width:768px){.sf-tabs{gap:0}.sf-tab{padding:10px 12px;font-size:.8rem}.sf-tab span{display:none}.sf-form-row,.sf-form-row-3,.sf-rating-stats{grid-template-columns:1fr}.sf-complaint-stats{grid-template-columns:repeat(2,1fr)}.sf-detail-grid{grid-template-columns:1fr}}.profile-page{padding:32px;max-width:1200px;margin:0 auto}.page-header{margin-bottom:32px}.page-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.page-subtitle{font-size:16px;color:var(--text-secondary);margin:0}.save-success{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#d1fae5;border:1px solid #a7f3d0;border-radius:8px;color:#065f46;font-size:14px;font-weight:500;margin-bottom:24px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-navigation{display:flex;gap:12px;margin-bottom:32px;border-bottom:2px solid var(--border-color)}.nav-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.nav-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-btn.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.profile-section{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.section-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:32px;box-shadow:0 2px 8px #0000000d}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.section-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.section-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.btn-edit{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-edit:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.info-section{margin-bottom:32px}.info-section:last-child{margin-bottom:0}.subsection-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.subsection-title svg{color:var(--accent-primary)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group.full-width{grid-column:1 / -1}.form-label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--text-primary)}.form-label svg{color:var(--accent-primary)}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;font-family:inherit;color:var(--text-primary);background:var(--bg-primary);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #4169e11a}.form-input:disabled{background:var(--bg-secondary);cursor:not-allowed;color:var(--text-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.btn-cancel{padding:12px 24px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:var(--border-color)}.btn-save{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--accent-primary);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-save:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4169e133}.notification-list{display:flex;flex-direction:column;gap:16px}.notification-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.notification-item:hover{border-color:var(--accent-primary)}.notification-info{flex:1}.notification-info strong{display:block;font-size:15px;color:var(--text-primary);margin-bottom:4px}.notification-info p{font-size:13px;color:var(--text-secondary);margin:0}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--border-color);transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.security-note{display:flex;align-items:flex-start;gap:10px;padding:16px;background:#dbeafe;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:14px;line-height:1.6;margin-bottom:20px}.security-note svg{flex-shrink:0;margin-top:2px}.btn-external{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--accent-primary);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-external:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4169e133}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.activity-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#d1fae5;border-radius:50%;color:#10b981}.activity-details strong{display:block;font-size:15px;color:var(--text-primary);margin-bottom:4px}.activity-details p{font-size:13px;color:var(--text-secondary);margin:0}@media(max-width:768px){.profile-page{padding:20px}.page-title{font-size:28px}.section-card{padding:24px 20px}.section-header{flex-direction:column;gap:16px}.btn-edit{width:100%;justify-content:center}.form-grid{grid-template-columns:1fr}.profile-navigation{flex-direction:column;gap:0;border-bottom:none}.nav-btn{border-bottom:none;border-left:3px solid transparent;padding:12px 16px;justify-content:flex-start}.nav-btn.active{border-left-color:var(--accent-primary);border-bottom-color:transparent}.form-actions{flex-direction:column}.btn-cancel,.btn-save,.btn-external{width:100%;justify-content:center}.notification-item{flex-direction:column;gap:12px}.toggle-switch{align-self:flex-start}}[data-theme=dark] .section-card{box-shadow:0 2px 8px #0000004d}[data-theme=dark] .nav-btn:hover{background:#ffffff0d}[data-theme=dark] .form-input:disabled{background:#ffffff0d}[data-theme=dark] .security-note{background:#3b82f61a;border-color:#3b82f633;color:#60a5fa}[data-theme=dark] .activity-icon{background:#10b9811a}[data-theme=dark] .save-success{background:#10b9811a;border-color:#10b98133;color:#34d399}.theme-options{display:flex;gap:8px}.theme-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;cursor:pointer;transition:all .2s}.theme-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.customer-invoices-page{display:flex;flex-direction:column;gap:16px}.customer-invoices-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.customer-invoices-header h1{display:flex;align-items:center;gap:8px;margin:0;font-size:2rem}.customer-invoices-header p{margin:4px 0 0;color:#64748b}.customer-invoices-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:4px}.stat-card span{color:#64748b;font-size:.85rem}.stat-card strong{font-size:1.4rem;color:#1e293b}.customer-invoices-filters{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px}.search-box{display:flex;align-items:center;gap:8px;border:1px solid #d1d5db;border-radius:10px;padding:8px 10px}.search-box input{border:none;outline:none;width:100%;font-size:.95rem}.status-tabs{display:flex;flex-wrap:wrap;gap:8px}.status-tab{border:1px solid #d1d5db;background:#fff;border-radius:8px;padding:6px 12px;cursor:pointer;font-weight:600;color:#475569}.status-tab.active{background:#2563eb;color:#fff;border-color:#2563eb}.table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:auto}.table-wrap table{width:100%;border-collapse:collapse}.table-wrap th,.table-wrap td{padding:12px;text-align:left;border-bottom:1px solid #f1f5f9;vertical-align:top}.table-wrap th{font-size:.85rem;letter-spacing:.01em;color:#64748b}.muted{color:#64748b;font-size:.85rem}.actions{display:flex;gap:8px;flex-wrap:wrap}.status-chip{border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700}.status-chip.unpaid{background:#fffbeb;color:#b45309}.status-chip.overdue{background:#fef2f2;color:#b91c1c}.status-chip.paid{background:#ecfdf5;color:#047857}.status-chip.draft,.status-chip.cancelled{background:#f1f5f9;color:#475569}.customer-invoices-btn{border:1px solid transparent;border-radius:8px;padding:8px 12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-weight:600}.customer-invoices-btn.small{padding:6px 10px;font-size:.85rem}.customer-invoices-btn.primary{background:#2563eb;border-color:#2563eb;color:#fff}.customer-invoices-btn.primary:disabled{opacity:.7;cursor:not-allowed}.customer-invoices-btn.secondary{background:#fff;color:#334155;border-color:#cbd5e1}.state-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:10px;color:#64748b}.state-card.error{border-color:#fecaca;color:#b91c1c;background:#fef2f2}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal-card{width:min(860px,100%);background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:16px;display:flex;flex-direction:column;gap:14px}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.modal-head h3{margin:0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.detail-grid>div{border:1px solid #e2e8f0;border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:4px}.detail-grid span{color:#64748b;font-size:.82rem}.line-items table{width:100%;border-collapse:collapse;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.line-items th,.line-items td{padding:10px;border-bottom:1px solid #f1f5f9}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.form-grid label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#334155}.form-grid input,.form-grid select{border:1px solid #cbd5e1;border-radius:8px;padding:9px 10px;font-size:.95rem}.inline-error{border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:8px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notifications-page{padding:24px;max-width:1200px;margin:0 auto}.notifications-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}.header-title{display:flex;align-items:flex-start;gap:16px}.header-title svg{color:var(--color-primary);flex-shrink:0}.header-title h1{margin:0 0 4px;font-size:28px;font-weight:600;color:var(--color-text)}.header-title p{margin:0;font-size:14px;color:var(--color-text-secondary)}.header-actions{display:flex;gap:12px}.btn-secondary{display:flex;align-items:center;gap:8px;padding:10px 16px;background:transparent;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--color-hover);border-color:var(--color-primary);color:var(--color-primary)}.notifications-filters{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:16px;margin-bottom:24px}.notifications-error-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:16px;border-radius:8px;border:1px solid rgba(var(--color-error-rgb),.25);background:rgba(var(--color-error-rgb),.08);color:var(--color-error)}.btn-link{margin-left:auto;border:none;background:transparent;color:inherit;font-weight:600;cursor:pointer;padding:4px 8px;text-decoration:underline}.btn-link:disabled{opacity:.6;cursor:not-allowed;text-decoration:none}.filter-tabs{display:flex;gap:8px}.filter-tab{padding:8px 16px;background:transparent;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.filter-tab:hover{background:var(--color-hover);color:var(--color-text)}.filter-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.notifications-loading,.notifications-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;color:var(--color-text-secondary)}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite;margin-bottom:16px}.notifications-empty svg{color:var(--color-text-secondary);margin-bottom:16px;opacity:.5}.notifications-empty h3{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--color-text)}.notifications-empty p{margin:0;font-size:14px;color:var(--color-text-secondary)}.notifications-list-page{display:flex;flex-direction:column;gap:12px}.notification-card{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s;position:relative}.notification-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #00000014}.notification-card.unread{background:rgba(var(--color-primary-rgb),.03);border-left:3px solid var(--color-primary)}.notification-card.read{opacity:.7}.notification-icon-wrapper{flex-shrink:0;margin-top:2px}.notification-icon{flex-shrink:0}.notification-icon.success{color:var(--color-success)}.notification-icon.warning{color:var(--color-warning)}.notification-icon.error{color:var(--color-error)}.notification-icon.info{color:var(--color-info)}.notification-content{flex:1;min-width:0}.notification-message{margin:0 0 8px;font-size:15px;color:var(--color-text);line-height:1.5}.notification-card.read .notification-message{color:var(--color-text-secondary)}.notification-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--color-text-secondary)}.notification-category,.notification-urgent{padding:3px 10px;background:var(--color-hover);border-radius:4px;font-size:12px;text-transform:capitalize;font-weight:500}.notification-urgent{background:rgba(var(--color-error-rgb),.1);color:var(--color-error)}.notification-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.unread-indicator{width:10px;height:10px;background:var(--color-primary);border-radius:50%}.icon-btn{background:transparent;border:none;padding:6px;cursor:pointer;color:var(--color-text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-btn:hover{background:var(--color-hover);color:var(--color-text)}.delete-btn:hover{color:var(--color-error)}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:32px;padding:16px}.pagination-btn{padding:8px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:14px;color:var(--color-text-secondary)}@media(max-width:768px){.notifications-page{padding:16px}.notifications-page-header{flex-direction:column}.header-title h1{font-size:24px}.notification-card{gap:12px;padding:12px}.filter-tabs{flex-wrap:wrap}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-secondary)}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen h2{margin-top:var(--spacing-2xl);font-size:var(--font-size-xl);color:var(--text-secondary);font-weight:500}.welcome-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:var(--spacing-xl)}.welcome-card{background:var(--bg-primary);padding:var(--spacing-5xl) var(--spacing-4xl);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-width:420px;width:100%;text-align:center}.logo-section{margin-bottom:var(--spacing-3xl)}.logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.logo-cf{font-size:var(--font-size-5xl);font-weight:700;color:var(--text-primary)}.logo-hub{font-size:var(--font-size-5xl);font-weight:700;color:var(--accent-secondary)}.logo-subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600;letter-spacing:1px}.welcome-card h1{font-size:var(--font-size-4xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.welcome-card p{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--spacing-3xl)}.btn-login{width:100%;padding:13px var(--spacing-2xl);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:background var(--transition-base)}.btn-login:hover{background:var(--accent-primary-hover)}.page{padding:var(--spacing-3xl);max-width:1200px;margin:0 auto}.page h1{font-size:var(--font-size-4xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.page p{font-size:var(--font-size-md);color:var(--text-secondary)}
