:root{--color-primary-50: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-200: #c7d2fe;--color-primary-300: #a5b4fc;--color-primary-400: #818cf8;--color-primary-500: #6366f1;--color-primary-600: #4f46e5;--color-primary-700: #4338ca;--color-primary-800: #3730a3;--color-primary-900: #312e81;--color-success-50: #ecfdf5;--color-success-100: #d1fae5;--color-success-500: #10b981;--color-success-600: #059669;--color-success-700: #047857;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-error-50: #fef2f2;--color-error-100: #fee2e2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-error-700: #b91c1c;--color-info-50: #eff6ff;--color-info-100: #dbeafe;--color-info-500: #3b82f6;--color-info-600: #2563eb;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--font-family-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", Monaco, Consolas, "Liberation Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05);--shadow-glow: 0 0 20px rgb(99 102 241 / .3);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-toast: 700;--z-tooltip: 800;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--btn-height-sm: 32px;--btn-height-md: 40px;--btn-height-lg: 48px;--input-height-sm: 32px;--input-height-md: 40px;--input-height-lg: 48px;--sidebar-width: 240px;--sidebar-width-collapsed: 64px;--header-height: 64px;--mobile-nav-height: 64px;--bg-primary: #ffffff;--bg-secondary: var(--color-gray-50);--bg-tertiary: var(--color-gray-100);--bg-inverse: var(--color-gray-900);--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-600);--text-tertiary: var(--color-gray-500);--text-inverse: #ffffff;--text-muted: var(--color-gray-400);--border-primary: var(--color-gray-200);--border-secondary: var(--color-gray-100);--border-focus: var(--color-primary-500);--surface-elevated: #ffffff;--surface-overlay: rgba(0, 0, 0, .5)}@media(prefers-color-scheme:dark){:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-inverse: #ffffff;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-inverse: #0f172a;--text-muted: #475569;--border-primary: #334155;--border-secondary: #1e293b;--surface-elevated: #1e293b;--surface-overlay: rgba(0, 0, 0, .7);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .3), 0 2px 4px -2px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .3), 0 4px 6px -4px rgb(0 0 0 / .3)}}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-family-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-secondary);margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1 0%}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.m-0{margin:0}.m-2{margin:var(--space-2)}.m-4{margin:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success-600)}.text-warning{color:var(--color-warning-600)}.text-error{color:var(--color-error-600)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.border{border:1px solid var(--border-primary)}.border-0{border:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-surface{background-color:var(--surface-elevated)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.hidden{display:none}.visible{visibility:visible}.invisible{visibility:hidden}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-4);height:var(--btn-height-md);font-size:var(--text-sm);font-weight:var(--font-semibold);border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.btn--sm{height:var(--btn-height-sm);padding:0 var(--space-3);font-size:var(--text-xs)}.btn--lg{height:var(--btn-height-lg);padding:0 var(--space-6);font-size:var(--text-base)}.btn--primary{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-700));transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--secondary{background:var(--color-gray-100);color:var(--text-primary)}.btn--secondary:hover:not(:disabled){background:var(--color-gray-200)}.btn--ghost{background:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--text-primary)}.btn--danger{background:linear-gradient(135deg,var(--color-error-500),var(--color-error-600));color:#fff}.btn--danger:hover:not(:disabled){background:linear-gradient(135deg,var(--color-error-600),var(--color-error-700))}.btn--success{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:#fff}.btn--icon{width:var(--btn-height-md);padding:0;flex-shrink:0}.btn--icon.btn--sm{width:var(--btn-height-sm)}.btn--icon.btn--lg{width:var(--btn-height-lg)}.input{height:var(--input-height-md);padding:0 var(--space-3);font-size:var(--text-sm);border:1px solid var(--border-primary);border-radius:var(--radius-lg);background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-fast);width:100%}.input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.input::placeholder{color:var(--text-muted)}.input--sm{height:var(--input-height-sm);font-size:var(--text-xs)}.input--lg{height:var(--input-height-lg);font-size:var(--text-base)}.input--error{border-color:var(--color-error-500)}.input--error:focus{box-shadow:0 0 0 3px var(--color-error-100)}.card{background:var(--surface-elevated);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--border-secondary)}.card--interactive{cursor:pointer;transition:all var(--transition-normal)}.card--interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.card__subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap}.badge--primary{background:var(--color-primary-100);color:var(--color-primary-700)}.badge--success{background:var(--color-success-100);color:var(--color-success-700)}.badge--warning{background:var(--color-warning-100);color:var(--color-warning-700)}.badge--error{background:var(--color-error-100);color:var(--color-error-700)}.badge--gray{background:var(--color-gray-100);color:var(--color-gray-700)}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-400),var(--color-primary-600));color:#fff;font-weight:var(--font-semibold);flex-shrink:0}.avatar--xs{width:24px;height:24px;font-size:var(--text-xs)}.avatar--sm{width:32px;height:32px;font-size:var(--text-sm)}.avatar--md{width:40px;height:40px;font-size:var(--text-base)}.avatar--lg{width:48px;height:48px;font-size:var(--text-lg)}.avatar--xl{width:64px;height:64px;font-size:var(--text-xl)}.divider{height:1px;background:var(--border-primary);border:none;margin:var(--space-4) 0}.stat-card{background:var(--surface-elevated);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);border:1px solid var(--border-secondary);transition:all var(--transition-normal)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card__icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.stat-card__label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.stat-card__value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.stat-card__trend{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium)}.stat-card__trend--up{color:var(--color-success-600)}.stat-card__trend--down{color:var(--color-error-600)}.stat-card__trend--neutral{color:var(--text-muted)}@media(max-width:639px){.sm\:hidden{display:none!important}.sm\:flex{display:flex!important}.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:text-sm{font-size:var(--text-sm)}}@media(min-width:640px){.md\:hidden{display:none!important}.md\:flex{display:flex!important}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.lg\:hidden{display:none!important}.lg\:flex{display:flex!important}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(-5%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(0);animation-timing-function:cubic-bezier(0,0,.2,1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-normal)}.animate-fade-in-up{animation:fadeInUp var(--transition-slow)}.animate-slide-in-right{animation:slideInRight var(--transition-slow)}.animate-slide-in-up{animation:slideInUp var(--transition-slow)}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary-600);color:#fff;padding:var(--space-2) var(--space-4);z-index:9999;text-decoration:none;font-weight:var(--font-semibold);transition:top var(--transition-fast)}.skip-link:focus{top:0}@media(prefers-contrast:high){:root{--border-primary: var(--color-gray-700);--text-secondary: var(--color-gray-700)}.card,.btn,.input{border-width:2px}}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh;background-color:var(--bg-color)}button{cursor:pointer}:root{--bg-color: #f1f5f9;--card-bg: #ffffff;--sidebar-bg: #ffffff;--text-main: #0f172a;--text-muted: #475569;--border-color: #cbd5e1;--input-bg: #f8fafc;--accent-blue: #2563eb;--accent-blue-hover: #1d4ed8;--danger-red: #dc2626;--success-green: #059669;--warning-yellow: #d97706;--hover-bg: #e2e8f0;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .12), 0 2px 4px -1px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .12), 0 4px 6px -2px rgba(0, 0, 0, .08);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--rv-bg: #f1f5f9;--rv-border: #cbd5e1;--rv-text-main: #0f172a;--rv-text-muted: #475569;--rv-header-bg: #f1f5f9;--rv-card: #ffffff;--rv-radius: 12px;--rv-shadow: 0 2px 6px rgba(0,0,0,.1);--rv-sub: #475569}body.dark-mode{--bg-color: #0f172a;--card-bg: #1e293b;--sidebar-bg: #1e293b;--text-main: #f3f4f6;--text-muted: #9ca3af;--border-color: #334155;--input-bg: #334155;--accent-blue: #3b82f6;--accent-blue-hover: #60a5fa;--hover-bg: #334155;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3);--rv-bg: #1e293b;--rv-border: #334155;--rv-text-main: #f3f4f6;--rv-text-muted: #9ca3af;--rv-header-bg: #1e293b;--rv-card: #1e293b;--rv-radius: 12px;--rv-shadow: 0 2px 8px rgba(0,0,0,.3);--rv-sub: #94a3b8}body.dark-mode .form-select option,body.dark-mode select option{background:#1e293b;color:#f3f4f6}html,body,#root{height:100%;width:100%;margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,Helvetica,sans-serif;background-color:var(--bg-color);color:var(--text-main);font-size:14px;-webkit-font-smoothing:antialiased;scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-color)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:10px;border:3px solid var(--bg-color)}::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}.login-wrapper{display:flex;align-items:center;justify-content:center;height:100vh;width:100vw;background-color:var(--bg-color);position:fixed;top:0;left:0;z-index:9999}.login-card{background:var(--card-bg);padding:30px 25px;border-radius:16px;box-shadow:0 4px 20px #00000014;width:100%;max-width:260px;text-align:center;border:1px solid var(--border-color)}.login-header h2{margin:0 0 8px;color:var(--text-main);font-size:2rem;font-weight:800}.login-header p{color:var(--text-muted);margin:0 0 25px;font-size:.9rem}.login-field{margin-bottom:16px;text-align:left}.login-field label{display:block;margin-bottom:6px;font-size:.8rem;font-weight:600;color:var(--text-muted)}.btn-login{width:100%;margin-top:10px;padding:12px;font-size:1rem}.password-toggle-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;padding:5px;border-radius:50%;transition:background .2s ease;outline:none!important;box-shadow:none!important}.password-toggle-btn:hover{background-color:var(--hover-bg)}.password-toggle-btn:focus{outline:none!important}.app-container{display:flex;height:100vh;overflow:hidden;width:100%}.sidebar{width:200px;background:var(--sidebar-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1rem .8rem;transition:width .3s cubic-bezier(.2,.8,.2,1);z-index:20;flex-shrink:0;position:relative}.sidebar.collapsed{width:55px;padding:1rem 0;align-items:center}.brand{display:flex;align-items:center;gap:12px;padding:0 10px 2rem;font-weight:800;font-size:1.4rem;letter-spacing:-.5px;white-space:nowrap;color:var(--text-main)}.sidebar.collapsed .brand span{display:none}.sidebar.collapsed .brand{justify-content:center;padding-left:0;padding-right:0}.nav-links{flex-grow:1}.nav-item{display:flex;align-items:center;padding:12px 14px;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;margin-bottom:4px;transition:.2s;font-weight:600;font-size:.9rem}.nav-item:hover{background:var(--hover-bg);color:var(--text-main)}.nav-item.active{background:var(--hover-bg);color:var(--accent-blue)}.nav-item svg{margin-right:12px;flex-shrink:0;opacity:.8;width:20px;height:20px}.sidebar.collapsed .nav-item{justify-content:center;padding:6px;width:32px}.sidebar.collapsed .nav-item svg{margin:0;opacity:1}.sidebar.collapsed .nav-item span{display:none}.user-panel{margin-top:auto;padding:15px 10px;border-top:1px solid var(--border-color);display:flex;align-items:center;cursor:pointer;position:relative;color:var(--text-main)}.sidebar.collapsed .user-panel{padding:15px 0;justify-content:center}.user-avatar{width:36px;height:36px;background:var(--accent-blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0}.user-info{margin-left:10px;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar.collapsed .user-info{display:none}.settings-popover{position:absolute;bottom:60px;right:-10px;left:auto;width:200px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 10px 30px #00000026;padding:6px;display:none;z-index:1000}.settings-popover.open{display:block;animation:popUp .2s ease}@keyframes popUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translate(0)}}.popover-item{padding:10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:10px;color:var(--text-main);font-size:.9rem}.popover-item:hover{background:var(--hover-bg)}.popover-divider{height:1px;background:var(--border-color);margin:5px 0}.popover-item.logout{color:var(--danger-red)}.popover-item.logout:hover{background:#ff3b301a}.theme-row{display:flex;justify-content:space-between;align-items:center;padding:10px;font-size:.9rem;color:var(--text-main);cursor:default}.switch{position:relative;display:inline-block;width:36px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--accent-blue)}input:checked+.slider:before{transform:translate(16px)}.main-content{flex:1;display:flex;flex-direction:column;height:100%;overflow-y:hidden;padding:15px 24px 0;width:100%;background-color:var(--bg-color)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-shrink:0}.header h1{font-size:1.5rem;margin:0;font-weight:700;letter-spacing:-.5px;color:var(--text-main)}.header-actions{display:flex;align-items:center;gap:12px;position:relative}.header-action-btn{display:flex;align-items:center;gap:6px}@media(max-width:768px){.header-action-text{display:none}.header-action-btn{padding:10px!important}}.notification-btn{position:relative;cursor:pointer;padding:8px;border-radius:50%;transition:background .2s;color:var(--text-muted)}.notification-btn:hover{background-color:var(--hover-bg);color:var(--text-main)}.notification-badge{position:absolute;top:4px;right:4px;background-color:var(--danger-red);color:#fff;font-size:.65rem;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid var(--bg-color)}.notification-dropdown{position:absolute;top:50px;right:0;width:300px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #00000026;z-index:1000;overflow:hidden;animation:popUp .2s ease}.notif-header{padding:12px 15px;font-weight:600;border-bottom:1px solid var(--border-color);font-size:.9rem;color:var(--text-main)}.notif-list{max-height:300px;overflow-y:auto}.notif-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:.85rem}.notif-item{padding:12px 15px;border-bottom:1px solid var(--border-color);display:flex;gap:12px;font-size:.85rem;cursor:default;color:var(--text-main)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--hover-bg)}.notif-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-title{font-weight:600;margin-bottom:2px}.notif-msg{color:var(--text-muted);font-size:.8rem}.grid-compact{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:15px}@media(max-width:900px){.grid-compact{grid-template-columns:1fr}}.card-mini{background:var(--card-bg);padding:15px;border-radius:var(--radius-md);border:1px solid var(--border-color);display:flex;flex-direction:column;justify-content:space-between;gap:10px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.card-mini:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.amount-mini{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin:5px 0;color:var(--text-main)}.amount-mini.red{color:var(--danger-red)}.amount-mini.green{color:var(--success-green)}.mini-sub{font-size:.8rem;color:var(--text-muted)}.table-card{background:var(--card-bg);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-sm);width:100%;margin-bottom:10px;flex:1 1 0%;min-height:0;display:flex;flex-direction:column}.card-header-row{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.card-header-row h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-main)}.filter-select{padding:6px 10px;border-radius:6px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-main);font-size:.8rem;outline:none}.table-responsive{overflow-x:auto;overflow-y:auto;flex:1;min-height:0}.table-scroll-y{display:flex;flex-direction:column;flex:1;min-height:0;padding:0}.table-body-scroll{display:block;overflow-y:auto;max-height:250px;border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);flex-shrink:1}.table-body-scroll::-webkit-scrollbar{width:8px}.table-body-scroll::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:4px}body.dark-mode .table-body-scroll::-webkit-scrollbar-thumb{background-color:#555}.clean-table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:100%;display:table}.clean-table thead,.clean-table tbody{display:table-row-group}.clean-table th{text-align:left;padding:10px 15px;color:var(--text-muted);font-weight:600;font-size:.75rem;border-bottom:1px solid var(--border-color);background:var(--hover-bg);position:sticky;top:0;z-index:1}.clean-table td{padding:8px 15px;border-bottom:1px solid var(--border-color);vertical-align:middle;height:40px;color:var(--text-main)}.clean-table tr:last-child td{border-bottom:none}.clean-table tr:hover{background-color:var(--hover-bg)}.fw-500{font-weight:500}.fw-600{font-weight:600}.tag-category{background:var(--hover-bg);padding:2px 8px;border-radius:4px;font-size:.8rem;color:var(--text-muted);border:1px solid var(--border-color)}.status-wrapper span{font-weight:600;font-size:.8rem;padding:4px 8px;border-radius:6px}.status-wrapper.pending span{background:#ff3b301a;color:var(--danger-red)}.status-wrapper.paid span{background:#34c7591a;color:var(--success-green)}.status-wrapper.overdue span{background:#ff950026;color:#ff9500}.delete-icon{color:var(--text-muted);cursor:pointer;opacity:.5;transition:.2s}.delete-icon:hover{color:var(--danger-red);opacity:1}.users-avatars{display:flex;gap:-8px}.mini-avatar{width:26px;height:26px;background:#e0e0e0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#333;border:2px solid var(--card-bg);margin-right:-8px}.editable-cell-display{cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .2s;min-height:24px;display:flex;align-items:center}.editable-cell-display:hover{background:var(--hover-bg);box-shadow:0 0 0 1px var(--border-color)}.inline-input{width:100%;padding:4px 8px;border:1px solid var(--accent-blue);border-radius:6px;font-size:.9rem;background:var(--card-bg);color:var(--text-main);outline:none}.modal-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:28px;z-index:100}.modal{background:linear-gradient(145deg,var(--card-bg) 0%,var(--bg-color) 100%);border-radius:var(--radius-md);box-shadow:0 20px 50px #00000059;overflow:auto;animation:popUp .3s ease;color:var(--text-main);max-height:calc(100vh - 84px);border:1px solid var(--border-color)}.modal.compact{background:var(--card-bg);width:440px;max-width:92%;border-radius:var(--radius-md);box-shadow:0 20px 50px #00000040;overflow:auto;animation:popUp .3s ease;color:var(--text-main);max-height:calc(100vh - 84px)}.modal-header{padding:14px 24px;background:var(--hover-bg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.05rem;font-weight:600}.close-icon{cursor:pointer;color:var(--text-muted)}.modal form{padding:26px 24px 28px}.form-row.compact-row{display:flex;gap:12px;margin-bottom:12px}.form-group{display:flex;flex-direction:column;flex:1}.form-group label{font-size:.7rem;font-weight:700;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.form-input{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-main);font-size:.9rem;outline:none;width:100%;box-sizing:border-box;transition:border .2s}.form-input.read-only{background:var(--hover-bg);border-color:transparent;pointer-events:none;color:var(--text-muted);font-weight:600}.form-select{padding:8px 36px 8px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-main);font-size:.9rem;outline:none;width:100%;box-sizing:border-box;transition:border .2s;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb1a}.form-select option{background:var(--card-bg);color:var(--text-main);padding:8px}.btn-primary{width:100%;background-color:var(--accent-blue);color:#fff;padding:10px 16px;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;font-size:.95rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 2px 4px #0000001a}.btn-primary:hover{background-color:var(--accent-blue-hover);transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.btn-small{padding:6px 12px;font-size:.8rem;display:flex;align-items:center;gap:5px;width:auto}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:15px}.btn-secondary{background-color:var(--card-bg);color:var(--text-main);border:1px solid var(--border-color);padding:10px 16px;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;font-size:.95rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-secondary:hover{background:var(--hover-bg);border-color:var(--text-muted);transform:translateY(-1px)}.icon-btn{background:transparent;border:1px solid transparent;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:.2s}.icon-btn:hover{background:var(--hover-bg);color:var(--accent-blue);border-color:var(--border-color)}.icon-btn.delete:hover{background:#ff3b301a;color:var(--danger-red);border-color:#ff3b3033}.user-list-container{display:flex;flex-direction:column;gap:8px;margin-bottom:15px;max-height:250px;overflow-y:auto}.user-list-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px}.selected-tags-wrapper{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:15px}.user-tag{display:flex;align-items:center;gap:6px;background-color:var(--hover-bg);color:var(--text-main);padding:4px 10px;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid var(--border-color);transition:all .2s ease}.user-tag:hover{background-color:var(--border-color)}.user-tag svg{color:var(--text-muted)}.user-tag:hover svg{color:var(--danger-red)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px 20px;margin-bottom:25px}.detail-item{display:flex;flex-direction:column}.detail-item label{font-size:.7rem;font-weight:700;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.detail-item div{font-size:.95rem;font-weight:500;color:var(--text-main)}.progress-bar{width:100%;height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden}.progress-fill{height:100%;width:0%;border-radius:4px;transition:width .3s ease-out}.animate-fade{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.toast-notification{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-100px);background-color:#333;color:#fff;padding:10px 20px;border-radius:30px;display:flex;align-items:center;gap:10px;box-shadow:0 10px 30px #0003;z-index:10000;transition:transform .3s cubic-bezier(.175,.885,.32,1.275);font-size:.9rem;font-weight:500;visibility:hidden;opacity:0}.toast-notification.show{transform:translate(-50%) translateY(0);visibility:visible;opacity:1}.toast-notification.success{background-color:#1d1d1f}.toast-notification.error{background-color:var(--danger-red)}.confirm-actions{display:flex;justify-content:center;gap:15px;width:100%;margin-top:10px}.btn-danger{background:var(--danger-red);color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:500}.btn-danger:hover{background:#d32f2f}.gallery-empty-state{width:80vw;height:70vh;max-width:500px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#000000b3;border-radius:var(--radius-md);color:#fff;text-align:center;padding:20px}.ImageWrapper{max-width:95vw;max-height:90vh;width:100%;height:100%;display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative;will-change:transform;transition:transform .2s ease-out}.ImageWrapper img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;position:relative}.nav-arrow-btn{position:fixed;top:50%;transform:translateY(-50%);background:#00000080;color:#fff;z-index:100;border:none;cursor:pointer;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.nav-arrow-btn:hover{background:#000c}.nav-arrow-btn.left{left:30px}.nav-arrow-btn.right{right:30px}.gallery-bottom-bar{position:fixed;bottom:30px;padding:10px 20px;background:#1e293be6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:15px;color:#fff;z-index:200;box-shadow:0 10px 30px #0000004d;border:1px solid rgba(255,255,255,.1)}.zoom-controls{display:flex;align-items:center;gap:5px;background-color:#ffffff1a;padding:4px 8px;border-radius:15px}.icon-btn-rounded{background:none;border:none;cursor:pointer;color:#fff;padding:4px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.icon-btn-rounded:hover:not(:disabled){background:#fff3}.icon-btn-rounded:disabled{opacity:.5;cursor:not-allowed}body.dark-mode .nav-arrow-btn{background:#fff3}body.dark-mode .nav-arrow-btn:hover{background:#ffffff4d}body.dark-mode .gallery-bottom-bar{background:#000c}.net-balance-badge{font-size:.8rem;padding:4px 12px;border-radius:20px;font-weight:700}.net-balance-badge.positive{background-color:#dcfce7;color:#15803d}.net-balance-badge.negative{background-color:#fee2e2;color:#b91c1c}.clean-state-wrapper{display:flex;align-items:center;justify-content:center;gap:15px;padding:20px;background-color:var(--bg-color);border-radius:12px;color:var(--text-main)}.icon-circle{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center}.icon-circle.success{background:#dcfce7;color:#15803d}.balance-hero-grid{display:flex;justify-content:space-around;align-items:center;text-align:center}.hero-divider{width:1px;height:60px;background-color:var(--border-color)}.hero-section{flex:1;transition:opacity .3s}.hero-section.inactive{opacity:.3}.hero-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;font-weight:700;color:var(--text-muted);margin-bottom:8px}.hero-amount{font-size:2.2rem;font-weight:800;line-height:1;margin-bottom:5px}.hero-amount.red{color:var(--danger-red)}.hero-amount.green{color:var(--success-green)}.hero-sub{font-size:.8rem;color:var(--text-muted);font-weight:500}.my-debts-section{background-color:#fafafa;border-top:1px solid var(--border-color);padding:15px 20px}body.dark-mode .my-debts-section{background-color:#ffffff08}.section-title-small{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:15px}.debt-cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;max-height:105px;overflow-y:auto;padding-right:5px}.debt-action-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;margin:2px 0;padding:15px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 5px #00000008;transition:transform .2s,box-shadow .2s;position:relative}.debt-action-card:hover{transform:translateY(-2px);box-shadow:0 5px 20px #00000026;border-color:var(--accent-blue);z-index:10}.dac-info{display:flex;gap:12px;align-items:center}.dac-action{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:5px}.dac-amount{font-weight:700;color:var(--danger-red);font-size:1.1rem}.mini-avatar.large{width:32px;height:32px;font-size:.9rem;margin-right:0}.matrix-table td{padding:12px 15px;vertical-align:middle;height:40px}.user-cell{display:flex;align-items:center;gap:10px;font-size:.9rem}.user-cell .mini-avatar{margin-right:0}.row-highlight-debt{background-color:#ff3b3008}.row-highlight-credit{background-color:#34c75908}.mini-avatar.highlight-red{background-color:var(--danger-red);color:#fff}.mini-avatar.highlight-green{background-color:var(--success-green);color:#fff}.fw-bold{font-weight:700;color:var(--text-main)}.kpi-card-clean{background:var(--rv-card, var(--card-bg));border-radius:var(--rv-radius, 12px);padding:12px 14px;display:flex;flex-direction:column;justify-content:center;border:1px solid var(--rv-border, var(--border-color));box-shadow:var(--rv-shadow, 0 2px 8px rgba(0,0,0,.15));min-height:70px;transition:transform .2s ease,box-shadow .2s ease}.kpi-card-clean:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.rv-kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;flex:0 0 70px}.rv-kpi-label{font-size:.7rem;color:var(--rv-sub);font-weight:600;text-transform:uppercase;margin-bottom:4px;letter-spacing:.3px}.rv-kpi-value{font-size:1.4rem;font-weight:800;color:var(--rv-text-main);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-main);padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:6px;cursor:pointer}.btn-outline:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--hover-bg)}.table-scroll{max-height:calc(100vh - 220px);overflow-y:auto;overflow-x:auto;padding-bottom:16px;-webkit-overflow-scrolling:touch}.table-scroll table{width:100%;table-layout:fixed}.table-scroll th,.table-scroll td{white-space:normal;word-break:break-word;padding:12px 16px}.table-scroll{max-height:60vh;overflow-y:auto;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch}.debts-list{display:flex;flex-direction:column;gap:0}.debt-item{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;border-bottom:1px solid var(--border-color);transition:background-color .2s}.debt-item:last-child{border-bottom:none}.debt-item:hover{background-color:var(--hover-bg)}.debt-item.highlight{background-color:#0071e308}.debt-avatars{display:flex;align-items:center;gap:8px;margin-right:15px;min-width:80px}.debt-avatars .avatar{width:32px;height:32px;border-radius:50%;background-color:#e0e0e0;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;color:#333;border:1px solid var(--border-color)}.debt-avatars .arrow-connector{color:var(--text-muted);display:flex;align-items:center}.debt-details{flex:1;display:flex;flex-direction:column;justify-content:center}.debt-text{font-size:.9rem;color:var(--text-main);margin-bottom:2px}.debt-amount{font-weight:700;font-size:.95rem;color:var(--text-main)}.debt-item.highlight .debt-amount{color:var(--accent-blue)}.btn-settle{background-color:var(--bg-color);border:1px solid var(--border-color);color:var(--text-main);padding:6px 12px;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-settle:hover{background-color:var(--success-green);color:#fff;border-color:var(--success-green)}.sub-text{color:var(--text-muted);font-size:.85rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-muted)}.glass{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}body.dark-mode .glass{background:#1e293bb3;border:1px solid rgba(255,255,255,.1)}.shadow-hover{transition:box-shadow .2s ease,transform .2s ease}.shadow-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.table-responsive::-webkit-scrollbar{height:10px;width:8px}.table-responsive::-webkit-scrollbar-track{background:var(--hover-bg);border-radius:5px}.table-responsive::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:5px}.table-responsive::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}.table-responsive .clean-table{min-width:1400px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb1a}@media(max-width:768px){.sidebar,.header{display:none!important}.main-content{padding:10px 12px 0!important;overflow-y:auto!important;overflow-x:hidden!important}.animate-fade{height:auto!important;overflow-x:hidden}.ai-chat-toggle,.hide-on-mobile{display:none!important}.card-header-row{flex-direction:column;align-items:flex-start;gap:10px;padding:12px 15px}.card-header-row>div{flex-wrap:wrap;width:100%}.filter-select{flex:1;min-width:0;font-size:.75rem}.rv-kpi-row{grid-template-columns:repeat(3,1fr)!important;gap:8px!important}.kpi-card-clean{padding:10px 8px!important;min-height:60px;overflow:hidden;word-break:break-word}.rv-kpi-value{font-size:1.1rem!important}.rv-kpi-label{font-size:.55rem}.kpi-row-4{grid-template-columns:repeat(2,1fr)!important}.kpi-row-2{grid-template-columns:1fr!important}.table-responsive .clean-table{min-width:600px}.table-card{flex:none!important;min-height:400px;max-height:60vh}.modal-overlay{padding:12px!important;align-items:center!important;justify-content:center!important}.modal,.modal.compact{width:100%!important;max-width:100%!important;max-height:85vh;margin:0;border-radius:12px}.user-list-item{flex-wrap:nowrap;gap:8px;padding:10px}.user-list-item>div:first-child{min-width:0;flex:1}.user-list-item>div:first-child>div:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-btn{width:28px;height:28px;padding:4px;flex-shrink:0}.form-row.compact-row{flex-direction:column;gap:8px}}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--surface-elevated, #fff);border-bottom:1px solid var(--border-primary, #e5e7eb);padding:0 16px;align-items:center;justify-content:space-between;z-index:var(--z-sticky, 200);box-shadow:var(--shadow-sm, 0 1px 2px rgba(0,0,0,.05))}.mobile-header__logo{display:flex;align-items:center;gap:8px}.mobile-header__logo-icon{font-size:24px}.mobile-header__logo-text{font-size:18px;font-weight:700;color:var(--text-primary, #1f2937)}.mobile-header__menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;cursor:pointer;color:var(--text-primary, #1f2937);border-radius:8px;transition:background .2s}.mobile-header__menu-btn:hover{background:var(--color-gray-100, #f3f4f6)}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--surface-elevated, #fff);border-top:1px solid var(--border-primary, #e5e7eb);padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0);align-items:center;justify-content:space-around;z-index:var(--z-sticky, 200);box-shadow:0 -4px 12px #0000000d}.mobile-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;color:var(--text-muted, #9ca3af);text-decoration:none;border:none;background:transparent;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.mobile-nav__item--active{color:var(--color-primary-600, #4f46e5)}.mobile-nav__item--active .mobile-nav__label{font-weight:600}.mobile-nav__label{font-size:10px;font-weight:500;white-space:nowrap}.mobile-nav__item--fab{flex:0 0 auto}.mobile-nav__fab{width:52px;height:52px;background:linear-gradient(135deg,var(--color-primary-500, #6366f1),var(--color-primary-600, #4f46e5));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #6366f166;transform:translateY(-8px);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.mobile-nav__item--fab:active .mobile-nav__fab{transform:translateY(-8px) scale(.95)}.mobile-nav__item--fab.mobile-nav__item--active .mobile-nav__fab{transform:translateY(-8px) rotate(45deg);background:linear-gradient(135deg,var(--color-error-500, #ef4444),var(--color-error-600, #dc2626))}.quick-actions-overlay{position:fixed;inset:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop, 400);animation:fadeIn .2s ease}.quick-actions{position:fixed;bottom:90px;left:50%;transform:translate(-50%);display:flex;flex-direction:column-reverse;align-items:center;gap:12px;z-index:var(--z-modal, 500);padding-bottom:env(safe-area-inset-bottom,0);animation:fadeIn .2s ease-out}.quick-actions__item{display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--surface-elevated, #fff);border:none;border-radius:100px;box-shadow:0 4px 20px #00000026;cursor:pointer;color:var(--text-primary, #1f2937);font-size:14px;font-weight:600;transition:all .2s ease;white-space:nowrap}.quick-actions__item:hover{transform:scale(1.05)}.quick-actions__icon{width:44px;height:44px;background:var(--action-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.mobile-menu-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop, 400);animation:fadeIn .2s ease}.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:85vw;background:var(--surface-elevated, #fff);z-index:var(--z-modal, 500);transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;box-shadow:-10px 0 40px #00000026}.mobile-menu--open{transform:translate(0)}.mobile-menu__header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px;background:linear-gradient(135deg,var(--color-primary-500, #6366f1),var(--color-primary-600, #4f46e5));color:#fff}.mobile-menu__user{display:flex;align-items:center;gap:12px}.mobile-menu__avatar{width:48px;height:48px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.mobile-menu__user-info{display:flex;flex-direction:column}.mobile-menu__user-name{margin:0;font-size:16px;font-weight:600}.mobile-menu__user-email{margin:0;font-size:12px;opacity:.8}.mobile-menu__close{background:#ffffff1a;border:none;border-radius:8px;padding:8px;cursor:pointer;color:#fff;transition:background .2s}.mobile-menu__close:hover{background:#fff3}.mobile-menu__nav{flex:1;padding:16px 0;overflow-y:auto}.mobile-menu__link{display:flex;align-items:center;gap:12px;padding:14px 24px;color:var(--text-primary, #1f2937);text-decoration:none;font-size:15px;font-weight:500;transition:all .2s;border:none;background:transparent;width:100%;text-align:left;cursor:pointer}.mobile-menu__link:hover,.mobile-menu__link.active{background:var(--color-primary-50, #eef2ff);color:var(--color-primary-600, #4f46e5)}.mobile-menu__link--danger{color:var(--color-error-600, #dc2626)}.mobile-menu__link--danger:hover{background:var(--color-error-50, #fef2f2);color:var(--color-error-700, #b91c1c)}.mobile-menu__divider{height:1px;background:var(--border-primary, #e5e7eb);margin:8px 24px}.mobile-menu__actions{padding:16px 0;border-top:1px solid var(--border-primary, #e5e7eb)}@media(max-width:768px){.mobile-header,.mobile-nav{display:flex}.main-layout__content{padding-top:56px!important;padding-bottom:80px!important}}@keyframes slideInUp{0%{opacity:0;transform:translate(-50%) translateY(10px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@media(hover:none)and (pointer:coarse){.mobile-nav__item:active{transform:scale(.95);transition:transform .1s}.quick-actions__item:active{transform:scale(.98)}}@supports (padding: max(0px)){.mobile-nav{padding-bottom:max(8px,env(safe-area-inset-bottom))}.mobile-header{padding-top:env(safe-area-inset-top);height:calc(56px + env(safe-area-inset-top))}}@media(max-width:768px)and (orientation:landscape){.mobile-nav{height:48px}.mobile-nav__fab{width:44px;height:44px;transform:translateY(-4px)}.mobile-nav__label{display:none}}.ocr-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.ocr-modal__overlay{position:absolute;inset:0;background:linear-gradient(135deg,#4f46e526,#7c3aed26);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.ocr-modal__content{position:relative;background:linear-gradient(145deg,#fffffffa,#f9fafbf2);border:1px solid rgba(255,255,255,.8);border-radius:20px;width:100%;max-width:360px;max-height:85vh;overflow:hidden;box-shadow:0 20px 40px #4f46e526,0 8px 16px #00000014;animation:modalSlideIn .3s ease-out}body.dark-mode .ocr-modal__content{background:linear-gradient(145deg,#1e1e23fa,#19191ef2);border:1px solid rgba(255,255,255,.1);box-shadow:0 32px 64px #0006,0 16px 32px #4f46e526,inset 0 1px #ffffff0d}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.ocr-modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(135deg,#4f46e5,#7c3aed,#a855f7);position:relative;overflow:hidden}.ocr-modal__header:before{content:"";position:absolute;top:-50%;right:-20%;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.ocr-modal__header:after{content:"";position:absolute;bottom:-30%;left:-10%;width:150px;height:150px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.ocr-modal__title{display:flex;align-items:center;gap:8px;margin:0;font-size:16px;font-weight:600;color:#fff;position:relative;z-index:1}.ocr-modal__title svg{width:18px;height:18px}.ocr-modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:#ffffff26;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease;position:relative;z-index:1}.ocr-modal__close svg{width:18px;height:18px}.ocr-modal__close:hover{background:#ffffff40;transform:scale(1.05)}.ocr-modal__body{padding:16px;max-height:calc(85vh - 60px);overflow-y:auto}.ocr-error{display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:14px;color:#dc2626;font-size:14px;font-weight:500;margin-bottom:20px;box-shadow:0 4px 12px #dc26261a}body.dark-mode .ocr-error{background:linear-gradient(135deg,#dc262626,#b91c1c1a);border-color:#dc26264d;color:#f87171}.ocr-capture__options{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.ocr-capture__option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s ease}body.dark-mode .ocr-capture__option{background:#33415566;border-color:#64748b4d}.ocr-capture__option:hover{border-color:#6366f1;background:#f8fafc}body.dark-mode .ocr-capture__option:hover{background:#47556980}.ocr-capture__option-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:8px;color:#fff;box-shadow:0 2px 8px #4f46e533}.ocr-capture__option-icon svg{width:14px;height:14px}.ocr-capture__option-icon--secondary{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b98133}.ocr-capture__option-title{font-size:12px;font-weight:600;color:#0f172a}body.dark-mode .ocr-capture__option-title{color:#f3f4f6}.ocr-capture__option-desc{font-size:10px;color:#64748b;text-align:center}body.dark-mode .ocr-capture__option-desc{color:#94a3b8}.ocr-capture__preview{position:relative;border-radius:12px;overflow:hidden;margin-bottom:14px}.ocr-capture__preview img{width:100%;max-height:200px;object-fit:contain;background:#f1f5f9}body.dark-mode .ocr-capture__preview img{background:#1e293b}.ocr-capture__retry{position:absolute;bottom:14px;right:14px;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border:none;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 12px #0000004d}.ocr-capture__retry:hover{background:#000000e6;transform:translateY(-2px);box-shadow:0 6px 16px #0006}.ocr-capture__tips{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 14px}body.dark-mode .ocr-capture__tips{background:#3b82f61a;border-color:#3b82f633}.ocr-capture__tips h4{margin:0 0 6px;font-size:11px;font-weight:700;color:#1e40af}body.dark-mode .ocr-capture__tips h4{color:#60a5fa}.ocr-capture__tips ul{margin:0;padding-left:16px;font-size:10px;color:#1e3a5f;line-height:1.5}body.dark-mode .ocr-capture__tips ul{color:#93c5fd}.ocr-camera{display:flex;flex-direction:column;gap:16px}.ocr-camera__viewfinder{position:relative;border-radius:16px;overflow:hidden;background:#000;aspect-ratio:3/4;max-height:400px}.ocr-camera__video{width:100%;height:100%;object-fit:cover}.ocr-camera__frame{position:absolute;inset:20px;pointer-events:none}.ocr-camera__corner{position:absolute;width:30px;height:30px;border:3px solid rgba(255,255,255,.9)}.ocr-camera__corner--tl{top:0;left:0;border-right:none;border-bottom:none;border-radius:8px 0 0}.ocr-camera__corner--tr{top:0;right:0;border-left:none;border-bottom:none;border-radius:0 8px 0 0}.ocr-camera__corner--bl{bottom:0;left:0;border-right:none;border-top:none;border-radius:0 0 0 8px}.ocr-camera__corner--br{bottom:0;right:0;border-left:none;border-top:none;border-radius:0 0 8px}.ocr-camera__hint{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;white-space:nowrap}.ocr-camera__controls{display:flex;align-items:center;justify-content:center;gap:24px;padding:16px 0}.ocr-camera__btn{display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s ease}.ocr-camera__btn--back,.ocr-camera__btn--switch{width:48px;height:48px;border-radius:50%;background:#0000001a;color:#374151}body.dark-mode .ocr-camera__btn--back,body.dark-mode .ocr-camera__btn--switch{background:#ffffff1a;color:#e5e7eb}.ocr-camera__btn--back:hover,.ocr-camera__btn--switch:hover{background:#0003;transform:scale(1.05)}body.dark-mode .ocr-camera__btn--back:hover,body.dark-mode .ocr-camera__btn--switch:hover{background:#fff3}.ocr-camera__btn--capture{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;box-shadow:0 4px 20px #4f46e566}.ocr-camera__btn--capture:hover{transform:scale(1.05);box-shadow:0 6px 24px #4f46e580}.ocr-camera__btn--capture:active{transform:scale(.95)}.ocr-camera__error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;gap:16px;color:#dc2626}body.dark-mode .ocr-camera__error{color:#f87171}.ocr-camera__error p{margin:0;font-size:14px;line-height:1.5;color:#475569}body.dark-mode .ocr-camera__error p{color:#94a3b8}.ocr-camera__error-btn{padding:10px 24px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.ocr-camera__error-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4f46e566}.ocr-scanning{text-align:center}.ocr-scanning__preview{position:relative;border-radius:18px;overflow:hidden;margin-bottom:28px;box-shadow:0 12px 32px #4f46e526}.ocr-scanning__preview img{width:100%;max-height:320px;object-fit:contain;filter:saturate(.8)}.ocr-scanning__overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 0%,rgba(79,70,229,.05) 100%)}.ocr-scanning__line{position:absolute;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,#4f46e5,#7c3aed,#4f46e5,transparent);box-shadow:0 0 20px #4f46e599;animation:scanLine 2.5s ease-in-out infinite}@keyframes scanLine{0%,to{top:0;opacity:0}10%{opacity:1}50%{top:calc(100% - 4px)}90%{opacity:1}}.ocr-scanning__progress{display:flex;flex-direction:column;align-items:center;gap:14px;padding:0 12px}.ocr-scanning__spinner{animation:spin 1s linear infinite;color:var(--color-primary-600, #4f46e5);filter:drop-shadow(0 4px 8px rgba(79,70,229,.3))}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ocr-scanning__stage{font-size:17px;font-weight:600;color:var(--text-primary, #1f2937);letter-spacing:-.01em}body.dark-mode .ocr-scanning__stage{color:#f3f4f6}.ocr-scanning__bar{width:100%;height:10px;background:var(--color-gray-200, #e5e7eb);border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}body.dark-mode .ocr-scanning__bar{background:#37415199}.ocr-scanning__bar-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed,#a855f7);border-radius:6px;transition:width .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #4f46e566;position:relative}.ocr-scanning__bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ocr-scanning__percent{font-size:15px;font-weight:700;color:var(--color-primary-600, #4f46e5);letter-spacing:.02em}.ocr-review__confidence{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding:10px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:12px;font-weight:600;color:#334155}body.dark-mode .ocr-review__confidence{background:linear-gradient(145deg,#37415180,#2d374866);border-color:#ffffff14;color:#94a3b8}.ocr-review__confidence-badge{padding:4px 10px;border-radius:16px;font-weight:700;font-size:11px}.ocr-review__confidence-badge.high{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857;box-shadow:0 2px 8px #10b98133}.ocr-review__confidence-badge.medium{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309;box-shadow:0 2px 8px #f59e0b33}.ocr-review__confidence-badge.low{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c;box-shadow:0 2px 8px #ef444433}.ocr-review__fields{display:flex;flex-direction:column;gap:14px;margin-bottom:16px}.ocr-field__label{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:10px;font-weight:700;color:#1e293b;text-transform:uppercase;letter-spacing:.05em}.ocr-field__label svg{color:#64748b;width:12px;height:12px}body.dark-mode .ocr-field__label{color:#e2e8f0}body.dark-mode .ocr-field__label svg{color:#94a3b8}.ocr-field__input{width:100%;padding:10px 12px;border:1.5px solid #cbd5e1;border-radius:8px;font-size:13px;font-weight:500;background:#fff;color:#0f172a;transition:all .2s ease}body.dark-mode .ocr-field__input{background:#1e293bcc;border-color:#64748b80;color:#f1f5f9}.ocr-field__input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}body.dark-mode .ocr-field__input:focus{box-shadow:0 0 0 3px #6366f140}.ocr-field__input--large{font-size:20px;font-weight:700;color:#059669;text-align:center;background:#f0fdf4;border-color:#86efac;padding:8px 12px}body.dark-mode .ocr-field__input--large{color:#34d399;background:#10b9811a;border-color:#34d3994d}.ocr-field__categories{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.ocr-field__category{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .15s ease;font-size:9px;font-weight:600;color:#475569}body.dark-mode .ocr-field__category{background:#33415566;border-color:#64748b4d;color:#94a3b8}.ocr-field__category:hover{background:#f1f5f9;border-color:#94a3b8}body.dark-mode .ocr-field__category:hover{background:#47556980;border-color:#94a3b866}.ocr-field__category.active{background:#eef2ff;border-color:#6366f1;color:#4338ca}body.dark-mode .ocr-field__category.active{background:#6366f133;border-color:#818cf8;color:#a5b4fc}.ocr-field__category span:first-child{font-size:16px}.ocr-review__items{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px;max-height:160px;overflow-y:auto}body.dark-mode .ocr-review__items{background:#1e293b99;border-color:#64748b4d}.ocr-review__item{display:flex;justify-content:space-between;padding:8px 0;font-size:13px;font-weight:500;color:#334155;border-bottom:1px dashed #e2e8f0}body.dark-mode .ocr-review__item{color:#cbd5e1;border-bottom-color:#64748b4d}.ocr-review__item:last-child{border-bottom:none}.ocr-review__items-more{display:block;text-align:center;padding-top:10px;font-size:12px;font-weight:500;color:#64748b}body.dark-mode .ocr-review__items-more{color:#94a3b8}.ocr-review__actions{display:flex;gap:10px}.ocr-review__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border:none;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.ocr-review__btn svg{width:14px;height:14px}.ocr-review__btn--primary{background:linear-gradient(135deg,#4f46e5,#7c3aed,#a855f7);color:#fff;box-shadow:0 6px 20px #4f46e559,inset 0 1px #fff3}.ocr-review__btn--primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 28px #4f46e573,inset 0 1px #fff3}.ocr-review__btn--primary:active{transform:translateY(-1px) scale(1.01)}.ocr-review__btn--secondary{background:#f1f5f9;color:#1e293b;border:1px solid #cbd5e1;box-shadow:0 2px 8px #0000000f}body.dark-mode .ocr-review__btn--secondary{background:#33415599;color:#f1f5f9;border-color:#64748b66}.ocr-review__btn--secondary:hover{background:#e2e8f0;border-color:#94a3b8}body.dark-mode .ocr-review__btn--secondary:hover{background:#475569b3}.ocr-success{text-align:center;padding:48px 24px}.ocr-success__icon{width:88px;height:88px;margin:0 auto 24px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 12px 32px #10b98166,inset 0 2px #fff3;animation:successPop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes successPop{0%{transform:scale(0) rotate(-30deg);opacity:0}50%{transform:scale(1.1) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}.ocr-success h3{margin:0 0 10px;font-size:24px;font-weight:800;color:var(--text-primary, #1f2937);letter-spacing:-.02em}body.dark-mode .ocr-success h3{color:#f3f4f6}.ocr-success p{margin:0;font-size:15px;color:var(--text-secondary, #6b7280)}body.dark-mode .ocr-success p{color:#9ca3af}@media(max-width:480px){.ocr-modal__content{max-width:100%;border-radius:24px 24px 0 0;max-height:95vh;margin-top:auto}.ocr-capture__options{grid-template-columns:1fr;gap:8px}.ocr-capture__option{flex-direction:row;gap:12px;padding:12px 14px;text-align:left}.ocr-capture__option-icon{width:36px;height:36px;flex-shrink:0}.ocr-capture__option-icon svg{width:16px;height:16px}.ocr-field__categories{grid-template-columns:repeat(4,1fr);gap:6px}.ocr-field__category{padding:10px 4px;font-size:10px}.ocr-field__category span:first-child{font-size:20px}.ocr-review__actions{flex-direction:column;gap:10px}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#fef2f2,#fce7f3)}.error-boundary__card{background:#fff;border-radius:16px;padding:40px;max-width:480px;width:100%;text-align:center;box-shadow:0 20px 60px #0000001a}.error-boundary__icon{width:80px;height:80px;margin:0 auto 24px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{transform:scale(1);box-shadow:0 0 #fbbf2466}50%{transform:scale(1.05);box-shadow:0 0 0 20px #fbbf2400}}.error-boundary__title{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 12px}.error-boundary__message{font-size:16px;color:#6b7280;margin:0 0 32px;line-height:1.6}.error-boundary__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}.error-boundary__btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease}.error-boundary__btn--primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.error-boundary__btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #4f46e54d}.error-boundary__btn--secondary{background:#f3f4f6;color:#374151}.error-boundary__btn--secondary:hover{background:#e5e7eb}.error-boundary__details-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:#9ca3af;font-size:12px;cursor:pointer;padding:8px;transition:color .2s}.error-boundary__details-toggle:hover{color:#6b7280}.error-boundary__details{margin-top:16px;text-align:left;background:#1f2937;border-radius:8px;padding:16px;overflow:auto;max-height:300px}.error-boundary__details pre{margin:0;font-size:11px;color:#e5e7eb;white-space:pre-wrap;word-break:break-word;font-family:Monaco,Consolas,monospace}.error-boundary__details strong{color:#fbbf24}@media(max-width:480px){.error-boundary__card{padding:24px}.error-boundary__actions{flex-direction:column}.error-boundary__btn{width:100%;justify-content:center}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 20px}.loading-spinner__fullscreen{position:fixed;inset:0;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.loading-spinner__ring{display:inline-block;position:relative}.loading-spinner--small .loading-spinner__ring{width:24px;height:24px}.loading-spinner--medium .loading-spinner__ring{width:40px;height:40px}.loading-spinner--large .loading-spinner__ring{width:64px;height:64px}.loading-spinner__ring div{box-sizing:border-box;display:block;position:absolute;width:100%;height:100%;border-radius:50%;border-style:solid;border-color:#4f46e5 transparent transparent transparent;animation:loading-ring 1.2s cubic-bezier(.5,0,.5,1) infinite}.loading-spinner--small .loading-spinner__ring div{border-width:2px}.loading-spinner--medium .loading-spinner__ring div{border-width:3px}.loading-spinner--large .loading-spinner__ring div{border-width:4px}.loading-spinner__ring div:nth-child(1){animation-delay:-.45s}.loading-spinner__ring div:nth-child(2){animation-delay:-.3s}.loading-spinner__ring div:nth-child(3){animation-delay:-.15s}@keyframes loading-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner__message{font-size:14px;color:#6b7280;margin:0;font-weight:500}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--text{height:16px;width:100%}.skeleton--title{height:24px;width:60%}.skeleton--card{height:120px;width:100%;border-radius:12px}.skeleton--avatar{width:40px;height:40px;border-radius:50%}.skeleton--button{height:40px;width:120px;border-radius:8px}.onboarding-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}.onboarding-backdrop{position:absolute;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease}.onboarding-card{position:relative;background:var(--surface-elevated, #fff);border-radius:24px;padding:40px;max-width:440px;width:100%;text-align:center;box-shadow:0 25px 80px #0000004d;animation:slideInUp .4s cubic-bezier(.34,1.56,.64,1)}.onboarding-skip{position:absolute;top:16px;right:16px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100, #f3f4f6);border:none;border-radius:50%;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .2s}.onboarding-skip:hover{background:var(--color-gray-200, #e5e7eb);color:var(--text-primary, #1f2937)}.onboarding-progress{display:flex;justify-content:center;gap:8px;margin-bottom:32px}.onboarding-dot{width:10px;height:10px;border-radius:50%;background:var(--color-gray-300, #d1d5db);border:none;padding:0;cursor:pointer;transition:all .3s ease}.onboarding-dot.active{width:28px;border-radius:5px;background:var(--color-primary-500, #6366f1)}.onboarding-dot.completed{background:var(--color-primary-400, #818cf8)}.onboarding-content{transition:all .2s ease}.onboarding-content.animating{opacity:0;transform:translate(-10px)}.onboarding-icon{width:88px;height:88px;margin:0 auto 24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 12px 32px #6366f14d;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.onboarding-title{font-size:24px;font-weight:700;color:var(--text-primary, #1f2937);margin:0 0 16px}.onboarding-description{font-size:15px;color:var(--text-secondary, #6b7280);line-height:1.6;margin:0 0 32px}.onboarding-nav{display:flex;gap:12px}.onboarding-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:12px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease}.onboarding-btn:disabled{opacity:.4;cursor:not-allowed}.onboarding-btn--primary{background:linear-gradient(135deg,var(--color-primary-500, #6366f1),var(--color-primary-600, #4f46e5));color:#fff}.onboarding-btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6366f159}.onboarding-btn--secondary{background:#ffffff1a;color:var(--text-primary, #1f2937);border:1px solid rgba(255,255,255,.2)}.onboarding-btn--secondary:hover:not(:disabled){background:#ffffff2e;border-color:#ffffff4d}@media(prefers-color-scheme:light){.onboarding-btn--secondary{background:var(--color-gray-100, #f3f4f6);color:var(--text-primary, #1f2937);border:1px solid transparent}.onboarding-btn--secondary:hover:not(:disabled){background:var(--color-gray-200, #e5e7eb)}}.onboarding-counter{margin-top:20px;font-size:12px;color:var(--text-muted, #9ca3af)}@media(max-width:480px){.onboarding-card{padding:28px 20px;margin:0 12px}.onboarding-icon{width:72px;height:72px}.onboarding-icon svg{width:32px;height:32px}.onboarding-title{font-size:20px}.onboarding-description{font-size:14px}}@keyframes slideInUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.global-search-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;display:flex;justify-content:center;padding-top:100px;animation:fadeIn .15s ease}.global-search{width:100%;max-width:580px;background:var(--surface-elevated, #fff);border-radius:16px;box-shadow:0 25px 80px #0000004d;overflow:hidden;animation:slideDown .2s ease;max-height:calc(100vh - 200px);display:flex;flex-direction:column}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.global-search__input-wrapper{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border-primary, #e5e7eb)}.global-search__icon{color:var(--text-muted, #9ca3af);flex-shrink:0}.global-search__input{flex:1;border:none;background:transparent;font-size:17px;color:var(--text-primary, #1f2937);outline:none}.global-search__input::placeholder{color:var(--text-muted, #9ca3af)}.global-search__shortcut{display:flex;gap:4px}.global-search__shortcut kbd{padding:3px 6px;background:var(--color-gray-100, #f3f4f6);border-radius:4px;font-size:11px;color:var(--text-secondary, #6b7280);font-family:inherit}.global-search__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--color-gray-100, #f3f4f6);border-radius:6px;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .15s}.global-search__close:hover{background:var(--color-gray-200, #e5e7eb)}.global-search__results{flex:1;overflow-y:auto;padding:8px}.global-search__section{margin-bottom:8px}.global-search__section:last-child{margin-bottom:0}.global-search__section-title{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #9ca3af)}.global-search__item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;text-align:left;transition:all .1s;color:var(--text-primary, #1f2937)}.global-search__item:hover,.global-search__item.selected{background:var(--color-primary-50, #eef2ff)}.global-search__item.selected{background:var(--color-primary-100, #e0e7ff)}.global-search__item-icon{color:var(--color-primary-500, #6366f1);flex-shrink:0}.global-search__item-label{flex:1;font-size:14px;font-weight:500}.global-search__item-content{flex:1;display:flex;flex-direction:column;gap:2px}.global-search__item-sub{font-size:12px;color:var(--text-secondary, #6b7280)}.global-search__item-meta{display:flex;align-items:center;gap:8px;color:var(--text-muted, #9ca3af)}.global-search__item-meta kbd{padding:2px 6px;background:var(--color-gray-100, #f3f4f6);border-radius:4px;font-size:10px;font-weight:600}.global-search__item--recent .global-search__item-icon{color:var(--text-muted, #9ca3af)}.global-search__empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;color:var(--text-muted, #9ca3af)}.global-search__empty p{margin:0;font-size:14px}.global-search__footer{display:flex;justify-content:center;gap:24px;padding:12px 20px;background:var(--color-gray-50, #f9fafb);border-top:1px solid var(--border-primary, #e5e7eb);font-size:12px;color:var(--text-secondary, #6b7280)}.global-search__footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;padding:2px 5px;margin-right:4px;background:var(--color-gray-200, #e5e7eb);border-radius:4px;font-size:10px;font-weight:600;font-family:inherit}@media(max-width:640px){.global-search-overlay{padding:60px 20px 20px}.global-search{max-height:calc(100vh - 100px)}.global-search__shortcut,.global-search__footer{display:none}}.shortcut-help-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}.shortcut-help{background:var(--surface-elevated, #fff);border-radius:16px;width:100%;max-width:480px;box-shadow:0 25px 80px #00000040;animation:slideUp .2s ease;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.shortcut-help__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary, #e5e7eb)}.shortcut-help__title{display:flex;align-items:center;gap:10px;color:var(--text-primary, #1f2937)}.shortcut-help__title h2{margin:0;font-size:18px;font-weight:600}.shortcut-help__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--color-gray-100, #f3f4f6);border-radius:8px;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .15s}.shortcut-help__close:hover{background:var(--color-gray-200, #e5e7eb)}.shortcut-help__content{padding:16px 20px;max-height:60vh;overflow-y:auto}.shortcut-help__category{margin-bottom:20px}.shortcut-help__category:last-child{margin-bottom:0}.shortcut-help__category-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #9ca3af);margin:0 0 10px}.shortcut-help__list{display:flex;flex-direction:column;gap:8px}.shortcut-help__item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-gray-50, #f9fafb);border-radius:8px}.shortcut-help__description{font-size:14px;color:var(--text-primary, #1f2937)}.shortcut-help__keys{display:flex;align-items:center;gap:4px}.shortcut-help__keys kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;padding:4px 8px;background:var(--color-gray-200, #e5e7eb);border-radius:6px;font-size:12px;font-weight:600;font-family:inherit;color:var(--text-primary, #1f2937)}.shortcut-help__keys span{color:var(--text-muted, #9ca3af);font-size:12px}.shortcut-help__footer{padding:12px 20px;background:var(--color-gray-50, #f9fafb);border-top:1px solid var(--border-primary, #e5e7eb);font-size:12px;color:var(--text-secondary, #6b7280);text-align:center}.shortcut-help__footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:2px 5px;margin:0 2px;background:var(--color-gray-200, #e5e7eb);border-radius:4px;font-size:10px;font-weight:600;font-family:inherit}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
