:root{--primary-50: #f0f9ff;--primary-100: #e0f2fe;--primary-200: #bae6fd;--primary-300: #7dd3fc;--primary-400: #38bdf8;--primary-500: #0ea5e9;--primary-600: #0284c7;--primary-700: #0369a1;--primary-800: #075985;--primary-900: #0c4a6e;--secondary-50: #fef3c7;--secondary-100: #fde68a;--secondary-300: #fbbf24;--secondary-400: #f59e0b;--secondary-500: #d97706;--secondary-600: #b45309;--success-50: #ecfdf5;--success-100: #d1fae5;--success-500: #10b981;--success-600: #059669;--warning-50: #fff7ed;--warning-100: #ffedd5;--warning-500: #f97316;--warning-600: #ea580c;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--gray-50: #fafaf9;--gray-100: #f5f5f4;--gray-200: #e7e5e4;--gray-300: #d6d3d1;--gray-400: #a8a29e;--gray-500: #78716c;--gray-600: #57534e;--gray-700: #44403c;--gray-800: #292524;--gray-900: #1c1917;--bg-page: #fafaf9;--bg-card: #ffffff;--bg-elevated: #f5f5f4;--bg-hover: #f5f5f4;--bg-input: #ffffff;--text-primary: #1c1917;--text-secondary: #57534e;--text-muted: #78716c;--text-disabled: #a8a29e;--border-color: #e7e5e4;--border-hover: #d6d3d1;--border-focus: #0ea5e9;--primary-btn: #0ea5e9;--primary-btn-hover: #0284c7;--primary-text: #0284c7;--primary-text-hover: #0369a1;--primary-bg: #f0f9ff;--primary-bg-hover: #e0f2fe;--primary-border: #bae6fd;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--ease-smooth: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--chart-purchased: #2563eb;--chart-opened: #10b981;--chart-depleted: #f59e0b;--chart-grid: #e5e7eb;--chart-purchased-fill: rgba(37, 99, 235, .1);--chart-opened-fill: rgba(16, 185, 129, .1);--chart-depleted-fill: rgba(245, 158, 11, .1)}[data-theme=dark]{--bg-page: #18181b;--bg-card: #27272a;--bg-elevated: #3f3f46;--bg-hover: #52525b;--bg-input: #3f3f46;--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-disabled: #52525b;--border-color: #3f3f46;--border-hover: #52525b;--border-focus: #38bdf8;--primary-btn: #38bdf8;--primary-btn-hover: #7dd3fc;--primary-text: #38bdf8;--primary-text-hover: #7dd3fc;--primary-bg: rgba(56, 189, 248, .1);--primary-bg-hover: rgba(56, 189, 248, .15);--primary-border: rgba(56, 189, 248, .3);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .6);--error-50: rgba(239, 68, 68, .15);--error-100: rgba(239, 68, 68, .25);--error-500: #f87171;--error-600: #fca5a5;--success-50: rgba(16, 185, 129, .15);--success-100: rgba(16, 185, 129, .25);--success-500: #34d399;--success-600: #6ee7b7;--warning-50: rgba(249, 115, 22, .15);--warning-100: rgba(249, 115, 22, .25);--warning-500: #fb923c;--warning-600: #fdba74;--secondary-50: rgba(245, 158, 11, .15);--secondary-100: rgba(245, 158, 11, .25);--secondary-400: #fbbf24;--secondary-500: #fcd34d;--secondary-600: #fde68a;--chart-purchased: #60a5fa;--chart-opened: #34d399;--chart-depleted: #fbbf24;--chart-grid: #3f3f46;--chart-purchased-fill: rgba(96, 165, 250, .15);--chart-opened-fill: rgba(52, 211, 153, .15);--chart-depleted-fill: rgba(251, 191, 36, .15)}*{margin:0;padding:0;box-sizing:border-box}html{color-scheme:light;overflow-x:hidden}[data-theme=dark]{color-scheme:dark}body{font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-page);color:var(--text-primary);line-height:1.5;transition:background-color var(--duration-slow) var(--ease-smooth),color var(--duration-slow) var(--ease-smooth)}*:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:4px}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.1rem;color:var(--text-muted);font-weight:500}.app-loader{display:flex;flex-direction:column;align-items:center;gap:16px;animation:fadeIn .3s var(--ease-smooth)}.app-loader-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.container{max-width:1600px;margin:0 auto;padding:0 24px}@media(max-width:640px){.container{padding:0 16px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-size:15px;font-family:var(--font-family);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:0 2px 8px #0ea5e940}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e959}.btn-primary:active:not(:disabled){transform:translateY(0) scale(.98)}.btn-primary svg,.btn-success svg,.btn-danger svg,.btn-secondary svg{transition:transform var(--duration-normal) var(--ease-smooth)}.btn-primary:hover:not(:disabled) svg,.btn-success:hover:not(:disabled) svg{transform:scale(1.1)}.btn-danger:hover:not(:disabled) svg{transform:scale(1.1) rotate(-3deg)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1.5px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.btn-success{background:linear-gradient(135deg,var(--success-500) 0%,var(--success-600) 100%);color:#fff;box-shadow:0 2px 8px #10b98140}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b98159}.btn-danger{background:linear-gradient(135deg,var(--error-500) 0%,var(--error-600) 100%);color:#fff;box-shadow:0 2px 8px #ef444433}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;font-size:15px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color var(--duration-fast),box-shadow var(--duration-fast);-webkit-appearance:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.form-group label{transition:color var(--duration-fast)}.form-group:focus-within label{color:var(--primary-text)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-disabled)}.form-group input:-webkit-autofill,.form-group input:-webkit-autofill:hover,.form-group input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--bg-input) inset;-webkit-text-fill-color:var(--text-primary);transition:background-color 5000s ease-in-out 0s}input[type=date],input[type=time],input[type=datetime-local]{color:var(--text-primary);background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 10px;font-size:13px;font-family:var(--font-family);outline:none}input[type=date]:focus,input[type=time]:focus,input[type=datetime-local]:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg)}.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2378716c' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:20px;border:1px solid var(--border-color);transition:box-shadow var(--duration-normal) var(--ease-smooth),transform var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal)}.card:hover{box-shadow:var(--shadow-md)}.error{background:var(--error-100);color:var(--error-600);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:14px;font-weight:500;border:1px solid rgba(239,68,68,.2)}.success{background:var(--success-100);color:var(--success-600);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:14px;font-weight:500;border:1px solid rgba(16,185,129,.2)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scalePop{0%{transform:scale(.96);opacity:0}60%{transform:scale(1.01)}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes staggerIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stagger-in{animation:staggerIn .4s var(--ease-smooth) both}.stagger-in:nth-child(1){animation-delay:0ms}.stagger-in:nth-child(2){animation-delay:50ms}.stagger-in:nth-child(3){animation-delay:.1s}.stagger-in:nth-child(4){animation-delay:.15s}.stagger-in:nth-child(5){animation-delay:.2s}.stagger-in:nth-child(6){animation-delay:.25s}.stagger-in:nth-child(7){animation-delay:.3s}.stagger-in:nth-child(8){animation-delay:.35s}.stagger-in:nth-child(9){animation-delay:.4s}.stagger-in:nth-child(10){animation-delay:.45s}.dark-mode-toggle{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--duration-normal) var(--ease-smooth);flex-shrink:0}.dark-mode-toggle:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 40%,#1e1b4b 100%);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(56,189,248,.15) 0%,transparent 70%);top:-200px;right:-200px;pointer-events:none}.login-container:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);bottom:-100px;left:-100px;pointer-events:none}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:440px;box-shadow:0 25px 60px #0000004d;animation:loginCardIn .5s var(--ease-smooth);transition:background-color var(--duration-slow);position:relative;z-index:1;border:1px solid rgba(255,255,255,.1)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card h1{text-align:center;color:var(--text-primary);margin-bottom:0;font-size:26px;font-weight:600;letter-spacing:-.025em}.login-card h2{text-align:center;color:var(--text-muted);margin-bottom:32px;font-size:16px;font-weight:400}.btn-block{width:100%;margin-top:8px}.login-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--text-muted)}.link-button{background:none;border:none;color:var(--primary-text);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-family);text-decoration:underline;padding:0}.link-button:hover{color:var(--primary-text-hover)}.registration-mode-selector{display:flex;flex-direction:column;gap:12px;margin:16px 0 24px}.mode-option{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1.5px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast)}.mode-option:hover{border-color:var(--primary-btn);background:var(--primary-bg)}.mode-option input[type=radio]{margin-top:3px;flex-shrink:0;accent-color:var(--primary-btn)}.mode-title{font-weight:700;color:var(--text-primary);margin-bottom:4px;font-size:15px}.mode-description{font-size:13px;color:var(--text-muted)}.clinic-code-validation{margin-top:6px;font-size:13px;font-weight:500;min-height:18px}.clinic-code-validation.valid{color:var(--success-600)}.clinic-code-validation.invalid{color:var(--error-600)}.success-code-display{background:var(--success-50);border:1.5px solid rgba(16,185,129,.3);border-radius:var(--radius-md);padding:24px;text-align:center;margin:16px 0 24px;animation:scalePop var(--duration-slow) var(--ease-smooth)}.success-code-display h3{color:var(--success-600);font-size:18px;margin-bottom:12px;font-weight:700}.code-to-share{font-size:32px;font-weight:700;font-family:Courier New,monospace;letter-spacing:4px;color:var(--text-primary);margin:12px 0}.button-group{display:flex;gap:12px;margin-top:8px}[data-theme=dark] .login-container{background:linear-gradient(135deg,#0c4a6e,#0f172a,#1e1b4b)}[data-theme=dark] .login-card{border-color:#ffffff0f}.brand-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:8px}.brand-header h1{font-size:32px;font-weight:300;letter-spacing:.25em;text-transform:uppercase;color:var(--text-primary)}.brand-icon{width:64px;height:64px}.success-invite-display{background:var(--success-50);border:1.5px solid rgba(16,185,129,.3);border-radius:var(--radius-md);padding:20px;text-align:center;margin:16px 0 24px;animation:scalePop var(--duration-slow) var(--ease-smooth)}.success-invite-display h3{color:var(--success-600);font-size:18px;margin-bottom:8px;font-weight:700}.success-invite-display p{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.invite-link-box{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 14px;font-family:Courier New,monospace;font-size:12px;color:var(--text-primary);word-break:break-all;margin:12px 0;text-align:left}.invite-link-actions{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:8px}.auth-mode-cards{display:flex;gap:8px}.auth-mode-card{flex:1;display:flex;gap:10px;align-items:flex-start;border:1.5px solid var(--border-color);border-radius:var(--radius-md);padding:12px;cursor:pointer;transition:border-color var(--duration-fast),background var(--duration-fast)}.auth-mode-card input[type=radio]{margin-top:2px;flex-shrink:0;accent-color:var(--primary-btn)}.auth-mode-card.selected{border-color:var(--primary-btn);background:var(--primary-bg)}.auth-mode-card-title{font-weight:700;font-size:14px;color:var(--text-primary)}.auth-mode-card-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.join-clinic-banner{background:var(--primary-bg);border:1px solid var(--primary-border);border-radius:var(--radius-sm);padding:12px 16px;font-size:14px;font-weight:500;color:var(--primary-700);margin-bottom:20px;text-align:center}[data-theme=dark] .join-clinic-banner{color:var(--primary-text)}.avatar-dropdown{position:relative;display:inline-flex;align-items:center}.avatar-btn{width:36px;height:36px;border-radius:var(--radius-full);background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);font-size:13px;font-weight:700;font-family:var(--font-family);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast) var(--ease-smooth),transform .15s var(--ease-smooth),border-color var(--duration-fast);flex-shrink:0;line-height:1;letter-spacing:.02em}.avatar-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:scale(1.08)}.avatar-btn:focus-visible{outline:2px solid var(--primary-btn);outline-offset:2px}.avatar-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:var(--shadow-lg);min-width:220px;z-index:1000;overflow:hidden;animation:avatar-menu-appear .12s ease-out;transition:background-color var(--duration-slow)}@keyframes avatar-menu-appear{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.avatar-dropdown-header{padding:12px 16px;display:flex;flex-direction:column;gap:2px}.avatar-dropdown-name{font-size:14px;font-weight:700;color:var(--text-primary)}.avatar-dropdown-role{font-size:12px;color:var(--text-muted);text-transform:capitalize}.avatar-dropdown-divider{height:1px;background:var(--border-color);margin:4px 0}.avatar-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:none;border:none;text-align:left;font-size:14px;font-family:var(--font-family);color:var(--text-primary);cursor:pointer;text-decoration:none;transition:background .1s}.avatar-dropdown-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.avatar-dropdown-item--danger{color:var(--error-600)}.avatar-dropdown-item--danger:hover{background:var(--error-50);color:var(--error-600)}.avatar-dropdown-item-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}.tour-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px;animation:tour-fade-in var(--duration-normal) ease-out}@keyframes tour-fade-in{0%{opacity:0}to{opacity:1}}.tour-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:32px;max-width:480px;width:100%;box-shadow:var(--shadow-xl);animation:tour-slide-up var(--duration-normal) ease-out;transition:background-color var(--duration-slow)}@keyframes tour-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.tour-header{text-align:center;margin-bottom:20px}.tour-icon{font-size:48px;line-height:1;margin-bottom:12px}.tour-step-badge{display:inline-block;background:var(--primary-bg);color:var(--primary-text);font-size:13px;font-weight:600;padding:4px 12px;border-radius:var(--radius-xl);margin-bottom:12px}.tour-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.tour-body{min-height:90px;margin-bottom:24px}.tour-intro{font-size:16px;color:var(--text-primary);text-align:center;margin-bottom:16px;line-height:1.5}.tour-content{font-size:15px;color:var(--text-primary);line-height:1.6;margin:0}.tour-bullets{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.tour-bullets li{font-size:15px;color:var(--text-primary);padding:10px 14px;background:var(--bg-elevated);border-radius:var(--radius-sm);border-left:3px solid var(--primary-btn)}.tour-dots{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.tour-dot{width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:background var(--duration-normal) var(--ease-smooth),transform var(--duration-normal) var(--ease-smooth)}.tour-dot-active{background:var(--primary-btn);transform:scale(1.3)}.tour-actions{display:flex;gap:12px;justify-content:flex-end;align-items:center}.btn-tour-primary{background:var(--primary-btn);color:#fff;border:none;padding:10px 22px;border-radius:var(--radius-sm);font-size:15px;font-family:var(--font-family);font-weight:600;cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth),transform .1s}.btn-tour-primary:hover{background:var(--primary-btn-hover);transform:translateY(-1px)}.btn-tour-skip{background:none;color:var(--text-muted);border:none;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);cursor:pointer;transition:color var(--duration-fast) var(--ease-smooth)}.btn-tour-skip:hover{color:var(--text-secondary)}.btn-tour-back{background:none;color:var(--text-secondary);border:1px solid var(--border-color);padding:10px 16px;border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth)}.btn-tour-back:hover{background:var(--bg-elevated);color:var(--text-primary)}@media(max-width:520px){.tour-card{padding:24px 20px}.tour-title{font-size:19px}}.shortcuts-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn var(--duration-fast) var(--ease-smooth)}.shortcuts-modal{background:var(--bg-card);border-radius:var(--radius-lg);max-width:460px;width:100%;box-shadow:var(--shadow-xl);overflow:hidden;animation:slideUp var(--duration-fast) var(--ease-smooth);border:1px solid var(--border-color)}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.shortcuts-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.shortcuts-close{background:none;border:none;font-size:18px;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background var(--duration-fast),color var(--duration-fast);line-height:1;font-family:var(--font-family)}.shortcuts-close:hover{background:var(--bg-hover);color:var(--text-primary)}.shortcuts-body{padding:20px 24px;display:flex;flex-direction:column;gap:20px}.shortcuts-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 10px}.shortcuts-list{display:flex;flex-direction:column;gap:6px}.shortcut-row{display:flex;align-items:center;gap:12px;padding:6px 0}.shortcut-keys{display:flex;align-items:center;gap:4px;min-width:80px}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:26px;padding:0 6px;background:var(--bg-elevated);border:1px solid var(--border-color);border-bottom-width:2px;border-radius:5px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-weight:600;color:var(--text-primary)}.shortcut-key-sm{min-width:22px;height:22px;font-size:12px}.shortcut-desc{font-size:14px;color:var(--text-secondary);font-weight:500}.shortcuts-footer{padding:14px 24px;background:var(--bg-elevated);border-top:1px solid var(--border-color);font-size:13px;color:var(--text-muted);text-align:center;display:flex;align-items:center;justify-content:center;gap:6px}.stm-overlay{position:fixed;inset:0;z-index:2000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px}.stm-modal{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.stm-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.stm-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.stm-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;transition:background var(--duration-fast)}.stm-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.stm-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.stm-field{display:flex;flex-direction:column;gap:6px}.stm-field label{font-size:13px;font-weight:600;color:var(--text-secondary)}.stm-field select,.stm-field textarea{font-family:var(--font-family);font-size:14px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-primary);outline:none;transition:border-color var(--duration-fast)}.stm-field select:focus,.stm-field textarea:focus{border-color:var(--primary-btn)}.stm-field textarea{resize:vertical;min-height:100px}.stm-char-count{font-size:12px;color:var(--text-muted);text-align:right}.stm-severity-group{display:flex;gap:0;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.stm-severity-btn{flex:1;padding:8px 12px;border:none;background:var(--bg-elevated);color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:background var(--duration-fast),color var(--duration-fast)}.stm-severity-btn:not(:last-child){border-right:1px solid var(--border-color)}.stm-severity-btn:hover{background:var(--bg-page)}.stm-severity-active.stm-severity-low{background:var(--success-50);color:var(--success-700);font-weight:600}.stm-severity-active.stm-severity-medium{background:var(--warning-50);color:var(--warning-700);font-weight:600}.stm-severity-active.stm-severity-high{background:var(--error-50);color:var(--error-700);font-weight:600}.stm-error{background:var(--error-50);color:var(--error-700);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px}.stm-success{padding:48px 24px;text-align:center;color:var(--success-500);display:flex;flex-direction:column;align-items:center;gap:12px}.stm-success p{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.stm-capture-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1px dashed var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);font-family:var(--font-family);font-size:13px;font-weight:500;cursor:pointer;transition:border-color var(--duration-fast),color var(--duration-fast)}.stm-capture-btn:hover:not(:disabled){border-color:var(--primary-btn);color:var(--primary-btn)}.stm-capture-btn:disabled{opacity:.6;cursor:not-allowed}.stm-screenshot-preview{display:flex;flex-direction:column;gap:8px}.stm-screenshot-preview img{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border-color);max-height:200px;object-fit:contain;background:var(--bg-elevated)}.stm-screenshot-actions{display:flex;align-items:center;justify-content:space-between}.stm-screenshot-attached{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--success-700)}.stm-screenshot-remove{display:flex;align-items:center;gap:4px;padding:4px 8px;border:none;border-radius:var(--radius-sm);background:none;color:var(--text-muted);font-family:var(--font-family);font-size:12px;cursor:pointer;transition:color var(--duration-fast)}.stm-screenshot-remove:hover{color:var(--error-700)}.floating-report-btn{position:fixed;bottom:24px;right:24px;z-index:1000;width:52px;height:52px;border-radius:50%;background:var(--primary-btn);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:background var(--duration-fast) var(--ease-smooth),transform var(--duration-fast)}.floating-report-btn:hover{background:var(--primary-btn-hover);transform:scale(1.08)}.message-center-btn{position:relative;width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast),color var(--duration-fast),border-color var(--duration-fast);flex-shrink:0}.message-center-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.message-center-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;border-radius:8px;background:var(--error-500);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;border:2px solid var(--primary-700);animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.status-panel{overflow:hidden;display:flex;flex-direction:column}.status-panel-tabs{display:flex;border-bottom:1px solid var(--border-color)}.status-tab{flex:1;padding:12px 8px;border:none;background:none;font-family:var(--font-family);font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;position:relative;transition:color var(--duration-fast),background var(--duration-fast);display:flex;align-items:center;justify-content:center;gap:6px}.status-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.status-tab.active{color:var(--primary-text)}.status-tab.active:after{content:"";position:absolute;bottom:0;left:16px;right:16px;height:2px;background:var(--primary-btn);border-radius:2px 2px 0 0}.status-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);font-size:11px;font-weight:700;line-height:1}.status-tab-badge--alert{background:var(--error-100);color:var(--error-600)}.status-tab-badge--warn{background:var(--secondary-100);color:var(--secondary-600)}.status-panel-body{padding:12px 16px;flex:1}.status-sub-tabs{display:flex;gap:4px;margin-bottom:12px}.status-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:20px 0}.status-empty--ok{color:var(--success-600);display:flex;align-items:center;justify-content:center;gap:8px}.status-action{text-align:center;margin-top:12px}.status-summary{font-size:13px;color:var(--text-muted);margin:0 0 12px}.status-view-link{display:block;text-align:center;font-size:13px;color:var(--primary-btn);text-decoration:none;margin-top:12px;padding-top:8px;border-top:1px solid var(--border-color)}.status-view-link:hover{text-decoration:underline}.status-panel .expiry-alert-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:6px;cursor:pointer;transition:opacity var(--duration-fast) var(--ease-smooth);-webkit-user-select:none;user-select:none}.status-panel .expiry-alert-item:hover{opacity:.85}.status-panel .expiry-alert-item:last-of-type{margin-bottom:0}.status-panel .expiry-alert-expired{background:var(--error-50);border-left:3px solid var(--error-600)}.status-panel .expiry-alert-critical{background:var(--warning-50);border-left:3px solid var(--warning-600)}.status-panel .expiry-alert-warning{background:var(--secondary-50);border-left:3px solid var(--secondary-400)}.status-panel .expiry-alert-icon{font-size:16px;flex-shrink:0}.status-panel .expiry-alert-text{flex:1;font-size:13px;color:var(--text-primary)}.status-panel .expiry-alert-count{font-size:20px;font-weight:700;color:var(--text-primary)}.status-panel .ad-widget-item{border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:8px;border-left:4px solid transparent}.status-panel .ad-widget-item:last-of-type{margin-bottom:0}.status-panel .ad-widget-item.urgency-critical{background:#fef2f2;border-left-color:#dc2626}.status-panel .ad-widget-item.urgency-soon{background:#fff7ed;border-left-color:#ea580c}.status-panel .ad-widget-item.urgency-upcoming{background:#fefce8;border-left-color:#eab308}[data-theme=dark] .status-panel .ad-widget-item.urgency-critical{background:#dc26261f}[data-theme=dark] .status-panel .ad-widget-item.urgency-soon{background:#ea580c1f}[data-theme=dark] .status-panel .ad-widget-item.urgency-upcoming{background:#eab3081a}.status-panel .ad-widget-item-top{display:flex;align-items:flex-start;gap:8px}.status-panel .ad-widget-icon{font-size:16px;flex-shrink:0;margin-top:1px}.status-panel .ad-widget-info{flex:1;min-width:0}.status-panel .ad-widget-name{display:block;font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-panel .ad-widget-lot{display:block;font-size:12px;color:var(--text-muted)}.status-panel .ad-widget-dismiss{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-muted);padding:0 2px;line-height:1;flex-shrink:0}.status-panel .ad-widget-dismiss:hover{color:var(--text-primary)}.status-panel .ad-widget-countdown{font-size:12px;color:var(--text-secondary);margin:4px 0 0 24px}.status-panel .low-stock-list{display:flex;flex-direction:column;gap:6px}.status-panel .low-stock-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:transform var(--duration-fast) var(--ease-smooth),opacity var(--duration-fast) var(--ease-smooth);-webkit-user-select:none;user-select:none;animation:staggerIn .3s var(--ease-smooth) both}.status-panel .low-stock-item:nth-child(1){animation-delay:0ms}.status-panel .low-stock-item:nth-child(2){animation-delay:60ms}.status-panel .low-stock-item:nth-child(3){animation-delay:.12s}.status-panel .low-stock-item:nth-child(4){animation-delay:.18s}.status-panel .low-stock-item:nth-child(5){animation-delay:.24s}.status-panel .low-stock-item:hover{transform:translate(2px);opacity:.9}.status-panel .low-stock-item-warning{background:var(--secondary-50);border-left:3px solid var(--secondary-400)}.status-panel .low-stock-item-danger{background:var(--error-50);border-left:3px solid var(--error-600)}.status-panel .low-stock-item-name{flex:1;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:12px}.status-panel .low-stock-item-count{font-size:13px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.status-costs .cost-widget-body{display:flex;flex-direction:column;gap:8px}.status-panel-trends{border-top:1px solid var(--border-color);margin-top:auto}.status-panel-trends .panel{box-shadow:none;border:none;border-radius:0}.status-panel-trends .panel:hover{box-shadow:none}.empty-illustration{margin:0 auto 16px}.empty-illustration svg{width:100%;height:100%}.esi-float{animation:esiFloat 3s ease-in-out infinite}@keyframes esiFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.esi-sparkle{animation:esiSparkle 2s ease-in-out infinite}.esi-sparkle-1{animation-delay:0s}.esi-sparkle-2{animation-delay:.5s}.esi-sparkle-3{animation-delay:1s}@keyframes esiSparkle{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@media(prefers-reduced-motion:reduce){.esi-float,.esi-sparkle{animation:none}}.skeleton-shimmer{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite linear;border-radius:var(--radius-sm)}.skeleton-text{height:14px;border-radius:4px;margin-bottom:8px}.skeleton-text:last-child{margin-bottom:0}.skeleton-circle{border-radius:50%}.skeleton-rect{border-radius:var(--radius-sm)}.skeleton-card-block{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.skeleton-table-row td{padding:12px;border-top:1px solid var(--border-color)}.skeleton-table-row td .skeleton-shimmer{height:14px;border-radius:4px}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.install-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:16px;background:var(--primary-bg);border:1px solid var(--primary-border);border-radius:var(--radius-md, 10px);box-shadow:var(--shadow-sm)}.install-banner-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--primary-btn);color:#fff;border-radius:50%}.install-banner-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.install-banner-text strong{color:var(--text-primary);font-size:.9rem}.install-banner-text span{color:var(--text-secondary);font-size:.8rem}.install-banner-actions{flex-shrink:0;display:flex;align-items:center;gap:8px}.install-banner-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:50%;cursor:pointer;transition:background .15s,color .15s}.install-banner-close:hover{background:var(--bg-hover);color:var(--text-primary)}@media(max-width:480px){.install-banner{flex-wrap:wrap}.install-banner-text{flex-basis:calc(100% - 56px)}.install-banner-actions{flex-basis:100%;justify-content:flex-end}}.dashboard{min-height:100vh;background:var(--bg-page)}.dashboard-header{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-800) 60%,var(--primary-900) 100%);box-shadow:0 4px 20px #0ea5e926;padding:20px 0;margin-bottom:28px;border-bottom:none;position:sticky;top:0;z-index:40;transition:background var(--duration-slow)}.header-content{display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{font-size:22px;color:#fff;font-weight:700;margin-bottom:2px;letter-spacing:-.025em}.clinic-name{color:#ffffffb3;font-size:13px;font-weight:500}.user-info{display:flex;align-items:center;gap:8px}.user-name{color:#ffffffe6;font-weight:500;font-size:14px;text-decoration:none;cursor:pointer}.user-name:hover{color:#fff;text-decoration:underline}.header-icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast),color var(--duration-fast),border-color var(--duration-fast);flex-shrink:0}.header-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.dashboard-header .header-icon-btn,.dashboard-header .dark-mode-toggle,.dashboard-header .message-center-btn{background:#ffffff26;border-color:#ffffff40;color:#fff}.dashboard-header .header-icon-btn:hover,.dashboard-header .dark-mode-toggle:hover,.dashboard-header .message-center-btn:hover{background:#ffffff40;border-color:#fff6;color:#fff}.btn-sm{padding:7px 14px;font-size:13px;border-radius:var(--radius-sm)}.dashboard-main{padding-bottom:48px}.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px}@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:680px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;text-align:center;box-shadow:var(--shadow-sm);border:1.5px solid transparent;cursor:pointer;transition:transform var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal),background-color var(--duration-slow);-webkit-user-select:none;user-select:none;animation:staggerIn .4s var(--ease-smooth) both}.stat-card:nth-child(5){animation-delay:.24s}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-card:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.stat-card-success{border-color:#10b98140;background:linear-gradient(to bottom,var(--success-50),var(--bg-card))}.stat-card-warning{border-color:#f59e0b40;background:linear-gradient(to bottom,var(--warning-50),var(--bg-card))}.stat-card-danger{border-color:#ef444440;background:linear-gradient(to bottom,var(--error-50),var(--bg-card))}.stat-card-neutral{border-color:var(--border-color);background:linear-gradient(to bottom,var(--primary-50),var(--bg-card))}.stat-icon{font-size:28px;margin-bottom:8px}.stat-value{font-size:42px;font-weight:700;color:var(--primary-text);line-height:1;margin:8px 0;letter-spacing:-.02em}.stat-value-sm{font-size:34px;font-weight:700;color:var(--success-500)}.stat-label{font-size:11px;text-transform:uppercase;font-weight:700;color:var(--text-muted);letter-spacing:.06em;margin-bottom:6px}.stat-trend{font-size:13px;color:var(--text-muted);margin-top:4px}.stat-trend.up{color:var(--success-600)}.stat-trend.down{color:var(--error-600)}.stat-trend-link{color:var(--primary-text);text-decoration:underline}.stat-expiry-badges{display:flex;justify-content:center;gap:8px;margin:10px 0 6px;flex-wrap:wrap}.expiry-badge-sm{font-size:13px;font-weight:600;padding:3px 10px;border-radius:var(--radius-full)}.badge-expired{background:var(--error-100);color:var(--error-600)}.badge-critical{background:var(--warning-100);color:var(--warning-600)}.badge-warning{background:var(--secondary-50);color:var(--secondary-600)}.skeleton-card{min-height:120px;cursor:default;border-color:transparent!important;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:var(--bg-card)}.skeleton-center{margin:0 auto}.panel{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border-color);transition:background-color var(--duration-slow),box-shadow var(--duration-normal) var(--ease-smooth);animation:staggerIn .5s var(--ease-smooth) both;animation-delay:.2s}.panel:hover{box-shadow:var(--shadow-md)}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:8px}.panel-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}.panel-link{font-size:13px;font-weight:500;color:var(--primary-btn);text-decoration:none;letter-spacing:-.01em}.panel-footer-note{font-size:11px;color:var(--text-muted);text-align:center;padding:8px;border-top:1px solid var(--border-color)}.quick-actions-toolbar{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);padding:16px;margin-bottom:20px;transition:background-color var(--duration-slow);animation:staggerIn .4s var(--ease-smooth) both;animation-delay:50ms}.quick-actions-primary{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:12px}.action-card{border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#fff;cursor:pointer;transition:transform var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth);padding:16px 12px;gap:6px;animation:staggerIn .4s var(--ease-smooth) both;position:relative;overflow:hidden}.action-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 60%);pointer-events:none}.action-card:nth-child(1){animation-delay:.1s}.action-card:nth-child(2){animation-delay:.15s}.action-card:nth-child(3){animation-delay:.2s}.action-card:nth-child(4){animation-delay:.25s}.action-card:nth-child(5){animation-delay:.3s}.action-card:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #00000040}.action-card:active{transform:translateY(0) scale(.98)}.action-card .action-icon{transition:transform var(--duration-normal) var(--ease-smooth)}.action-card:hover .action-icon{transform:scale(1.15)}.action-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-700))}.action-secondary{background:linear-gradient(135deg,#6366f1,#4f46e5)}.action-success{background:linear-gradient(135deg,var(--success-500),var(--success-600))}.action-warning{background:linear-gradient(135deg,var(--secondary-400),var(--secondary-500))}.action-inventory{background:linear-gradient(135deg,#64748b,#475569)}.action-icon{font-size:28px;line-height:1}.action-label{font-size:12px;font-weight:700;text-align:center;line-height:1.2}@media(max-width:680px){.quick-actions-primary{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.quick-actions-primary{grid-template-columns:repeat(2,1fr)}}.quick-actions-links{display:flex;flex-wrap:wrap;gap:6px;padding-top:12px;border-top:1px solid var(--border-color)}.action-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full);background:var(--bg-elevated);text-decoration:none;color:var(--text-secondary);font-size:13px;font-weight:500;transition:background var(--duration-fast) var(--ease-smooth),color var(--duration-fast),transform var(--duration-fast) var(--ease-smooth);white-space:nowrap}.action-pill:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px)}.action-pill svg{transition:transform var(--duration-fast) var(--ease-smooth)}.action-pill:hover svg{transform:scale(1.1)}.action-pill-super{color:#7c3aed;font-weight:600}.activity-feed{max-height:500px;overflow-y:auto}.activity-item{display:flex;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border-color);transition:background var(--duration-fast) var(--ease-smooth);animation:staggerIn .3s var(--ease-smooth) both}.activity-item:nth-child(1){animation-delay:0ms}.activity-item:nth-child(2){animation-delay:30ms}.activity-item:nth-child(3){animation-delay:60ms}.activity-item:nth-child(4){animation-delay:90ms}.activity-item:nth-child(5){animation-delay:.12s}.activity-item:nth-child(6){animation-delay:.15s}.activity-item:nth-child(7){animation-delay:.18s}.activity-item:nth-child(8){animation-delay:.21s}.activity-item:hover{background:var(--bg-hover)}.activity-item:last-child{border-bottom:none}.activity-item--clickable{cursor:pointer}.activity-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center;margin-top:2px}.activity-content{flex:1;min-width:0}.activity-text{color:var(--text-primary);font-size:14px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.activity-meta{font-size:12px;color:var(--text-muted)}.activity-empty{padding:32px 20px;text-align:center;color:var(--text-muted);font-size:14px}.activity-more{padding:12px 20px;border-top:1px solid var(--border-color);text-align:center}.dashboard-main>.panel{margin-bottom:20px}.dashboard-full-row{margin-bottom:20px}.dashboard-charts-grid{display:grid;grid-template-columns:3fr 2fr;gap:20px;margin-bottom:20px;align-items:stretch}@media(max-width:768px){.dashboard-charts-grid{grid-template-columns:1fr}}.chart-container{padding:8px 16px 16px;height:220px;display:flex;align-items:center;justify-content:center}.chart-loading,.chart-no-data{color:var(--text-muted);font-size:14px;text-align:center;padding:40px}.chart-controls{display:flex;gap:4px;flex-wrap:wrap}.chart-legend{display:flex;gap:16px;justify-content:center;padding:4px 16px 8px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.legend-item-interactive{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity var(--duration-fast)}.legend-item-interactive:hover{opacity:.8}.legend-item-hidden{opacity:.4;text-decoration:line-through}.legend-dot{width:14px;height:3px;border-radius:2px;display:inline-block}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:10px 14px;font-family:inherit;font-size:13px}.chart-tooltip-label{font-weight:600;color:var(--text-primary);margin-bottom:6px}.chart-tooltip-row{display:flex;align-items:center;gap:6px;padding:2px 0}.chart-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chart-tooltip-name{color:var(--text-secondary);flex:1}.chart-tooltip-value{font-weight:700;color:var(--text-primary);margin-left:12px}.tab-toggle{display:flex;gap:4px}.tab-btn{padding:5px 12px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);font-size:12px;font-family:var(--font-family);font-weight:600;cursor:pointer;color:var(--text-muted);transition:all var(--duration-fast)}.tab-btn.active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.top-products-list{padding:12px 20px;display:flex;flex-direction:column;gap:12px;position:relative}.top-product-row{cursor:pointer;transition:opacity var(--duration-fast)}.top-product-row:hover .top-product-fill{filter:brightness(1.15)}.top-product-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;gap:8px}.top-product-name{font-size:13px;font-weight:500;color:var(--text-secondary);min-width:0}.top-product-count{font-size:13px;font-weight:700;color:var(--text-secondary);flex-shrink:0}.top-product-track{height:16px;background:var(--bg-elevated);border-radius:4px;overflow:hidden}.top-product-fill{height:100%;border-radius:4px;transition:width .6s var(--ease-smooth),filter var(--duration-fast);min-width:4px;background-image:linear-gradient(90deg,transparent,rgba(255,255,255,.15));background-size:100%}.dashboard-mid-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media(max-width:768px){.dashboard-mid-grid{grid-template-columns:1fr}}.health-body{display:flex;align-items:center;gap:24px;padding:20px}.health-gauge{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.health-svg{width:90px;height:90px}.health-arc{transition:stroke-dashoffset .6s ease}.health-label{font-size:13px;font-weight:700;margin-top:6px}.health-excellent{color:var(--success-600)}.health-good{color:var(--success-500)}.health-fair{color:var(--secondary-400)}.health-poor{color:var(--error-600)}.health-checks{flex:1;display:flex;flex-direction:column;gap:8px}.health-check-item{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500}.check-ok{color:var(--text-secondary)}.check-warn{color:var(--error-500)}.check-icon{font-size:14px;font-weight:700;flex-shrink:0}.supplier-breakdown-body{padding:16px 20px}.supplier-breakdown-content{display:flex;align-items:center;gap:16px}.supplier-breakdown-chart{flex-shrink:0;width:180px}.supplier-breakdown-legend{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.supplier-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.supplier-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.supplier-legend-name{flex:1;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.supplier-legend-pct{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}@media(max-width:480px){.supplier-breakdown-content{flex-direction:column}.supplier-breakdown-chart{width:140px}}.empty-state{text-align:center;padding:60px 20px;background:linear-gradient(180deg,var(--primary-50) 0%,var(--bg-card) 50%);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);margin-bottom:20px;animation:staggerIn .5s var(--ease-smooth) both}.empty-icon{font-size:56px;margin-bottom:16px;color:var(--primary-400);animation:floatBounce 3s ease-in-out infinite}@keyframes floatBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.empty-state h2{font-size:20px;color:var(--text-primary);margin-bottom:8px;font-weight:700}.empty-state p{color:var(--text-muted);margin-bottom:24px;font-size:15px}.dashboard-error{background:var(--error-50);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);padding:20px;text-align:center;color:var(--error-600);margin-bottom:20px}[data-theme=dark] .dashboard-header{background:linear-gradient(135deg,#0c4a6e,#0f172a 60%,#1e1b4b);box-shadow:0 4px 20px #0000004d}[data-theme=dark] .stat-card-success{background:linear-gradient(to bottom,rgba(16,185,129,.08),var(--bg-card))}[data-theme=dark] .stat-card-warning{background:linear-gradient(to bottom,rgba(245,158,11,.08),var(--bg-card))}[data-theme=dark] .stat-card-danger{background:linear-gradient(to bottom,rgba(239,68,68,.08),var(--bg-card))}[data-theme=dark] .stat-card-neutral{background:linear-gradient(to bottom,rgba(56,189,248,.06),var(--bg-card))}[data-theme=dark] .empty-state{background:linear-gradient(180deg,rgba(56,189,248,.06) 0%,var(--bg-card) 50%)}.recall-warning-banner{background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-md);padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px;color:#92400e;font-weight:600;font-size:15px;cursor:pointer;transition:background .15s}.recall-warning-banner:hover{background:#fde68a}[data-theme=dark] .recall-warning-banner{background:#fbbf241f;border-color:#fbbf244d;color:#fbbf24}[data-theme=dark] .recall-warning-banner:hover{background:#fbbf2433}.barcode-scanner{width:100%;max-width:500px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.scanner-container{position:relative;width:100%;aspect-ratio:3/4;background:#000;border-radius:var(--radius-md);overflow:hidden;touch-action:none}.scanner-video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.scanner-frame{position:relative;border-radius:12px;box-shadow:0 0 0 9999px #00000073;transition:border-color .2s,box-shadow .2s}.frame-s{width:38%;padding-top:38%}.frame-m{width:58%;padding-top:58%}.frame-l{width:78%;padding-top:78%}.frame-w{width:88%;padding-top:28%}.scanner-frame.scanning{box-shadow:0 0 0 9999px #00000073;animation:frame-pulse 2s ease-in-out infinite}.scanner-frame.success{box-shadow:0 0 0 9999px #00000073,0 0 0 3px var(--success-500);animation:frame-pop .35s ease-out}@keyframes frame-pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes frame-pop{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.corner{position:absolute;width:20px;height:20px;border:3px solid #fff;border-radius:3px}.corner-tl{top:-2px;left:-2px;border-right:none;border-bottom:none}.corner-tr{top:-2px;right:-2px;border-left:none;border-bottom:none}.corner-bl{bottom:-2px;left:-2px;border-right:none;border-top:none}.corner-br{bottom:-2px;right:-2px;border-left:none;border-top:none}.scanner-frame.success .corner{border-color:var(--success-500)}.scan-overlay-hint{position:absolute;bottom:14%;left:50%;transform:translate(-50%);white-space:nowrap;color:#fff;font-size:13px;font-weight:500;background:#0000008c;padding:5px 14px;border-radius:999px;pointer-events:none}.success-hint{background:#10b981bf}.torch-btn{position:absolute;top:12px;right:12px;width:44px;height:44px;border-radius:50%;border:none;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,box-shadow .2s;color:#fff}.torch-btn:hover{background:#000000bf}.torch-btn.active{background:#fbbf24;box-shadow:0 0 18px #fbbf24b3}.scanner-controls{display:flex;flex-direction:column;gap:10px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.zoom-section{display:flex;flex-direction:column;gap:8px}.zoom-presets{display:flex;gap:6px}.zoom-preset-btn{flex:1;padding:6px 0;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.zoom-preset-btn:hover{border-color:var(--primary-btn);color:var(--primary-btn)}.zoom-preset-btn.active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.zoom-slider-row{display:flex;align-items:center;gap:8px}.zoom-label{font-size:12px;color:var(--text-muted);white-space:nowrap;min-width:32px}.zoom-value{font-size:12px;color:var(--text-secondary);font-weight:600;min-width:32px;text-align:right}.zoom-slider{flex:1;-webkit-appearance:none;appearance:none;height:5px;border-radius:999px;background:var(--border-color);outline:none;cursor:pointer}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-btn);box-shadow:0 1px 6px #0003;cursor:pointer}.zoom-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-btn);border:none;cursor:pointer}.frame-size-section{display:flex;align-items:center;gap:6px}.frame-size-label{font-size:12px;color:var(--text-muted);margin-right:2px}.frame-size-btn{width:36px;height:28px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.frame-size-btn:hover{border-color:var(--primary-btn);color:var(--primary-btn)}.frame-size-btn.active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.scanner-tips{padding:14px 16px;background:var(--warning-50);border:1px solid var(--warning-100);border-radius:var(--radius-md);font-size:13px}.tips-title{font-weight:700;color:var(--warning-600);margin-bottom:8px}.tips-list{margin:0 0 10px 16px;padding:0;color:var(--text-secondary);line-height:1.8}.scanner-error{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.scanner-error p{color:var(--error-500);font-size:14px}.supplier-selector{position:relative}.supplier-selector-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);font-size:14px;cursor:pointer}.supplier-selector-input:focus{outline:none;border-color:var(--primary-btn)}.supplier-selector-input::placeholder{color:var(--text-muted)}.supplier-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);max-height:240px;overflow-y:auto;margin-top:4px}.supplier-dropdown-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:2px}.supplier-dropdown-item:last-child{border-bottom:none}.supplier-dropdown-item:hover{background:var(--bg-elevated)}.supplier-dropdown-item.selected{background:var(--bg-elevated);font-weight:600}.supplier-dropdown-name{font-size:14px;color:var(--text-primary)}.supplier-dropdown-vat{font-size:12px;color:var(--text-muted);font-family:monospace}.supplier-dropdown-add{padding:10px 12px;cursor:pointer;color:var(--primary-btn);font-weight:600;font-size:14px;display:flex;align-items:center;gap:6px;border-top:1px solid var(--border-color)}.supplier-dropdown-add:hover{background:var(--bg-elevated)}.supplier-dropdown-empty{padding:10px 12px;color:var(--text-muted);font-size:13px;text-align:center}.supplier-selected{display:flex;align-items:center;gap:8px}.supplier-selected-name{flex:1;font-size:14px;color:var(--text-primary)}.supplier-clear-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center}.supplier-clear-btn:hover{color:var(--text-primary)}.supplier-inline-form .form-group{margin-bottom:12px}.animated-checkmark{position:relative;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.animated-checkmark--success .checkmark-circle,.animated-checkmark--success .checkmark-check{stroke:var(--success-500)}.animated-checkmark--primary .checkmark-circle,.animated-checkmark--primary .checkmark-check{stroke:var(--primary-500)}.checkmark-circle{animation:checkmarkCircle .6s cubic-bezier(.65,0,.45,1) forwards;animation-delay:.1s;transform-origin:center}.checkmark-check{animation:checkmarkStroke .4s cubic-bezier(.65,0,.45,1) forwards;animation-delay:.5s}.checkmark-ring{position:absolute;inset:-6px;border-radius:50%;border:2px solid transparent;animation:checkmarkRing .8s cubic-bezier(.65,0,.45,1) forwards;animation-delay:.6s}.animated-checkmark--success .checkmark-ring{border-color:#10b98126}.animated-checkmark--primary .checkmark-ring{border-color:#0ea5e926}@keyframes checkmarkCircle{0%{stroke-dashoffset:200;opacity:0}30%{opacity:1}to{stroke-dashoffset:0}}@keyframes checkmarkStroke{0%{stroke-dashoffset:60}to{stroke-dashoffset:0}}@keyframes checkmarkRing{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.15);opacity:.6}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.checkmark-circle,.checkmark-check,.checkmark-ring{animation:none;stroke-dashoffset:0;opacity:1}}.confetti-burst{position:absolute;top:50%;left:50%;width:0;height:0;pointer-events:none;z-index:10}.confetti-particle{position:absolute;animation:confettiFly 1s cubic-bezier(.25,.46,.45,.94) forwards;animation-delay:var(--delay);opacity:0}.confetti-circle{width:8px;height:8px;border-radius:50%}.confetti-square{width:7px;height:7px;border-radius:1px}.confetti-triangle{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:8px solid;background:transparent!important}@keyframes confettiFly{0%{transform:translate(0) rotate(0) scale(0);opacity:1}20%{opacity:1;transform:translate(calc(var(--dx) * .3),calc(var(--dy) * .3)) rotate(calc(var(--rotation) * .4)) scale(var(--scale))}to{transform:translate(var(--dx),calc(var(--dy) + 60px)) rotate(var(--rotation)) scale(0);opacity:0}}@media(prefers-reduced-motion:reduce){.confetti-particle{animation:none;display:none}}.inspection-form h2{margin:0 0 20px;font-size:18px;font-weight:600;color:var(--text-primary)}.inspection-group{margin-bottom:20px}.inspection-group-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.inspection-check-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0}.inspection-check-item+.inspection-check-item{border-top:1px solid var(--border-color, #f0f0f0)}.inspection-check-btn{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-md, 8px);border:2px solid var(--border-color);background:var(--bg-card);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.inspection-check-btn.check-yes{background:#dcfce7;border-color:#22c55e;color:#16a34a}.inspection-check-btn.check-no{background:#fee2e2;border-color:#ef4444;color:#dc2626}.inspection-check-btn.check-na{background:var(--bg-elevated, #f5f5f5);border-color:var(--border-color);color:var(--text-muted);font-size:11px;font-weight:600}.inspection-check-content{flex:1;min-width:0}.inspection-check-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4}.inspection-optional{font-weight:400;color:var(--text-muted);font-size:12px}.inspection-check-hint{display:block;font-size:12px;color:var(--text-muted);margin-top:2px;line-height:1.4}.inspection-notes{margin-top:20px}.inspection-notes-label{display:block;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.inspection-notes textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:inherit}.inspection-warning{margin-top:16px;padding:12px 16px;background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-md, 8px);color:#92400e;font-size:13px}[data-theme=dark] .inspection-warning{background:#78350f;border-color:#b45309;color:#fde68a}.inspection-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.inspection-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.inspection-modal{background:var(--bg-card);border-radius:var(--radius-lg, 12px);padding:24px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg, 0 20px 60px rgba(0, 0, 0, .2))}.inspection-summary{margin-top:20px}.inspection-summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.inspection-summary-header h3{margin:0;font-size:15px;color:var(--text-secondary)}.inspection-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.inspection-status-badge.status-passed{background:#dcfce7;color:#16a34a}.inspection-status-badge.status-issues{background:#fee2e2;color:#dc2626}[data-theme=dark] .inspection-status-badge.status-passed{background:#14532d;color:#86efac}[data-theme=dark] .inspection-status-badge.status-issues{background:#7f1d1d;color:#fca5a5}.inspection-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.inspection-summary-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 0}.inspection-summary-item .check-icon{font-size:16px}.inspection-summary-item .check-icon.passed{color:#22c55e}.inspection-summary-item .check-icon.failed{color:#ef4444}.inspection-summary-item .check-icon.na{color:var(--text-muted)}.inspection-summary-meta{margin-top:12px;font-size:12px;color:var(--text-muted)}.inspection-summary-notes{margin-top:8px;padding:10px 12px;background:var(--bg-elevated, #f5f5f5);border-radius:var(--radius-md, 8px);font-size:13px;color:var(--text-secondary)}.inspection-pending{margin-top:20px;padding:16px;border:1px dashed var(--border-color);border-radius:var(--radius-md, 8px);text-align:center}.inspection-pending.overdue{border-color:#f59e0b;background:#fffbeb}[data-theme=dark] .inspection-pending.overdue{background:#78350f33;border-color:#b45309}.inspection-pending p{margin:0 0 12px;font-size:14px;color:var(--text-secondary)}@media(max-width:480px){.inspection-summary-grid{grid-template-columns:1fr}.inspection-modal{padding:16px}}.page{min-height:100vh;background:var(--bg-page)}.container--narrow{max-width:640px}.page-header{background:var(--bg-card);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border-color);padding:18px 0;margin-bottom:24px;transition:background-color var(--duration-slow);animation:slideUp .3s var(--ease-smooth)}.back-link{color:var(--primary-text);text-decoration:none;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:4px;margin-bottom:8px;transition:color var(--duration-fast)}.back-link:hover{color:var(--primary-text-hover)}.page-header h1{font-size:22px;color:var(--text-primary);font-weight:700;letter-spacing:-.025em}.text-muted{color:var(--text-muted);font-size:14px}.mb-20{margin-bottom:20px}.form-hint{display:block;margin-top:4px;color:var(--text-muted);font-size:13px}.input-disabled{background:var(--bg-elevated)!important;cursor:not-allowed;color:var(--text-disabled)!important}.button-group{display:flex;gap:12px;margin-top:24px}.success-card{text-align:center;padding:40px 24px;animation:scalePop var(--duration-slow) var(--ease-smooth);background:linear-gradient(180deg,var(--success-50) 0%,var(--bg-card) 40%)}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--success-500),var(--success-600));color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto 24px;box-shadow:0 8px 24px #10b9814d,0 0 0 6px #10b9811a;animation:successPulse 2s ease-in-out infinite}@keyframes successPulse{0%,to{box-shadow:0 8px 24px #10b9814d,0 0 0 6px #10b9811a}50%{box-shadow:0 8px 24px #10b98166,0 0 0 12px #10b9810d}}.item-number-display{margin:28px 0;padding:20px;background:var(--secondary-50);border-radius:var(--radius-md);border:1.5px solid rgba(245,158,11,.3)}.item-number-display p{margin-bottom:10px;color:var(--secondary-600);font-weight:600}.item-number{font-size:56px;font-weight:700;color:var(--secondary-600);letter-spacing:-.02em}.success-details{margin:20px 0;text-align:left;background:var(--bg-elevated);padding:16px 20px;border-radius:var(--radius-sm)}.success-details p{margin-bottom:6px;color:var(--text-secondary);font-size:14px;font-weight:500}.success-details p:last-child{margin-bottom:0}.auto-depletion-section{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;margin-bottom:20px;background:var(--bg-elevated)}.auto-depletion-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:600;font-size:14px;color:var(--text-primary)}.auto-depletion-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-btn)}.auto-depletion-fields{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.number-input-row{display:flex;align-items:center;gap:8px}.number-input-row .number-input-short{width:80px;flex:0 0 80px;padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-card);color:var(--text-primary);text-align:center}.input-unit{font-size:14px;color:var(--text-secondary)}.input-range-hint{font-size:12px;color:var(--text-muted);margin-left:4px}.auto-depletion-hint{font-size:13px;color:var(--text-muted);background:var(--bg-page);border-radius:var(--radius-sm);padding:10px 12px;margin-top:4px;margin-bottom:0;line-height:1.5}.product-picker{border:1.5px solid var(--warning-500);border-radius:var(--radius-md);padding:16px;margin-bottom:20px;background:var(--bg-elevated)}.product-picker-header{margin-bottom:12px}.product-picker-warning{font-weight:600;color:var(--warning-600);font-size:14px;margin-bottom:4px}.product-picker-search{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-card);color:var(--text-primary);margin-bottom:8px}.product-picker-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.product-picker-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;text-align:left;transition:border-color var(--duration-fast),background var(--duration-fast)}.product-picker-item:hover{border-color:var(--primary-btn);background:var(--primary-50, rgba(59, 130, 246, .05))}.product-picker-name{font-weight:600;font-size:14px;color:var(--text-primary)}.product-picker-mfr{font-size:12px;color:var(--text-muted)}.product-picker-create-btn{width:100%;font-size:13px}.supply-stepper{display:flex;align-items:center;gap:16px;margin:24px 0}.stepper-btn{padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-family:var(--font-family);color:var(--text-primary);transition:all var(--duration-normal) var(--ease-smooth)}.stepper-btn:hover:not(:disabled){background:var(--border-color)}.stepper-btn:disabled{opacity:.5;cursor:not-allowed}.supply-card-display{flex:1;background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:24px;text-align:center;transition:background-color var(--duration-slow)}.supply-number-large{font-size:48px;font-weight:700;color:var(--primary-text);margin-bottom:16px}.supply-details p{margin-bottom:8px;color:var(--text-primary)}.supply-details p:last-child{margin-bottom:0}.supply-indicator{display:flex;justify-content:center;gap:8px;margin:16px 0}.indicator-dot{width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:all var(--duration-normal) var(--ease-smooth)}.indicator-dot.active{background:var(--primary-btn);width:24px;border-radius:4px}.text-center{text-align:center}.export-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.export-modal{background:var(--bg-card);border-radius:var(--radius-md);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);transition:background-color var(--duration-slow)}.export-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.export-header h2{margin:0;font-size:20px;color:var(--text-primary)}.export-close{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;line-height:1}.export-close:hover{background:var(--bg-elevated)}.export-body{padding:24px}.export-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end}.date-range{display:flex;align-items:center;gap:10px}.date-range input{flex:1}.date-range span{color:var(--text-secondary);white-space:nowrap}.format-options{display:flex;flex-direction:column;gap:10px}.radio-option{display:flex;align-items:flex-start;gap:10px;padding:12px;border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;position:relative}.radio-option:hover{background:var(--bg-elevated);border-color:var(--primary-btn)}.radio-option:has(input:checked){border-color:var(--primary-btn);background:var(--bg-elevated)}.radio-option input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.radio-option span{font-weight:500;color:var(--text-primary)}.help-text{display:block;margin-top:4px;font-size:12px;color:var(--text-secondary)}.column-select-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.column-select-header .btn-link{background:none;border:none;color:var(--primary-btn);cursor:pointer;font-size:13px;padding:0;font-weight:500}.column-select-header .btn-link:hover{text-decoration:underline}.column-count{font-size:12px;color:var(--text-muted)}.column-checkboxes{display:grid;grid-template-columns:1fr 1fr;padding:8px 0;border:1px solid var(--border-color);border-radius:var(--radius-sm);max-height:220px;overflow-y:auto}.checkbox-option{display:flex;align-items:center;gap:10px;padding:6px 12px;cursor:pointer;font-size:13px;color:var(--text-primary)}.checkbox-option:hover{background:var(--bg-elevated)}.checkbox-option input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.checkbox-icon{width:18px;height:18px;flex-shrink:0;border:2px solid var(--text-muted);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.checkbox-option input:checked+.checkbox-icon{background:var(--primary-btn);border-color:var(--primary-btn)}.checkbox-icon svg{display:none}.checkbox-option input:checked+.checkbox-icon svg{display:block}.export-success{text-align:center;padding:40px 20px;font-size:18px;color:var(--success-600)}.export-error{margin-top:16px;padding:12px;background:var(--error-50);border:1px solid var(--error-100);border-radius:var(--radius-sm);color:var(--error-600);font-size:14px}@media(max-width:480px){.date-range{flex-direction:column;align-items:stretch}.date-range span{text-align:center}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;text-align:center;box-shadow:var(--shadow-sm);border-left:4px solid var(--border-color);transition:background-color var(--duration-slow),box-shadow var(--duration-normal);animation:staggerIn .3s var(--ease-smooth) both}.stat-card:nth-child(1){animation-delay:0ms}.stat-card:nth-child(2){animation-delay:60ms}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:nth-child(4){animation-delay:.18s}.stat-card.stat-green{border-left-color:var(--success-500)}.stat-card.stat-yellow{border-left-color:var(--secondary-400)}.stat-card.stat-gray{border-left-color:var(--text-muted)}.stat-card.stat-red{border-left-color:var(--error-500)}.stat-card--clickable{cursor:pointer;transition:background-color var(--duration-slow),transform .1s,box-shadow .1s}.stat-card--clickable:hover{background:var(--bg-elevated);box-shadow:var(--shadow-md, 0 4px 12px rgba(0,0,0,.1));transform:translateY(-1px)}.stat-card--active{outline:2px solid var(--primary-btn);outline-offset:-2px}.stat-value{font-size:34px;font-weight:700;color:var(--text-primary);margin-bottom:6px;letter-spacing:-.02em}.stat-label{font-size:13px;color:var(--text-muted);font-weight:600}.search-filter-bar{display:flex;gap:12px;align-items:center;margin-bottom:12px}.search-wrapper{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;pointer-events:none;font-size:14px;color:var(--text-muted)}.search-input-full{width:100%;padding:10px 36px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.search-input-full:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e914}.search-input-full:focus+.search-icon,.search-wrapper:focus-within .search-icon{color:var(--primary-text);transition:color var(--duration-fast)}.search-input-full::placeholder{color:var(--text-disabled)}.search-clear{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-muted);line-height:1;padding:0}.search-clear:hover{color:var(--text-primary)}.filter-button-wrapper{position:relative;flex-shrink:0}.filter-toggle-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;font-size:14px;font-family:var(--font-family);font-weight:500;color:var(--text-secondary);white-space:nowrap;transition:border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast)}.filter-toggle-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.filter-toggle-btn--active{border-color:var(--primary-btn);color:var(--primary-text);background:var(--primary-bg)}.filter-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--primary-btn);color:#fff;font-size:11px;font-weight:700}.filter-panel-desktop{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:16px;z-index:50;animation:slideUp var(--duration-fast) var(--ease-smooth)}.filter-section{margin-bottom:16px}.filter-section:last-of-type{margin-bottom:0}.filter-label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.status-chips{display:flex;flex-wrap:wrap;gap:6px}.status-chip{padding:5px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-card);cursor:pointer;font-size:13px;font-family:var(--font-family);font-weight:500;color:var(--text-secondary);transition:border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast)}.status-chip:hover{border-color:var(--border-hover);color:var(--text-primary)}.status-chip--active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.date-range-inputs{display:flex;flex-direction:column;gap:8px}.date-range-row{display:flex;align-items:center;gap:10px}.date-range-label{font-size:13px;color:var(--text-muted);font-weight:500;width:32px;flex-shrink:0}.date-input{flex:1;padding:8px 10px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);outline:none;min-width:0}.date-input:focus{border-color:var(--border-focus)}.sort-row{display:flex;gap:8px}.sort-select{flex:1;padding:8px 10px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);outline:none;min-width:0}.sort-select:focus{border-color:var(--border-focus)}.sort-order-btn{padding:8px 12px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;font-size:13px;font-family:var(--font-family);color:var(--text-secondary);white-space:nowrap;flex-shrink:0;transition:border-color var(--duration-fast),background var(--duration-fast)}.sort-order-btn:hover{border-color:var(--border-hover);background:var(--bg-hover)}.filter-clear-all{display:block;background:none;border:none;color:var(--error-500);cursor:pointer;font-size:13px;font-family:var(--font-family);padding:0;margin-top:12px;text-decoration:underline}.active-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.filter-chip{display:inline-flex;align-items:center;gap:6px;background:var(--primary-bg);color:var(--primary-text);border:1px solid var(--primary-border);border-radius:var(--radius-full);padding:4px 10px 4px 12px;font-size:13px;font-weight:500}.filter-chip button{background:none;border:none;cursor:pointer;color:var(--primary-text);font-size:15px;padding:0;line-height:1;opacity:.7}.filter-chip button:hover{opacity:1}.clear-all-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font-family);text-decoration:underline;padding:0}.clear-all-link:hover{color:var(--text-secondary)}.result-count{font-size:14px;color:var(--text-muted);margin-bottom:12px;font-weight:500}.result-filtered{color:var(--text-disabled)}.inventory-list{display:flex;flex-direction:column;gap:20px}.product-group{overflow:hidden;animation:staggerIn .4s var(--ease-smooth) both}.product-group:nth-child(1){animation-delay:0ms}.product-group:nth-child(2){animation-delay:80ms}.product-group:nth-child(3){animation-delay:.16s}.product-group:nth-child(4){animation-delay:.24s}.product-group:nth-child(5){animation-delay:.32s}.product-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.product-header h3{font-size:17px;color:var(--text-primary);font-weight:700}.product-count{font-size:13px;color:var(--text-muted);background:var(--bg-elevated);padding:4px 12px;border-radius:var(--radius-full);font-weight:600}.supply-table{overflow-x:auto}.supply-table table{width:100%;border-collapse:collapse}.supply-table th{text-align:left;padding:10px 12px;background:var(--bg-elevated);color:var(--text-muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color)}.supply-table td{padding:11px 12px;border-top:1px solid var(--border-color);font-size:14px;color:var(--text-primary);transition:background var(--duration-fast) var(--ease-smooth)}.supply-table tbody tr:nth-child(2n) td{background:var(--bg-elevated)}.supply-table tbody tr:hover td{background:var(--primary-bg)}.supply-table tbody tr{animation:staggerIn .3s var(--ease-smooth) both}.supply-table tbody tr:nth-child(1){animation-delay:0ms}.supply-table tbody tr:nth-child(2){animation-delay:30ms}.supply-table tbody tr:nth-child(3){animation-delay:60ms}.supply-table tbody tr:nth-child(4){animation-delay:90ms}.supply-table tbody tr:nth-child(5){animation-delay:.12s}.supply-table tbody tr:nth-child(6){animation-delay:.15s}.supply-table tbody tr:nth-child(7){animation-delay:.18s}.supply-table tbody tr:nth-child(8){animation-delay:.21s}.supply-table tbody tr:nth-child(9){animation-delay:.24s}.supply-table tbody tr:nth-child(10){animation-delay:.27s}.item-number{font-weight:700;color:var(--primary-text)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;transition:transform var(--duration-fast),box-shadow var(--duration-fast)}.badge:hover{transform:scale(1.05)}.badge-green{background:var(--success-100);color:var(--success-600);box-shadow:0 1px 4px #10b98126}.badge-yellow{background:var(--secondary-50);color:var(--secondary-600);box-shadow:0 1px 4px #f59e0b26}.badge-gray{background:var(--bg-elevated);color:var(--text-muted)}.badge-red{background:var(--error-100, #fee2e2);color:var(--error-600, #dc2626);box-shadow:0 1px 4px #ef444426}.badge-orange{background:var(--warning-100, #fff7ed);color:var(--warning-600, #ea580c);box-shadow:0 1px 4px #f9731626}.pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 0 8px;margin-top:4px}.pagination-btn{padding:8px 18px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;font-size:14px;font-family:var(--font-family);font-weight:500;color:var(--text-secondary);transition:border-color var(--duration-fast),background var(--duration-fast)}.pagination-btn:hover:not(:disabled){border-color:var(--border-hover);background:var(--bg-hover);color:var(--text-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:14px;color:var(--text-muted);font-weight:500}.header-content{display:flex;justify-content:space-between;align-items:center;gap:16px}.header-content h1{margin:0}.btn-action{padding:4px 12px;border:none;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-family);font-weight:600;cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth),transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast)}.btn-action:hover{transform:translateY(-1px)}.btn-action:active{transform:translateY(0) scale(.96)}.btn-open{background:var(--primary-bg);color:var(--primary-text)}.btn-open:hover{background:var(--primary-bg-hover)}.btn-deplete{background:var(--error-100);color:var(--error-600)}.btn-deplete:hover{background:#ef444433}.btn-edit{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-edit:hover{background:var(--border-color);color:var(--text-primary)}.btn-delete-icon{background:none;color:var(--text-muted);border:1px solid transparent;padding:4px 6px;display:inline-flex;align-items:center}.btn-delete-icon:hover{color:var(--error-500);background:var(--error-50, #fef2f2)}.by-name{font-size:11px;color:var(--text-muted);margin-top:2px}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn var(--duration-fast) var(--ease-smooth)}.modal{background:var(--bg-card);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:420px;box-shadow:0 25px 60px #0000004d;animation:modalIn .3s var(--ease-smooth);border:1px solid var(--border-color)}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h3{font-size:20px;color:var(--text-primary);margin-bottom:16px;font-weight:700;letter-spacing:-.02em}.modal-details{background:var(--bg-elevated);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:16px}.modal-details p{font-size:14px;color:var(--text-secondary);margin-bottom:4px;font-weight:500}.modal-details p:last-child{margin-bottom:0}.modal-actions{display:flex;gap:12px;margin-top:20px}.modal-actions .btn{flex:1}.filter-overlay{position:fixed;inset:0;z-index:200;background:#0006}.filter-overlay-panel{position:absolute;inset:0;background:var(--bg-card);display:flex;flex-direction:column}.filter-overlay-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.filter-overlay-header h2{font-size:20px;margin:0;color:var(--text-primary);font-weight:700}.filter-overlay-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-muted);line-height:1;padding:0}.filter-overlay-content{flex:1;overflow-y:auto;padding:20px}.filter-overlay-footer{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;gap:12px;flex-shrink:0}.filter-overlay-footer .btn{flex:1}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.supply-table{font-size:12px}.supply-table th,.supply-table td{padding:8px}.filter-toggle-btn{padding:10px 14px}}.expiry-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:12px;font-weight:600;white-space:nowrap}.expiry-expired{background:var(--error-100);color:var(--error-600);box-shadow:0 1px 4px #ef444426;animation:pulse 2s ease-in-out infinite}.expiry-critical{background:var(--warning-100);color:var(--warning-600);box-shadow:0 1px 4px #f9731626}.expiry-warning{background:var(--secondary-50);color:var(--secondary-600);box-shadow:0 1px 4px #f59e0b1a}.expiry-good{background:var(--success-100);color:var(--success-600);box-shadow:0 1px 4px #10b9811a}.low-stock-badge{background:var(--secondary-50);color:var(--secondary-600)}.cost-cell{white-space:nowrap}.cost-value{font-variant-numeric:tabular-nums;font-weight:500;color:var(--text-primary)}.expiring-controls{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.expiring-threshold-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary)}.expiring-threshold-select{border:1px solid var(--border-color);border-radius:6px;padding:6px 10px;font-size:14px;font-family:var(--font-family);background:var(--bg-input);cursor:pointer}.expiring-section{margin-bottom:24px}.expiring-section-title{font-size:16px;font-weight:600;padding:10px 16px;border-radius:var(--radius-sm);margin-bottom:8px}.expiring-section-title--expired{background:var(--error-50);color:var(--error-600)}.expiring-section-title--critical{background:var(--warning-50);color:var(--warning-600)}.expiring-section-title--warning{background:var(--secondary-50);color:var(--secondary-500)}.expiring-item{background:var(--bg-card);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:8px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;box-shadow:0 1px 2px #0000000d;border-left:4px solid transparent;transition:background-color var(--duration-slow)}.expiring-item--expired{border-left-color:var(--error-600);background:var(--error-50)}.expiring-item--critical{border-left-color:var(--warning-600);background:var(--warning-50)}.expiring-item--warning{border-left-color:var(--secondary-400);background:var(--secondary-50)}.expiring-item-main{flex:1;min-width:0}.expiring-item-product{font-weight:600;font-size:15px;color:var(--text-primary);margin-bottom:4px}.expiring-item-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-secondary);margin-bottom:4px}.expiring-item-date{font-size:13px;color:var(--text-primary);font-weight:500}.expiring-item-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.expiry-edit-inline{display:flex;flex-direction:column;gap:6px}.expiry-edit-input{border:1px solid var(--border-color);border-radius:6px;padding:6px 10px;font-size:13px;font-family:var(--font-family);background:var(--bg-input)}.btn-sm{padding:5px 12px;font-size:12px}.status-badge{display:inline-block;padding:1px 6px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;text-transform:capitalize}.status-purchased{background:var(--success-100);color:var(--success-600)}.status-opened{background:var(--secondary-50);color:var(--secondary-500)}@media(max-width:600px){.expiring-item{flex-direction:column}.expiring-item-actions{flex-direction:row;flex-wrap:wrap}}.barcode-test-page{min-height:100vh;padding:40px 20px;background:var(--bg-page)}.barcode-test-page h1{margin-bottom:8px}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-top:16px}.example-btn{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:16px;text-align:left;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.example-btn:hover{background:var(--bg-hover);border-color:var(--primary-btn)}.example-btn strong{display:block;margin-bottom:4px;color:var(--text-primary)}.example-btn small{color:var(--text-secondary);font-size:12px}.test-input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:monospace;font-size:14px;background:var(--bg-input);color:var(--text-primary);margin-bottom:16px;resize:vertical}.test-input:focus{outline:none;border-color:var(--primary-btn)}.parse-result{background:var(--bg-elevated);border-radius:var(--radius-sm);padding:16px;margin-top:16px;transition:background-color var(--duration-slow)}.parse-result.success{border-left:4px solid var(--success-500)}.parse-result.simple{border-left:4px solid var(--text-secondary)}.result-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.result-row:last-child{border-bottom:none}.result-row.highlight{background:var(--success-100);padding:12px;border-radius:4px;margin:4px 0}.result-row strong{color:var(--text-primary);flex-shrink:0;margin-right:16px}.result-row span{color:var(--text-primary);font-weight:500}.result-row code{background:var(--text-primary);color:var(--success-500);padding:4px 8px;border-radius:4px;font-size:12px;word-break:break-all}.profile-page{max-width:620px;margin:0 auto;padding:24px 16px}.profile-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:background-color var(--duration-slow),box-shadow var(--duration-normal);animation:staggerIn .4s var(--ease-smooth) both}.profile-section:nth-child(1){animation-delay:0ms}.profile-section:nth-child(2){animation-delay:80ms}.profile-section:nth-child(3){animation-delay:.16s}.profile-section:nth-child(4){animation-delay:.24s}.profile-section:nth-child(5){animation-delay:.32s}.profile-section h2{font-size:17px;color:var(--text-primary);margin-bottom:20px;font-weight:700;letter-spacing:-.01em}.profile-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.profile-section-header h2{margin-bottom:0}.profile-field{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-color)}.profile-field:last-child{border-bottom:none}.profile-label{font-size:14px;color:var(--text-muted);font-weight:600}.profile-value{font-size:14px;color:var(--text-primary);font-weight:500}.profile-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.profile-stat{text-align:center;padding:16px 8px;background:var(--bg-elevated);border-radius:var(--radius-sm);transition:transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast)}.profile-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.profile-stat-value{font-size:26px;font-weight:700;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.02em}.profile-stat-label{font-size:12px;color:var(--text-muted);font-weight:600}.button-group{display:flex;gap:12px;margin-top:16px}.button-group .btn{flex:1}.language-options{display:flex;flex-wrap:wrap;gap:8px}.language-btn{padding:7px 16px;border:1.5px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-card);cursor:pointer;font-size:14px;font-family:var(--font-family);font-weight:500;color:var(--text-secondary);transition:border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast)}.language-btn:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary)}.language-btn--active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.language-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.profile-stats-grid{grid-template-columns:repeat(2,1fr)}.profile-field{flex-direction:column;align-items:flex-start;gap:4px}}.admin-page{padding:24px 16px}.admin-tabs{display:flex;gap:4px;background:var(--bg-elevated);border-radius:10px;padding:4px;margin-bottom:20px;overflow-x:auto}.admin-tab{flex:1;padding:8px 16px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:14px;font-family:var(--font-family);font-weight:500;cursor:pointer;white-space:nowrap;transition:all var(--duration-fast) var(--ease-smooth)}.admin-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.admin-toolbar{display:flex;align-items:center;gap:16px;margin-bottom:16px}.admin-search{flex:1;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);background:var(--bg-input);color:var(--text-primary)}.admin-search:focus{outline:none;border-color:var(--primary-btn)}.admin-total{font-size:14px;color:var(--text-secondary);white-space:nowrap}.admin-table-wrap{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:16px;overflow-x:auto;transition:background-color var(--duration-slow)}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:left;padding:12px;background:var(--bg-elevated);color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.admin-table td{padding:10px 12px;border-top:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.admin-id{color:var(--text-muted);font-size:12px}.admin-actions{display:flex;gap:6px;white-space:nowrap}.btn-edit{background:var(--primary-bg-hover);color:var(--primary-text-hover)}.btn-edit:hover{background:var(--primary-border)}.btn-delete{background:var(--error-100);color:var(--error-600)}.btn-delete:hover{background:var(--error-50)}.btn-delete-confirm{background:var(--error-600);color:#fff}.btn-delete-confirm:hover{background:var(--error-500)}.btn-cancel-delete{background:var(--bg-elevated);color:var(--text-primary)}.btn-cancel-delete:hover{background:var(--border-color)}.admin-self-label{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;background:var(--bg-elevated);color:var(--text-muted)}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 0}.admin-page-info{font-size:14px;color:var(--text-secondary)}.admin-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;z-index:100;padding:40px 20px;overflow-y:auto}.admin-modal{background:var(--bg-card);border-radius:var(--radius-xl, 12px);padding:28px;width:100%;max-width:480px;box-shadow:0 25px 60px #0000004d;border:1px solid var(--border-color);margin:auto 0}.admin-modal-id{font-size:13px;color:var(--text-muted);margin-bottom:16px}.badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-md);font-size:12px;font-weight:500}.badge-green{background:var(--success-100);color:var(--success-600)}.badge-yellow{background:var(--secondary-50);color:var(--secondary-500)}.badge-gray{background:var(--bg-elevated);color:var(--text-secondary)}@media(max-width:640px){.admin-tabs{flex-wrap:wrap}.admin-tab{flex:none}}.team-page{max-width:900px;margin:0 auto;padding:24px 16px}.invite-link-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:28px 32px;border-radius:var(--radius-md);margin-bottom:28px}.invite-link-label{font-size:13px;opacity:.85;margin-bottom:10px;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.invite-link-display{background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);padding:10px 14px;font-family:Courier New,monospace;font-size:13px;word-break:break-all;margin-bottom:10px}.invite-link-hint{font-size:13px;opacity:.85;margin-bottom:18px}.expiry-tag{opacity:.75;font-style:italic}.link-actions{display:flex;gap:10px;flex-wrap:wrap}.btn-invite-action{border:2px solid rgba(255,255,255,.4);padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-family);font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth)}.btn-copy{background:#fff3;color:#fff}.btn-copy:hover{background:#ffffff4d}.btn-share{background:transparent;color:#fff}.btn-share:hover{background:#ffffff26}.btn-regenerate{background:#ef444440;color:#fff;border-color:#ef444480;margin-left:auto}.btn-regenerate:hover:not(:disabled){background:#ef444466}.btn-regenerate:disabled{opacity:.5;cursor:not-allowed}.team-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.team-section h2{font-size:18px;color:var(--text-primary);margin-bottom:0}.username-tag{font-family:Courier New,monospace;font-size:13px;background:var(--bg-elevated);padding:1px 6px;border-radius:4px;color:var(--text-primary)}.btn-reset{background:var(--secondary-50);color:var(--secondary-500)}.btn-reset:hover{background:var(--secondary-100)}.credentials-box{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:14px 16px;display:flex;flex-direction:column;gap:8px;font-size:14px;margin-bottom:16px;transition:background-color var(--duration-slow)}.credentials-box span{color:var(--text-secondary);margin-right:4px}.temp-password{font-family:Courier New,monospace;font-size:16px;letter-spacing:.05em;color:var(--text-primary)}.team-table{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;overflow-x:auto;transition:background-color var(--duration-slow)}.team-table table{width:100%;border-collapse:collapse}.team-table th{text-align:left;padding:12px 16px;background:var(--bg-elevated);color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.team-table td{padding:14px 16px;border-top:1px solid var(--border-color);font-size:14px;color:var(--text-primary)}.email-cell{color:var(--text-secondary);font-size:13px}.inactive-row td{opacity:.5}.role-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-md);font-size:12px;font-weight:500;text-transform:capitalize}.role-badge.admin{background:var(--primary-bg-hover);color:var(--primary-text-hover)}.role-badge.staff{background:var(--primary-bg);color:var(--primary-text)}.status-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-md);font-size:12px;font-weight:500}.status-badge.active{background:var(--success-100);color:var(--success-600)}.status-badge.inactive{background:var(--error-100);color:var(--error-600)}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.btn-deactivate{background:var(--error-100);color:var(--error-600)}.btn-deactivate:hover{background:var(--error-50)}.btn-activate{background:var(--success-100);color:var(--success-600)}.btn-activate:hover{background:var(--success-50)}.role-options{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.role-option{display:flex;align-items:flex-start;gap:12px;padding:16px;border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth)}.role-option:hover{border-color:var(--primary-btn);background:var(--bg-elevated)}.role-option.selected{border-color:var(--primary-btn);background:var(--primary-bg)}.role-option input[type=radio]{margin-top:2px;flex-shrink:0}.role-option-title{font-weight:600;color:var(--text-primary);margin-bottom:2px}.role-option-desc{font-size:13px;color:var(--text-secondary)}@media(max-width:640px){.btn-regenerate{margin-left:0}.team-table td,.team-table th{padding:10px 12px;font-size:13px}.action-buttons{flex-direction:column}}.super-admin{min-height:100vh;background:#0f172a;color:#e2e8f0}.sa-header{background:#1e293b;border-bottom:1px solid #334155;padding:16px 0}.sa-subtitle{color:#94a3b8;font-size:14px;margin:0}.sa-back{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:14px;padding:0 0 4px;display:block}.sa-back:hover{color:#e2e8f0}.sa-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:24px 0}.sa-stat-card{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-md);padding:20px}.sa-stat-number{font-size:36px;font-weight:700;color:#f1f5f9;line-height:1}.sa-stat-label{color:#94a3b8;font-size:14px;margin-top:4px}.sa-stat-breakdown{font-size:12px;margin-top:8px;color:#64748b}.sa-section{margin:24px 0}.sa-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sa-section h2,.sa-section-header h2{font-size:18px;font-weight:600;color:#f1f5f9;margin:0 0 12px}.sa-section-header h2{margin:0}.sa-search{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-sm);color:#e2e8f0;padding:8px 12px;font-size:14px;font-family:var(--font-family);width:240px}.sa-search::placeholder{color:#64748b}.sa-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid #334155}.sa-table{width:100%;border-collapse:collapse;background:#1e293b}.sa-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;border-bottom:1px solid #334155;background:#0f172a}.sa-table td{padding:12px 16px;font-size:14px;color:#cbd5e1;border-bottom:1px solid #1e293b}.sa-table tr:last-child td{border-bottom:none}.sa-table tr:hover td{background:#273447}.sa-clinic-name{font-weight:500;color:#f1f5f9}.sa-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:12px;font-weight:600;color:#fff}.sa-empty{text-align:center;color:#64748b;padding:32px!important}.sa-link{color:#60a5fa;text-decoration:none;font-size:14px}.sa-link:hover{color:#93c5fd;text-decoration:underline}.sa-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:24px 0}.sa-panel{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:12px;transition:background-color var(--duration-slow)}.sa-panel h2{font-size:16px;font-weight:600;color:#f1f5f9;margin:0}.sa-panel p{margin:0;font-size:14px;color:#94a3b8}.sa-select,.sa-input{background:#0f172a;border:1px solid #334155;border-radius:var(--radius-sm);color:#e2e8f0;padding:8px 12px;font-size:14px;font-family:var(--font-family);width:100%}.sa-stats-panel{background:#162032}.impersonation-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--secondary-400);color:#1a1a1a;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;box-shadow:0 2px 8px #0000004d}.impersonation-banner-text{display:flex;align-items:center;gap:8px}.impersonation-banner button{background:#00000026;border:1px solid rgba(0,0,0,.2);border-radius:6px;color:#1a1a1a;padding:4px 12px;cursor:pointer;font-weight:600;font-family:var(--font-family);font-size:13px}.impersonation-banner button:hover{background:#00000040}.error-msg{background:#450a0a;border:1px solid #7f1d1d;border-radius:var(--radius-sm);color:#fca5a5;padding:12px 16px;margin:16px 0;font-size:14px}.info-msg{background:#052e16;border:1px solid #14532d;border-radius:var(--radius-sm);color:#86efac;padding:12px 16px;margin:16px 0;font-size:14px}.sa-ticket-badge{display:inline-block;margin-left:10px;padding:2px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;color:#fff;vertical-align:middle}.sa-ticket-badge-open{background:#3b82f6}.sa-ticket-badge-progress{background:#f59e0b}@keyframes sa-badge-pulse{0%,to{opacity:1}50%{opacity:.7}}.sa-ticket-badge-open{animation:sa-badge-pulse 2s ease-in-out infinite}.sa-ticket-summary{display:flex;align-items:center;gap:8px;font-size:14px;color:#94a3b8;background:#1e293b;border:1px solid #334155;border-radius:var(--radius-md);padding:12px 16px}.sa-ticket-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:8px}.help-page{min-height:100vh;background:var(--bg-page);transition:background-color var(--duration-slow)}.help-page-header{background:var(--bg-card);box-shadow:var(--shadow-sm);padding:20px 0 0;margin-bottom:0;transition:background-color var(--duration-slow)}.help-header-row{margin-bottom:16px}.help-page-title{font-size:24px;color:var(--text-primary);margin:4px 0 0}.back-link{font-size:14px;color:var(--primary-text);text-decoration:none;display:inline-block}.back-link:hover{text-decoration:underline}.help-tabs{display:flex;gap:0;margin-top:12px;border-bottom:2px solid var(--border-color)}.help-tab{display:flex;align-items:center;gap:6px;padding:10px 18px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:14px;font-weight:500;font-family:var(--font-family);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),border-color var(--duration-fast)}.help-tab:hover{color:var(--text-primary)}.help-tab-active{color:var(--primary-text);border-bottom-color:var(--primary-btn);font-weight:600}.help-tab-badge{background:var(--error-500);color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;line-height:1}.help-search-standalone{position:relative;display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:0 14px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.help-search-wrap{position:relative;display:flex;align-items:center;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px 10px 0 0;padding:0 14px;margin-top:4px}.help-search-icon{font-size:16px;flex-shrink:0;margin-right:10px;color:var(--text-muted)}.help-search-input{flex:1;border:none;background:transparent;padding:14px 0;font-size:15px;font-family:var(--font-family);color:var(--text-primary);outline:none}.help-search-input::placeholder{color:var(--text-muted)}.help-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;font-family:var(--font-family);padding:4px 6px;border-radius:4px;transition:background .1s}.help-search-clear:hover{background:var(--border-color);color:var(--text-primary)}.help-main{padding-top:28px;padding-bottom:48px}.help-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}@media(max-width:720px){.help-layout{grid-template-columns:1fr}}.help-sidebar{background:var(--bg-card);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm);position:sticky;top:20px;transition:background-color var(--duration-slow)}.help-sidebar-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 10px;padding:0 6px}.help-categories{display:flex;flex-direction:column;gap:2px}.help-category-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 10px;background:none;border:none;border-radius:var(--radius-sm);text-align:left;font-size:14px;font-family:var(--font-family);color:var(--text-primary);cursor:pointer;transition:background .1s}.help-category-btn:hover{background:var(--bg-elevated)}.help-category-active{background:var(--primary-bg)!important;color:var(--primary-text);font-weight:600}.help-category-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}.help-category-count{margin-left:auto;font-size:12px;background:var(--bg-elevated);color:var(--text-muted);padding:1px 7px;border-radius:10px;font-weight:600}.help-category-active .help-category-count{background:var(--primary-bg-hover);color:var(--primary-text)}.help-articles-col{min-width:0}.help-search-result-info{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.help-articles-grid{display:flex;flex-direction:column;gap:10px}.help-article-card-btn{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 18px;cursor:pointer;text-align:left;transition:border-color var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth),transform .1s;width:100%}.help-article-card-btn:hover{border-color:var(--primary-btn);box-shadow:0 2px 10px #0ea5e91a;transform:translate(2px)}.help-article-card-icon{font-size:28px;flex-shrink:0;width:40px;text-align:center}.help-article-card-body{flex:1;min-width:0}.help-article-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.help-article-card-excerpt{font-size:13px;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.help-article-card-arrow{color:var(--text-muted);font-size:16px;flex-shrink:0;transition:transform .1s}.help-article-card-btn:hover .help-article-card-arrow{color:var(--primary-text);transform:translate(4px)}.help-article-view{max-width:720px}.help-back-btn{background:none;border:none;color:var(--primary-text);font-size:14px;font-family:var(--font-family);cursor:pointer;padding:0;margin-bottom:16px;display:inline-flex;align-items:center;gap:4px;transition:opacity .1s}.help-back-btn:hover{opacity:.75}.help-article-card{background:var(--bg-card);border-radius:14px;padding:32px;box-shadow:var(--shadow-sm);transition:background-color var(--duration-slow)}.help-article-icon{font-size:40px;margin-bottom:12px;line-height:1}.help-article-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 24px;line-height:1.3}.help-article-body{color:var(--text-primary);line-height:1.7}.help-article-para{margin:0 0 12px;font-size:15px}.help-article-para:last-child{margin-bottom:0}.help-faq-list{display:flex;flex-direction:column;gap:8px}.help-faq-item{border:1px solid var(--border-color);border-radius:10px;overflow:hidden;transition:border-color var(--duration-fast) var(--ease-smooth)}.help-faq-open{border-color:var(--primary-btn)}.help-faq-question{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:none;border:none;text-align:left;font-size:15px;font-family:var(--font-family);font-weight:600;color:var(--text-primary);cursor:pointer;gap:12px;transition:background .1s}.help-faq-question:hover{background:var(--bg-elevated)}.help-faq-chevron{font-size:11px;color:var(--text-muted);flex-shrink:0;transition:color var(--duration-fast) var(--ease-smooth)}.help-faq-open .help-faq-chevron{color:var(--primary-text)}.help-faq-answer{padding:12px 16px 14px;font-size:14px;color:var(--text-primary);line-height:1.6;border-top:1px solid var(--bg-elevated)}.help-article-feedback{display:flex;align-items:center;gap:10px;margin-top:32px;padding-top:20px;border-top:1px solid var(--bg-elevated)}.help-feedback-label{font-size:14px;color:var(--text-secondary)}.help-feedback-btn{background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 14px;font-size:14px;font-family:var(--font-family);cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth)}.help-feedback-yes:hover{background:var(--success-50);border-color:var(--success-500)}.help-feedback-no:hover{background:var(--error-50);border-color:var(--error-500)}.help-feedback-thanks{font-size:14px;color:var(--success-500);font-weight:500;margin:0}.help-loading{padding:48px 0;text-align:center;color:var(--text-muted);font-size:15px}.help-no-results{text-align:center;padding:48px 20px;background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:background-color var(--duration-slow)}.help-no-results-icon{font-size:48px;margin-bottom:12px}.help-no-results p{color:var(--text-secondary);font-size:15px;margin-bottom:16px}@media(max-width:520px){.help-article-card{padding:20px 16px}.help-article-title{font-size:20px}}.st-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;color:#fff;line-height:1.4}.st-badge-outline{background:transparent!important;border:1.5px solid}.st-list-header{display:flex;justify-content:flex-end;margin-bottom:12px}.st-filter-select{font-family:var(--font-family);font-size:13px;padding:7px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-primary);cursor:pointer}.st-tickets{display:flex;flex-direction:column;gap:8px}.st-ticket-row{display:flex;flex-direction:column;gap:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 18px;cursor:pointer;text-align:left;width:100%;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.st-ticket-row:hover{border-color:var(--primary-btn);box-shadow:0 2px 8px #0ea5e914}.st-ticket-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.st-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--error-500);display:inline-block}.st-ticket-desc{font-size:14px;color:var(--text-primary);margin:0;line-height:1.5}.st-ticket-date{font-size:12px;color:var(--text-muted)}.st-detail{max-width:720px}.st-detail-card{background:var(--bg-card);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:20px}.st-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.st-detail-header h3{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.st-detail-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.st-meta-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.st-meta-dates{font-size:13px;color:var(--text-muted);gap:16px}.st-description{font-size:15px;color:var(--text-primary);line-height:1.7;white-space:pre-wrap}.st-reopen-btn{margin-top:16px;display:inline-flex;align-items:center;gap:6px}.st-comments-section{background:var(--bg-card);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm)}.st-comments-section h4{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.st-no-comments{font-size:14px;color:var(--text-muted);margin:0 0 16px}.st-comments-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.st-comment{padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.st-comment-admin{background:var(--primary-bg);border-color:transparent}.st-comment-user{background:var(--bg-elevated)}.st-comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px}.st-comment-author{font-size:13px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px}.st-role-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.st-role-admin{background:var(--primary-btn);color:#fff}.st-role-user{background:var(--bg-page);color:var(--text-secondary)}.st-comment-time{font-size:12px;color:var(--text-muted);flex-shrink:0}.st-comment-content{font-size:14px;color:var(--text-primary);margin:0;line-height:1.5}.st-comment-input{display:flex;gap:8px}.st-comment-input input{flex:1;font-family:var(--font-family);font-size:14px;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-primary);outline:none}.st-comment-input input:focus{border-color:var(--primary-btn)}.st-send-btn{background:var(--primary-btn);color:#fff;border:none;border-radius:var(--radius-sm);padding:0 14px;cursor:pointer;display:flex;align-items:center;transition:background var(--duration-fast)}.st-send-btn:hover:not(:disabled){background:var(--primary-btn-hover)}.st-send-btn:disabled{opacity:.5;cursor:not-allowed}.sat-filters{display:flex;gap:12px;margin:20px 0;flex-wrap:wrap}.sat-filters .sa-select{width:auto;min-width:160px;text-transform:capitalize}.sat-row-clickable{cursor:pointer}.sat-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin:20px 0}.sat-page-info{color:#94a3b8;font-size:14px}.sat-status-control{margin-top:4px}.sat-context{background:#0f172a;border:1px solid #334155;border-radius:var(--radius-sm);padding:12px;font-size:12px;color:#94a3b8;overflow-x:auto;margin:0;white-space:pre-wrap;word-break:break-all}.sat-description{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-md);padding:16px;font-size:14px;color:#cbd5e1;white-space:pre-wrap;line-height:1.6}.sat-comments{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.sat-no-comments{color:#64748b;font-size:14px;padding:16px 0}.sat-comment{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-md);padding:14px}.sat-comment-admin{border-left:3px solid #3b82f6}.sat-comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sat-comment-author{font-size:13px;font-weight:600;color:#f1f5f9;display:flex;align-items:center;gap:8px}.sat-comment-date{font-size:12px;color:#64748b}.sat-comment-body{font-size:14px;color:#cbd5e1;white-space:pre-wrap;line-height:1.5}.sat-role-badge{font-size:11px;font-weight:600;padding:1px 6px;border-radius:var(--radius-full);text-transform:uppercase}.sat-role-admin{background:#1e3a5f;color:#60a5fa}.sat-role-user{background:#1a2e1a;color:#86efac}.sat-comment-input{display:flex;gap:12px;align-items:flex-end}.sat-comment-input .sa-input{flex:1;resize:vertical;min-height:60px}.sat-context-info{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#94a3b8;background:#0f172a;border:1px solid #334155;border-radius:var(--radius-sm);padding:12px}.sat-breadcrumbs{display:flex;flex-direction:column;gap:2px;background:#0f172a;border:1px solid #334155;border-radius:var(--radius-sm);padding:8px;max-height:300px;overflow-y:auto;font-size:12px;font-family:monospace}.sat-crumb{display:flex;align-items:baseline;gap:8px;padding:3px 6px;border-radius:3px}.sat-crumb:hover{background:#1e293b}.sat-crumb-time{color:#64748b;flex-shrink:0;min-width:75px}.sat-crumb-type{font-size:10px;font-weight:600;text-transform:uppercase;padding:1px 5px;border-radius:3px;flex-shrink:0;min-width:65px;text-align:center}.sat-crumb-type-navigation{background:#1e3a5f;color:#60a5fa}.sat-crumb-type-action{background:#1a2e1a;color:#86efac}.sat-crumb-type-error{background:#3b1111;color:#fca5a5}.sat-crumb-type-scan{background:#2e1a3e;color:#c4b5fd}.sat-crumb-type-click{background:#2e2a1a;color:#fcd34d}.sat-crumb-type-input{background:#1a2e2e;color:#67e8f9}.sat-crumb-msg{color:#cbd5e1}.sat-crumb-data{color:#64748b;font-size:11px}.sat-screenshot-thumb{max-width:100%;max-height:250px;object-fit:contain;border-radius:8px;border:1px solid #334155;cursor:pointer;transition:opacity .15s;margin-top:8px}.sat-screenshot-thumb:hover{opacity:.85}.sat-screenshot-overlay{position:fixed;inset:0;z-index:9999;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:zoom-out;padding:24px}.sat-screenshot-full{max-width:95vw;max-height:95vh;object-fit:contain;border-radius:8px}.sal-time{white-space:nowrap;font-size:13px;color:#94a3b8}.sal-resource-type{text-transform:capitalize;font-weight:500;color:#f1f5f9}.sal-resource-id{margin-left:4px;color:#64748b;font-size:13px}.sal-details{max-width:360px}.sal-details-content{display:flex;flex-wrap:wrap;gap:4px 12px}.sal-detail-item{font-size:13px;color:#cbd5e1}.sal-detail-key{color:#64748b}.sal-no-details{color:#475569}.sal-ip{font-size:13px;color:#64748b;font-family:monospace}.ad-controls{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.ad-filters{display:flex;gap:8px;flex-wrap:wrap}.ad-filter-btn{padding:6px 14px;border:1px solid var(--border-color);border-radius:999px;background:var(--bg-card);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.ad-filter-btn.active,.ad-filter-btn:hover{background:var(--primary-btn);color:#fff;border-color:var(--primary-btn)}.ad-sort-select{padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-primary);font-size:13px;cursor:pointer}.ad-loading{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.ad-empty{text-align:center;color:var(--text-muted);padding:60px 20px;font-size:15px;display:flex;flex-direction:column;align-items:center;gap:16px}.ad-list{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.ad-card{background:var(--bg-card);border:1px solid var(--border-color);border-left:4px solid var(--border-color);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm)}.ad-card.ad-row-critical{border-left-color:#dc2626;background:#fef2f2}.ad-card.ad-row-soon{border-left-color:#ea580c;background:#fff7ed}.ad-card.ad-row-upcoming{border-left-color:#eab308;background:#fefce8}[data-theme=dark] .ad-card.ad-row-critical{background:#dc26261a}[data-theme=dark] .ad-card.ad-row-soon{background:#ea580c1a}[data-theme=dark] .ad-card.ad-row-upcoming{background:#eab30814}.ad-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.ad-card-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.ad-card-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ad-card-lot{font-size:12px;color:var(--text-muted)}.ad-card-countdown{text-align:right;flex-shrink:0}.ad-countdown-label{display:block;font-size:14px;font-weight:700;color:var(--text-primary)}.ad-countdown-label.ad-row-critical{color:#dc2626;animation:ad-pulse 2s infinite}.ad-countdown-label.ad-row-soon{color:#ea580c}.ad-countdown-label.ad-row-upcoming{color:#854d0e}@keyframes ad-pulse{0%,to{opacity:1}50%{opacity:.65}}.ad-scheduled-date{display:block;font-size:12px;color:var(--text-muted);margin-top:2px}.ad-card-meta{display:flex;gap:16px;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.status-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:capitalize}.status-purchased{background:#dbeafe;color:#1e40af}.status-opened{background:#dcfce7;color:#166534}.status-depleted{background:#f3f4f6;color:#6b7280}[data-theme=dark] .status-purchased{background:#3b82f626;color:#93c5fd}[data-theme=dark] .status-opened{background:#22c55e26;color:#86efac}[data-theme=dark] .status-depleted{background:#6b728026;color:#9ca3af}@media(max-width:600px){.ad-card-top{flex-direction:column}.ad-card-countdown{text-align:left}}.costs-page{padding-bottom:40px}.costs-period-bar{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.period-chip{padding:6px 16px;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s}.period-chip:hover{border-color:var(--primary-btn);color:var(--primary-btn)}.period-chip--active{background:var(--primary-btn);color:#fff;border-color:var(--primary-btn)}.costs-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.cost-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);border-top:3px solid var(--primary-btn)}.cost-card-label{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.cost-card-value{font-size:28px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;margin-bottom:4px}.cost-card-sub{font-size:12px;color:var(--text-muted)}.costs-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.costs-section-header h2{margin:0;font-size:18px}.costs-budget-card{margin-bottom:24px}.budget-edit-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.budget-numbers{display:flex;align-items:center;gap:12px;margin-bottom:8px;font-size:16px;font-weight:600;font-variant-numeric:tabular-nums}.budget-status-badge{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize}.budget-status--on_track{background:var(--success-100);color:var(--success-600)}.budget-status--warning{background:var(--secondary-50);color:var(--secondary-600)}.budget-status--critical{background:var(--warning-100);color:var(--warning-600)}.budget-status--over_budget{background:var(--error-100);color:var(--error-600)}.budget-status--no_budget{background:var(--bg-elevated);color:var(--text-muted)}.budget-alert{margin-top:8px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--warning-100);color:var(--warning-600);font-size:14px}.budget-progress{width:100%;height:10px;border-radius:999px;background:var(--bg-elevated);overflow:hidden;margin-bottom:4px}.budget-progress-fill{height:100%;border-radius:999px;transition:width .4s ease}.budget-progress-fill.good{background:var(--success-500)}.budget-progress-fill.caution{background:var(--secondary-500)}.budget-progress-fill.warning{background:var(--warning-500)}.budget-progress-fill.danger{background:var(--error-500)}.budget-progress-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}.budget-pct{font-weight:600}.budget-pct--good{color:var(--success-600)}.budget-pct--caution{color:var(--secondary-600)}.budget-pct--warning{color:var(--warning-600)}.budget-pct--danger{color:var(--error-600)}.costs-chart{display:flex;align-items:flex-end;gap:6px;height:160px;margin:16px 0 8px;overflow-x:auto;padding-bottom:2px}.chart-bar-col{display:flex;flex-direction:column;align-items:center;flex:1;min-width:32px;max-width:60px;height:100%}.chart-bar-label-top{font-size:10px;color:var(--text-muted);height:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}.chart-bar-track{flex:1;width:100%;display:flex;align-items:flex-end;padding:0 4px}.chart-bar-fill{width:100%;background:var(--primary-btn);border-radius:4px 4px 0 0;min-height:2px;transition:height .3s ease}.chart-bar-label{font-size:11px;color:var(--text-muted);margin-top:4px;text-align:center}.costs-chart-summary{display:flex;gap:24px;font-size:13px;color:var(--text-secondary);flex-wrap:wrap}.trend-badge{font-size:13px;padding:3px 10px;border-radius:999px;background:var(--bg-elevated);color:var(--text-secondary)}.by-product-list{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.by-product-row{display:grid;grid-template-columns:minmax(120px,1fr) 2fr auto;gap:12px;align-items:center}.by-product-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.by-product-bar-wrapper{height:12px;background:var(--bg-elevated);border-radius:999px;overflow:hidden}.by-product-bar{height:100%;background:var(--primary-btn);border-radius:999px;transition:width .4s ease;min-width:4px}.by-product-stats{display:flex;flex-direction:column;align-items:flex-end;white-space:nowrap}.by-product-total{font-weight:600;font-size:14px;font-variant-numeric:tabular-nums}.by-product-total-row{font-size:13px;color:var(--text-secondary);font-weight:500;border-top:1px solid var(--border-color);padding-top:8px;margin-top:4px}.costs-table{width:100%;border-collapse:collapse;font-size:14px}.costs-table th{text-align:left;padding:8px 12px;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.costs-table td{padding:10px 12px;border-bottom:1px solid var(--border-color);font-variant-numeric:tabular-nums}.costs-table tr:last-child td{border-bottom:none}.cost-input-wrapper{display:flex;align-items:center;gap:8px}.currency-symbol{font-size:18px;font-weight:600;color:var(--text-secondary)}.cost-input{width:150px;font-size:16px;font-variant-numeric:tabular-nums;text-align:right}.widget-link{font-size:13px;color:var(--primary-btn);text-decoration:none}.widget-link:hover{text-decoration:underline}.widget-empty{color:var(--text-muted);font-size:14px;padding:16px 20px}.cost-widget-body{display:flex;flex-direction:column;gap:8px;padding:16px 20px}.cost-stat-row{display:flex;justify-content:space-between;align-items:center;font-size:15px}.cost-stat-row--divider{border-top:1px solid var(--border-color);padding-top:8px;margin-top:4px}.cost-stat-label{color:var(--text-secondary)}.cost-stat-value{font-weight:600;font-variant-numeric:tabular-nums}.btn-sm{font-size:13px;padding:6px 12px}@media(max-width:600px){.costs-summary-grid{grid-template-columns:1fr 1fr}.by-product-row{grid-template-columns:1fr auto}.by-product-bar-wrapper{display:none}.cost-card-value{font-size:22px}}.detail-value{font-size:15px;color:var(--text-primary);padding:6px 0;min-height:32px}.supply-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:560px){.supply-detail-grid{grid-template-columns:1fr}}.suppliers-search{margin-bottom:16px}.suppliers-search .search-wrapper{position:relative}.suppliers-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.suppliers-search .search-input-full{width:100%;padding-left:36px}.suppliers-search .search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.suppliers-list{display:flex;flex-direction:column;gap:12px}.supplier-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:box-shadow .15s}.supplier-card:hover{box-shadow:var(--shadow-sm)}.supplier-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.supplier-card-header h3{margin:0;font-size:16px;color:var(--text-primary)}.supplier-vat{font-size:13px;color:var(--text-muted);font-family:monospace}.supplier-card-details{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text-secondary)}.supplier-card-details span{display:flex;align-items:center;gap:4px}.supplier-card-name h3{display:flex;align-items:center;gap:6px}.supplier-lock-icon{color:var(--text-muted);flex-shrink:0}.supplier-card-actions{display:flex;align-items:center;gap:8px}.supplier-edit-btn{padding:4px 8px!important;min-width:unset!important}.supplier-edit-btn:disabled{opacity:.4;cursor:not-allowed}.supplier-edits-remaining{font-size:13px;color:var(--text-muted);margin-bottom:12px;padding:6px 10px;background:var(--bg-elevated);border-radius:var(--radius-md)}.supplier-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:480px){.supplier-detail-grid{grid-template-columns:1fr}}.supplier-detail-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;display:block}.supplier-detail-value{font-size:14px;color:var(--text-primary)}.activity-log-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.activity-type-chips{display:flex;flex-wrap:wrap;gap:8px}.activity-log-list{display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-color)}.activity-log-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;text-decoration:none;color:inherit;border-bottom:1px solid var(--border-color);transition:background .15s}.activity-log-item:last-child{border-bottom:none}.activity-log-item:hover{background:var(--bg-elevated)}.activity-log-more{display:flex;justify-content:center;padding:20px 0}.recalls-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-bottom:24px}.recalls-tab{padding:12px 24px;background:none;border:none;color:var(--text-secondary);font-size:15px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.recalls-tab:hover{color:var(--text-primary)}.recalls-tab--active{color:var(--primary-btn);border-bottom-color:var(--primary-btn)}.recall-search-card{background:var(--bg-card);border-radius:var(--radius-md);padding:32px;box-shadow:var(--shadow-sm);max-width:600px;margin:0 auto}.recall-search-card h2{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--text-primary)}.recall-search-card .helper-text{color:var(--text-muted);font-size:14px;margin:0 0 20px}.recall-search-input-row{display:flex;gap:12px}.recall-search-input-row input{flex:1}.recall-preview{background:var(--bg-card);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm)}.recall-preview h3{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text-primary)}.recall-preview .lot-label{color:var(--text-muted);font-size:14px;margin:0 0 16px;font-family:monospace}.recall-count-banner{padding:12px 16px;border-radius:var(--radius-sm, 6px);font-weight:600;font-size:15px;margin-bottom:16px}.recall-count-banner--active{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}[data-theme=dark] .recall-count-banner--active{background:#fbbf241f;color:#fbbf24;border-color:#fbbf244d}.recall-count-banner--empty{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color)}.recall-preview-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:16px}.recall-preview-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border-color);color:var(--text-muted);font-weight:500;font-size:13px}.recall-preview-table td{padding:8px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.recall-preview-table tr.recall-row--skip{opacity:.5}.recall-skip-note{font-size:12px;color:var(--text-muted);font-style:italic}.recall-reason-field{margin-bottom:20px}.recall-reason-field label{display:block;font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.recall-reason-field input{width:100%;box-sizing:border-box}.recall-actions{display:flex;gap:12px;justify-content:flex-end}.recall-success{background:var(--bg-card);border-radius:var(--radius-md);padding:32px;box-shadow:var(--shadow-sm);text-align:center;max-width:500px;margin:0 auto}.recall-success-icon{font-size:48px;margin-bottom:12px}.recall-success h3{margin:0 0 8px;font-size:20px;color:var(--text-primary)}.recall-success p{color:var(--text-secondary);margin:0 0 20px}.recall-success-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.recall-history-table{width:100%;border-collapse:collapse;font-size:14px}.recall-history-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border-color);color:var(--text-muted);font-weight:500;font-size:13px}.recall-history-table td{padding:10px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.recall-history-table tr:hover{background:var(--bg-elevated)}.recall-lot-cell{font-family:monospace;font-weight:600}.recall-reason-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.recall-detail-meta{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;margin-bottom:20px;font-size:14px}.recall-detail-meta dt{color:var(--text-muted);font-weight:500}.recall-detail-meta dd{margin:0;color:var(--text-primary)}.recall-detail-records{max-height:300px;overflow-y:auto}.badge-orange{background:#fed7aa;color:#9a3412}[data-theme=dark] .badge-orange{background:#fb923c2e;color:#fb923c}@media(max-width:767px){.recall-search-card{padding:20px}.recall-search-input-row,.recall-actions{flex-direction:column}.recall-actions .btn{width:100%}.recall-preview-table{font-size:13px}.recall-preview-table th,.recall-preview-table td{padding:6px 8px}}.insp-filters{margin-bottom:16px}.insp-filter-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.insp-filter-tab{padding:5px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-card);cursor:pointer;font-size:13px;font-family:var(--font-family);font-weight:500;color:var(--text-secondary);transition:border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast)}.insp-filter-tab:hover{border-color:var(--border-hover);color:var(--text-primary)}.insp-filter-tab.active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.insp-search-row{display:flex;gap:8px;align-items:center}.insp-search-input{flex:1;min-width:200px;padding:10px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.insp-search-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e914}.insp-search-input::placeholder{color:var(--text-disabled)}.insp-search-row input[type=date]{padding:8px 10px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);outline:none;min-width:0}.insp-search-row input[type=date]:focus{border-color:var(--border-focus)}.insp-table-wrapper{overflow-x:auto}.insp-table{width:100%;border-collapse:collapse}.insp-table th{text-align:left;padding:10px 12px;background:var(--bg-elevated);color:var(--text-muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color);white-space:nowrap}.insp-table td{padding:11px 12px;border-top:1px solid var(--border-color);font-size:14px;color:var(--text-primary);transition:background var(--duration-fast) var(--ease-smooth)}.insp-table tbody tr:nth-child(2n) td{background:var(--bg-elevated)}.insp-table tbody tr:hover td{background:var(--primary-bg)}.insp-table tbody tr{animation:staggerIn .3s var(--ease-smooth) both}.insp-table tbody tr:nth-child(1){animation-delay:0ms}.insp-table tbody tr:nth-child(2){animation-delay:30ms}.insp-table tbody tr:nth-child(3){animation-delay:60ms}.insp-table tbody tr:nth-child(4){animation-delay:90ms}.insp-table tbody tr:nth-child(5){animation-delay:.12s}.insp-table tbody tr:nth-child(6){animation-delay:.15s}.insp-table tbody tr:nth-child(7){animation-delay:.18s}.insp-table tbody tr:nth-child(8){animation-delay:.21s}.insp-table tbody tr:nth-child(9){animation-delay:.24s}.insp-table tbody tr:nth-child(10){animation-delay:.27s}.insp-table tr:last-child td{border-bottom:none}.insp-product-cell{display:flex;flex-direction:column;gap:2px}.insp-product-name{font-weight:600;color:var(--text-primary)}.insp-barcode{font-size:11px;font-family:monospace;color:var(--text-muted)}.insp-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;white-space:nowrap;transition:transform var(--duration-fast),box-shadow var(--duration-fast)}.insp-badge:hover{transform:scale(1.05)}.insp-badge-passed{background:var(--success-100);color:var(--success-600);box-shadow:0 1px 4px #10b98126}.insp-badge-issues{background:var(--error-100, #fee2e2);color:var(--error-600, #dc2626);box-shadow:0 1px 4px #ef444426}.insp-badge-pending{background:var(--secondary-50);color:var(--secondary-600);box-shadow:0 1px 4px #f59e0b26}.insp-pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 0 8px;margin-top:4px}.insp-page-info{font-size:14px;color:var(--text-muted);font-weight:500}@media(max-width:640px){.insp-table th:nth-child(3),.insp-table td:nth-child(3),.insp-table th:nth-child(4),.insp-table td:nth-child(4){display:none}.insp-search-row{flex-direction:column}}.beta-welcome-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px}.beta-welcome-modal{background:var(--bg-card);border-radius:var(--radius-lg, 16px);padding:32px 28px;max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-lg, 0 20px 60px rgba(0, 0, 0, .3));animation:betaWelcomeFadeIn .3s ease-out}@keyframes betaWelcomeFadeIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.beta-welcome-logo{width:64px;height:64px;margin-bottom:16px}.beta-welcome-title{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0 0 12px}.beta-welcome-thank-you{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0 0 20px}.beta-welcome-disclaimer{background:var(--warning-50);border:1px solid var(--warning-500);border-radius:var(--radius-md, 8px);padding:12px 16px;font-size:.82rem;color:var(--warning-600);line-height:1.5;margin-bottom:20px;text-align:left}[data-theme=dark] .beta-welcome-disclaimer{background:#f973161a;border-color:#f973164d;color:#fdba74}.beta-welcome-cta-text{color:var(--text-secondary);font-size:.9rem;margin:0 0 16px}.beta-welcome-actions{display:flex;flex-direction:column;gap:10px}.beta-welcome-actions .btn{width:100%;padding:12px 16px;font-size:.95rem}.beta-welcome-actions .btn-text{background:none;border:none;color:var(--text-muted);font-size:.85rem;padding:8px 16px;cursor:pointer}.beta-welcome-actions .btn-text:hover{color:var(--text-secondary)}.page-transition--enter{will-change:opacity,transform;animation:pageEnter .25s cubic-bezier(.4,0,.2,1) both}.page-transition--exit{will-change:opacity,transform;animation:pageExit .15s cubic-bezier(.4,0,.2,1) both}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pageExit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@media(prefers-reduced-motion:reduce){.page-transition--enter,.page-transition--exit{animation:none}}
