:root{--cyan-300: #67e8f9;--cyan-400: #22d3ee;--cyan-500: #06b6d4;--cyan-600: #0891b2;--cyan-700: #0e7490;--navy-950: #020817;--navy-900: #0a1628;--navy-800: #0f2137;--navy-700: #162944;--navy-600: #1e3a57;--navy-500: #2d4f6e;--navy-400: #4a6c85;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--primary-50: #ecfeff;--primary-100: #cffafe;--primary-200: #a5f3fc;--primary-300: #67e8f9;--primary-400: #22d3ee;--primary-500: #06b6d4;--primary-600: #0891b2;--primary-700: #0e7490;--primary-800: #155e75;--primary-900: #164e63;--success-50: #ecfdf5;--success-100: #d1fae5;--success-500: #10b981;--success-600: #059669;--success-700: #047857;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-500: #f59e0b;--warning-600: #d97706;--warning-700: #92400e;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--error-700: #b91c1c;--info-100: #dbeafe;--info-500: #3b82f6;--info-600: #2563eb;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--sidebar-width: 220px;--sidebar-collapsed-width: 60px;--global-header-height: 52px;--ease-smooth: cubic-bezier(.4, 0, .2, 1);--duration-fast: .12s;--duration-normal:.2s;--duration-slow: .3s}[data-theme=dark]{color-scheme:dark;--bg-page: var(--navy-900);--bg-card: var(--navy-800);--bg-elevated: var(--navy-700);--bg-hover: var(--navy-700);--bg-input: var(--navy-800);--bg-sidebar: var(--navy-950);--text-primary: #f0f6ff;--text-secondary: #94a3b8;--text-muted: #64748b;--text-disabled: #334155;--border-color: var(--navy-600);--border-hover: var(--navy-500);--border-focus: var(--cyan-500);--primary-btn: var(--cyan-500);--primary-btn-hover: var(--cyan-400);--primary-text: var(--cyan-400);--primary-text-hover: var(--cyan-300);--primary-bg: rgba(6, 182, 212, .1);--primary-bg-hover: rgba(6, 182, 212, .15);--primary-border: rgba(6, 182, 212, .3);--shadow-xs: 0 1px 2px rgba(0,0,0,.4);--shadow-sm: 0 1px 3px rgba(0,0,0,.5);--shadow-md: 0 4px 6px rgba(0,0,0,.5);--shadow-lg: 0 10px 15px rgba(0,0,0,.6);--shadow-xl: 0 20px 25px rgba(0,0,0,.7);--chart-purchased: #06b6d4;--chart-opened: #10b981;--chart-depleted: #64748b;--chart-grid: var(--navy-700);--chart-purchased-fill: rgba(6,182,212,.12);--chart-opened-fill: rgba(16,185,129,.12);--chart-depleted-fill: rgba(100,116,139,.12);--warning-100: rgba(245, 158, 11, .12);--warning-500: #f59e0b;--warning-600: #fbbf24;--warning-700: #fbbf24;--chart-pie-1: #60a5fa;--chart-pie-2: #34d399;--chart-pie-3: #fbbf24;--chart-pie-4: #f87171;--chart-pie-5: #a78bfa;--chart-pie-6: #f472b6;--chart-pie-7: #22d3ee;--chart-pie-8: #a3e635}[data-theme=light]{color-scheme:light;--bg-page: var(--slate-50);--bg-card: #ffffff;--bg-elevated: var(--slate-100);--bg-hover: var(--slate-100);--bg-input: #ffffff;--bg-sidebar: #ffffff;--text-primary: var(--slate-900);--text-secondary: var(--slate-600);--text-muted: var(--slate-500);--text-disabled: var(--slate-400);--border-color: var(--slate-200);--border-hover: var(--slate-300);--border-focus: var(--cyan-500);--primary-btn: var(--cyan-600);--primary-btn-hover: var(--cyan-700);--primary-text: var(--cyan-600);--primary-text-hover: var(--cyan-700);--primary-bg: rgba(6, 182, 212, .08);--primary-bg-hover: rgba(6, 182, 212, .14);--primary-border: rgba(6, 182, 212, .35);--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.07);--shadow-md: 0 4px 6px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.08);--shadow-xl: 0 20px 25px rgba(0,0,0,.1);--chart-purchased: var(--cyan-600);--chart-opened: #10b981;--chart-depleted: var(--slate-400);--chart-grid: var(--slate-200);--chart-purchased-fill: rgba(8,145,178,.1);--chart-opened-fill: rgba(16,185,129,.1);--chart-depleted-fill: rgba(148,163,184,.1);--chart-pie-1: #2563eb;--chart-pie-2: #10b981;--chart-pie-3: #f59e0b;--chart-pie-4: #ef4444;--chart-pie-5: #8b5cf6;--chart-pie-6: #ec4899;--chart-pie-7: #06b6d4;--chart-pie-8: #84cc16}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}#root{overflow-x:clip}body{font-family:var(--font-family);font-size:14px;line-height:1.5;background-color:var(--bg-page);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100%;transition:background-color var(--duration-normal) var(--ease-smooth),color var(--duration-normal) var(--ease-smooth)}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:9999}*: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}}h1{font-size:28px;font-weight:600;line-height:1.25;color:var(--text-primary);letter-spacing:-.01em}h2{font-size:22px;font-weight:600;line-height:1.3;color:var(--text-primary);letter-spacing:-.01em}h3{font-size:18px;font-weight:600;line-height:1.4;color:var(--text-primary)}h4{font-size:15px;font-weight:600;line-height:1.5;color:var(--text-primary)}h5{font-size:13px;font-weight:600;line-height:1.5;color:var(--text-secondary)}p{font-size:14px;line-height:1.6;color:var(--text-secondary)}.text-caption{font-size:12px;color:var(--text-muted);letter-spacing:.01em}.text-label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}a{color:var(--primary-text);text-decoration:none;transition:color var(--duration-fast) var(--ease-smooth)}a:hover{color:var(--primary-text-hover)}.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}}.page-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-bottom:16px}.page-actions .tooltip-wrapper,.page-actions .tooltip-wrapper>*{flex:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;font-family:var(--font-family);font-size:14px;font-weight:600;line-height:1;border-radius:var(--radius-md);border:1.5px solid transparent;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:11px 24px;font-size:15px}.btn-primary{background:var(--primary-btn);color:#fff;border-color:var(--primary-btn)}.btn-primary:hover{background:var(--primary-btn-hover);border-color:var(--primary-btn-hover)}.btn-secondary{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--border-hover);color:var(--text-primary)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-danger{background:transparent;color:var(--error-500);border-color:var(--error-500)}.btn-danger:hover{background:#ef44441a}.btn-success{background:var(--success-500);color:#fff;border-color:var(--success-500)}.btn-success:hover{background:var(--success-600);border-color:var(--success-600)}.btn-icon{width:34px;height:34px;padding:0;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);border-color:transparent}.btn-icon:hover{background:var(--bg-elevated);color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;transition:border-color var(--duration-fast) var(--ease-smooth)}.card:hover{border-color:var(--border-hover)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border-color)}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 12px;font-size:14px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth);appearance:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--cyan-500);box-shadow:0 0 0 3px #06b6d426}.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:1px solid var(--border-color);border-radius:var(--radius-md);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(--cyan-500);box-shadow:0 0 0 3px #06b6d426}.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}thead th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;background:var(--bg-elevated);border-bottom:1px solid var(--border-color);white-space:nowrap}tbody tr{border-bottom:1px solid var(--border-color);transition:background var(--duration-fast)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-elevated)}tbody td{padding:11px 14px;color:var(--text-primary);vertical-align:middle}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;border-radius:var(--radius-full);letter-spacing:.02em;white-space:nowrap}.badge-success{background:#10b9811f;color:#34d399}.badge-warning{background:#f59e0b1f;color:#fbbf24}.badge-danger{background:#ef44441f;color:#f87171}.badge-info{background:#3b82f61f;color:#93c5fd}.badge-primary{background:#06b6d41f;color:#22d3ee}.badge-muted{background:var(--bg-elevated);color:var(--text-muted)}[data-theme=light] .badge-success{background:#10b9811a;color:#059669}[data-theme=light] .badge-warning{background:#f59e0b1a;color:#d97706}[data-theme=light] .badge-danger{background:#ef44441a;color:#dc2626}[data-theme=light] .badge-info{background:#3b82f61a;color:#2563eb}[data-theme=light] .badge-primary{background:#06b6d41a;color:#0891b2}.modal-overlay{position:fixed;inset:0;background:#020817bf;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp var(--duration-slow) var(--ease-smooth)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end}.app-shell{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left var(--duration-slow) var(--ease-smooth);min-width:0;overflow:hidden}.app-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.app-content{flex:1;padding:24px;overflow-y:auto}@media(max-width:768px){.app-main{margin-left:0!important}.app-content{padding:16px}}.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:background var(--duration-fast) var(--ease-smooth),color var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth);flex-shrink:0}.dark-mode-toggle:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.app-version{text-align:center;font-size:12px;color:var(--text-muted);padding:16px 0 8px;opacity:.6;letter-spacing:.02em}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-page)}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:loginCardIn .5s var(--ease-smooth);transition:background-color var(--duration-slow);border:1px solid var(--border-color)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.brand-icon{width:32px;height:32px}.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{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 8px;margin-top:24px;font-size:14px;color:var(--text-muted)}.login-footer-separator{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}.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)}.tooltip-wrapper{position:relative;display:inline-flex;align-items:center}.tooltip-wrapper:only-child{display:flex;flex:1;min-width:0}.tooltip-wrapper>*{flex:1;min-width:0}.tooltip-portal{position:absolute;z-index:10000;pointer-events:none;animation:tooltip-fade-in var(--duration-fast, .15s) ease-out}.tooltip-portal .tooltip-box{background:var(--slate-800);color:#f0f6ff;font-size:12px;font-weight:500;line-height:1.4;padding:6px 10px;border-radius:var(--radius-sm);white-space:normal;max-width:240px;width:max-content;box-shadow:var(--shadow-lg);text-align:center}.tooltip-top{transform:translate(-50%) translateY(-100%)}.tooltip-top .tooltip-box:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--slate-800)}.tooltip-bottom{transform:translate(-50%)}.tooltip-bottom .tooltip-box:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-bottom-color:var(--slate-800)}.tooltip-left{transform:translate(-100%) translateY(-50%)}.tooltip-left .tooltip-box:after{content:"";position:absolute;top:50%;left:100%;transform:translateY(-50%);border:5px solid transparent;border-left-color:var(--slate-800)}.tooltip-right{transform:translateY(-50%)}.tooltip-right .tooltip-box:after{content:"";position:absolute;top:50%;right:100%;transform:translateY(-50%);border:5px solid transparent;border-right-color:var(--slate-800)}@keyframes tooltip-fade-in{0%{opacity:0}to{opacity:1}}@media(hover:none){.tooltip-portal{display:none}}.tour-overlay{position:fixed;inset:0;background:#020817d9;-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}.tour-overlay-spotlight{position:fixed;inset:0;z-index:9000;animation:tour-fade-in var(--duration-normal) ease-out}.tour-spotlight{position:fixed;border-radius:var(--radius-md);box-shadow:0 0 0 9999px #020817d9;z-index:9001;pointer-events:none;transition:top .3s ease,left .3s ease,width .3s ease,height .3s ease}.tour-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:32px;max-width:420px;width:100%;box-shadow:var(--shadow-xl);animation:tour-slide-up var(--duration-normal) ease-out;transition:background-color var(--duration-slow)}.tour-card-targeted{position:fixed;z-index:9002}.tour-card-bottom{animation:tour-slide-down var(--duration-normal) ease-out}.tour-card-top{animation:tour-slide-up var(--duration-normal) ease-out}@keyframes tour-fade-in{0%{opacity:0}to{opacity:1}}@keyframes tour-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes tour-slide-down{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}.tour-header{text-align:center;margin-bottom:20px}.tour-icon{color:var(--primary-btn);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:80px;margin-bottom:24px}.tour-content{font-size:15px;color:var(--text-primary);line-height:1.6;margin:0}.tour-locked-badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg-elevated);color:var(--text-muted);font-size:12px;font-weight:600;padding:4px 10px;border-radius:var(--radius-sm);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.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(--cyan-500);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;max-width:calc(100vw - 32px)}.tour-title{font-size:19px}.tour-card-targeted{left:16px!important;right:16px;max-width:none}}.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%;max-height:calc(100vh - 32px);overflow-y:auto;box-shadow:var(--shadow-xl);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}.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}}.ios-guide-overlay{position:fixed;inset:0;z-index:9999;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px}.ios-guide-modal{background:var(--bg-card, #fff);border-radius:var(--radius-md, 10px);box-shadow:var(--shadow-lg, 0 8px 30px rgba(0, 0, 0, .15));max-width:340px;width:100%;padding:20px}.ios-guide-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.ios-guide-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.ios-guide-steps{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-direction:column;gap:16px}.ios-guide-steps li{display:flex;align-items:flex-start;gap:12px;color:var(--text-secondary);font-size:.9rem;line-height:1.4}.ios-guide-step-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-elevated, #f0f0f0);border-radius:8px;color:var(--primary-btn, #0ea5e9);font-size:1rem}.ios-guide-ok{width:100%}.alert-strip{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px;flex:1;min-width:0}.alert-pill{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:5px 12px;display:flex;align-items:center;gap:6px;text-decoration:none;transition:background var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth)}.alert-pill:hover{background:var(--bg-hover);border-color:var(--border-hover)}.alert-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.alert-pill-text{color:var(--text-primary);font-size:12px;font-weight:500;white-space:nowrap}.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}}.dashboard{min-height:100vh;background:var(--bg-page)}.dashboard-container{max-width:1600px;margin:0 auto;padding:0 24px}.dashboard-alert-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.dashboard-alert-row .alert-strip{margin-bottom:0}.dashboard-toolbar-actions{display:flex;gap:8px;flex-shrink:0}.header-content{display:flex;justify-content:space-between;align-items:center}.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)}.btn-sm{padding:7px 14px;font-size:13px;border-radius:var(--radius-sm)}.dashboard-main{padding-top:12px;padding-bottom:48px}.dashboard-top-bar .btn{display:flex;align-items:center;gap:6px}.dashboard-layout-btn{border-color:var(--primary-border);color:var(--primary-text)}.dashboard-layout-btn:hover{background:var(--primary-bg);border-color:var(--primary-border)}.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:12px}.stats-grid>.tooltip-wrapper{display:flex;align-items:stretch}@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}}@media(max-width:680px){.dashboard-alert-row{flex-direction:column;align-items:center}.alert-strip,.dashboard-toolbar-actions{justify-content:center}.tour-replay-btn{display:none}}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:14px 20px;text-align:center;border:1px solid var(--border-color);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-smooth),background-color var(--duration-fast);-webkit-user-select:none;user-select:none;animation:staggerIn .4s var(--ease-smooth) both;display:flex;flex-direction:column;justify-content:center}.stat-card:nth-child(5){animation-delay:.24s}.stat-card:hover{border-color:var(--border-hover);background:var(--bg-elevated)}.stat-card:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.stat-card-success,.stat-card-warning,.stat-card-danger,.stat-card-neutral{background:var(--bg-card);border-color:var(--border-color)}.stat-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);margin:0 auto 8px;color:var(--primary-500);background:#06b6d41f}.stat-card-success .stat-icon{color:var(--success-500);background:#10b9811f}.stat-card-warning .stat-icon{color:var(--warning-500);background:#f59e0b1f}.stat-card-danger .stat-icon{color:var(--error-500);background:#ef44441f}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary);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,.badge-warning{background:var(--warning-100);color:var(--warning-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 10px;margin-bottom:10px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:8px}.trends-summary{display:flex;align-items:center;gap:10px;font-size:12px}.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-primary{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:12px}.action-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none;color:var(--primary-500);cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth);animation:staggerIn .4s var(--ease-smooth) both}.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:nth-child(6){animation-delay:.35s}.action-card:hover{background:var(--bg-hover);border-color:var(--border-hover)}.action-label{color:var(--text-primary);font-size:11px;font-weight:500;text-align:center}@media(max-width:768px){.quick-actions-primary{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.quick-actions-primary{grid-template-columns:repeat(2,1fr)}}.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{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius-md);color:var(--text-muted);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:12px}.dashboard-full-row{margin-bottom:12px}.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:12px;margin-bottom:12px}@media(max-width:768px){.dashboard-mid-grid{grid-template-columns:1fr}}.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-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:680px){.supplier-breakdown-content{flex-direction:column;align-items:center}.supplier-breakdown-chart{width:160px}.supplier-breakdown-legend{width:100%}}.empty-state{text-align:center;padding:60px 20px;background:var(--bg-card);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}.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 #020817d9;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 #020817d9;animation:frame-pulse 2s ease-in-out infinite}.scanner-frame.success{box-shadow:0 0 0 9999px #020817d9,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 var(--cyan-500);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:#020817b3;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:1px solid var(--border-color);background:var(--bg-card);-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:var(--text-primary)}.torch-btn:hover{background:var(--bg-elevated)}.torch-btn.active{background:var(--warning-500);border-color:var(--warning-500);color:#fff;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-bg);border-color:var(--primary-btn);color:var(--primary-btn)}.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}.camera-gesture-prompt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#020817d9;border:none;color:#fff;font-size:16px;font-weight:600;cursor:pointer;z-index:10;-webkit-tap-highlight-color:transparent}.camera-gesture-prompt:active{background:#020817eb}.scanner-error{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px}.scanner-error-icon{color:var(--text-muted)}.scanner-error-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.scanner-error-instructions{color:var(--text-secondary);font-size:14px;margin:0;line-height:1.5}.scanner-error p{color:var(--error-500);font-size:14px}.supplier-selector{position:relative}.supplier-selector-input{width:100%;padding:11px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-size:15px;font-family:var(--font-family);cursor:pointer;outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.supplier-selector-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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}.manufacturer-selector{position:relative}.manufacturer-selector-input{width:100%;padding:11px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-size:15px;font-family:var(--font-family);cursor:pointer;outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.manufacturer-selector-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.manufacturer-selector-input::placeholder{color:var(--text-muted)}.manufacturer-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}.manufacturer-dropdown-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:2px}.manufacturer-dropdown-item:last-child{border-bottom:none}.manufacturer-dropdown-item:hover{background:var(--bg-elevated)}.manufacturer-dropdown-item.selected{background:var(--bg-elevated);font-weight:600}.manufacturer-dropdown-name{font-size:14px;color:var(--text-primary)}.manufacturer-dropdown-country{font-size:12px;color:var(--text-muted)}.manufacturer-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)}.manufacturer-dropdown-add:hover{background:var(--bg-elevated)}.manufacturer-dropdown-empty{padding:10px 12px;color:var(--text-muted);font-size:13px;text-align:center}.manufacturer-selected{display:flex;align-items:center;gap:8px}.manufacturer-selected-name{flex:1;font-size:14px;color:var(--text-primary)}.manufacturer-clear-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center}.manufacturer-clear-btn:hover{color:var(--text-primary)}.manufacturer-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-icon{flex-shrink:0;display:flex;align-items:center;gap:4px;color:var(--text-muted);opacity:.6}.regulatory-icon{display:inline-block;vertical-align:middle}.regulatory-icon-group{display:inline-flex;align-items:center;gap:4px}.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:11px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-size:15px;font-family:var(--font-family);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.inspection-notes textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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}.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:var(--bg-card);border:1px solid var(--success-500)}.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(--bg-elevated);border-radius:var(--radius-md);border:1.5px solid var(--border-color)}.item-number-display p{margin-bottom:10px;color:var(--text-primary);font-weight:600}.item-number{font-size:56px;font-weight:700;color:var(--cyan-500);letter-spacing:-.02em}.item-numbers-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.item-numbers-list .item-number{font-size:32px;background:var(--bg-elevated);color:var(--cyan-500);padding:4px 16px;border-radius:var(--radius-sm)}.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:1.5px 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);text-align:center;outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.number-input-row .number-input-short:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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:11px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:15px;font-family:var(--font-family);background:var(--bg-input);color:var(--text-primary);outline:none;margin-bottom:8px;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.product-picker-search:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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);color:var(--text-primary);cursor:pointer;text-align:left;font-family:var(--font-family);transition:border-color var(--duration-fast),background var(--duration-fast)}.product-picker-item:hover{border-color:var(--primary-btn);background:#3b82f61a}.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}.selected-product-display{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:16px}.selected-product-info{display:flex;flex-direction:column;gap:2px}.selected-product-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.selected-product-name{font-size:15px;font-weight:600;color:var(--text-primary)}.auto-opened-badge{display:inline-block;padding:4px 14px;background:linear-gradient(135deg,var(--success-500),var(--success-600));color:#fff;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);margin-bottom:8px}.item-number-display--opened{background:var(--success-50);border-color:#10b9814d}.item-number-display--opened p,.item-number-display--opened .item-number,.item-number-display--opened .item-numbers-list .item-number{color:var(--success-600)}.auto-open-hint{margin-top:12px}.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}.search-link-container{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.btn-full{width:100%}.product-search-results{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.product-search-item{display:block;width:100%;text-align:left;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-family);color:var(--text-primary);transition:all var(--duration-normal) var(--ease-smooth)}.product-search-item:hover:not(:disabled){border-color:var(--primary-btn);background:var(--bg-card)}.product-search-item:disabled{opacity:.6;cursor:not-allowed}.product-search-name{font-weight:600;font-size:15px;margin-bottom:4px}.product-search-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;color:var(--text-muted)}.product-search-barcode{font-family:monospace;font-size:12px}.product-search-count{color:var(--primary-btn);font-weight:500}.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}}.supplier-docs-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.supplier-docs-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.supplier-docs-group{margin-bottom:12px}.supplier-docs-supplier-name{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}.supplier-docs-list{display:flex;flex-direction:column;gap:6px}.supplier-doc-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);gap:12px}.supplier-doc-row-info{display:flex;flex-direction:column;min-width:0}.supplier-doc-type-label{font-size:13px;font-weight:600;color:var(--text-primary)}.supplier-doc-file-info{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.supplier-doc-badges{display:inline-flex;gap:4px;flex-wrap:wrap}.supplier-doc-badge{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:20px;padding:0 5px;font-size:10px;font-weight:700;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);color:var(--text-muted);background:var(--bg-elevated);cursor:default}.supplier-doc-badge.has-doc{border-color:var(--success-600);color:var(--success-600);background:var(--success-50);cursor:pointer}.supplier-doc-badge.has-doc:hover{background:var(--success-100, rgba(16, 185, 129, .15))}.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(--warning-500)}.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);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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;min-width:1100px}.supply-table th,.supply-table td{white-space:nowrap}.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;font-size:14px;color:var(--text-primary);transition:background var(--duration-fast) var(--ease-smooth)}.supply-row-primary td{border-top:1px solid var(--border-color)}.supply-row-secondary td{padding:0 12px 10px}.secondary-details{display:flex;flex-wrap:wrap;gap:4px 20px;font-size:12px;color:var(--text-muted)}.secondary-label{font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:10px;margin-right:4px;color:var(--text-muted);opacity:.7}.supply-table tbody tr:nth-child(4n+3) td,.supply-table tbody tr:nth-child(4n+4) td{background:var(--bg-elevated)}.supply-row-primary:hover td,.supply-row-primary:hover+.supply-row-secondary td,.supply-row-secondary:hover td{background:var(--primary-bg)}.supply-table tbody tr.supply-row-secondary:hover td{background:var(--primary-bg)}.supply-row-primary,.supply-row-secondary{animation:staggerIn .3s var(--ease-smooth) both}.supply-table tbody tr:nth-child(1),.supply-table tbody tr:nth-child(2){animation-delay:0ms}.supply-table tbody tr:nth-child(3),.supply-table tbody tr:nth-child(4){animation-delay:30ms}.supply-table tbody tr:nth-child(5),.supply-table tbody tr:nth-child(6){animation-delay:60ms}.supply-table tbody tr:nth-child(7),.supply-table tbody tr:nth-child(8){animation-delay:90ms}.supply-table tbody tr:nth-child(9),.supply-table tbody tr:nth-child(10){animation-delay:.12s}.supply-table tbody tr:nth-child(11),.supply-table tbody tr:nth-child(12){animation-delay:.15s}.supply-table tbody tr:nth-child(13),.supply-table tbody tr:nth-child(14){animation-delay:.18s}.supply-table tbody tr:nth-child(15),.supply-table tbody tr:nth-child(16){animation-delay:.21s}.supply-table tbody tr:nth-child(17),.supply-table tbody tr:nth-child(18){animation-delay:.24s}.supply-table tbody tr:nth-child(19),.supply-table tbody tr:nth-child(20){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(--warning-100);color:var(--warning-700);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;max-height:calc(100vh - 40px);overflow-y:auto;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(--warning-100);color:var(--warning-700);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(--warning-100);color:var(--warning-700)}.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(--warning-100);color:var(--warning-600)}[data-theme=dark] .expiring-section-title--expired{background:#dc26261f;color:var(--error-500)}[data-theme=dark] .expiring-section-title--critical{background:#ea580c1f;color:var(--warning-500)}[data-theme=dark] .expiring-section-title--warning{background:#eab3081a;color:var(--warning-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-500);background:var(--error-50)}.expiring-item--critical{border-left-color:var(--warning-500);background:var(--warning-50)}.expiring-item--warning{border-left-color:var(--warning-500);background:var(--warning-100)}[data-theme=dark] .expiring-item--expired{background:#dc26261f}[data-theme=dark] .expiring-item--critical{background:#ea580c1f}[data-theme=dark] .expiring-item--warning{background:#eab3081a}.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(--warning-100);color:var(--warning-600)}@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}}.profile-page .designation-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-md);font-size:11px;font-weight:600;margin-right:4px;text-transform:uppercase;letter-spacing:.5px}.profile-page .designation-badge.prrc{background:var(--warning-100);color:var(--warning-600)}.profile-page .designation-badge.vigilance{background:var(--info-100);color:var(--info-600)}.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;justify-content:flex-end}.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(--warning-100);color:var(--warning-600)}.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{padding:24px 16px}.invite-link-section{background:var(--bg-elevated);color:var(--text-primary);padding:24px;border-radius:var(--radius-lg);margin-bottom:28px;border:1px solid var(--border-color);border-left:3px solid var(--primary-500)}.invite-link-label{font-size:11px;color:var(--text-muted);margin-bottom:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.invite-link-display{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:10px 14px;font-family:Courier New,monospace;font-size:13px;word-break:break-all;margin-bottom:10px;color:var(--text-primary)}.invite-link-hint{font-size:13px;color:var(--text-muted);margin-bottom:18px}.expiry-tag{opacity:.75;font-style:italic}.link-actions{display:flex;gap:10px;flex-wrap:wrap}.btn-invite-action{border:1.5px solid var(--border-color);padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-family:var(--font-family);font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);background:transparent;color:var(--text-secondary)}.btn-copy{background:var(--primary-bg);color:var(--primary-text);border-color:var(--primary-border)}.btn-copy:hover{background:var(--primary-bg-hover)}.btn-share{background:transparent;color:var(--text-secondary)}.btn-share:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-regenerate{background:transparent;color:var(--error-500);border-color:var(--error-500);margin-left:auto}.btn-regenerate:hover:not(:disabled){background:#ef44441a}.btn-regenerate:disabled{opacity:.4;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(--warning-100);color:var(--warning-600)}.btn-reset:hover{background:var(--warning-50)}.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)}.designation-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-md);font-size:11px;font-weight:600;margin-left:4px;text-transform:uppercase;letter-spacing:.5px}.designation-badge.prrc{background:var(--warning-100);color:var(--warning-600)}.designation-badge.vigilance{background:var(--info-100);color:var(--info-600)}.designation-warning{background:var(--warning-100);border:1px solid var(--warning-500);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:16px;font-size:13px;color:var(--warning-700)}.designation-warning p{margin:0}.designation-warning p+p{margin-top:4px}.designation-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.designation-section-title{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:4px}.designation-section-hint{font-size:12px;color:var(--text-muted);margin-bottom:12px}.designation-checkbox{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:var(--radius-md);cursor:pointer;margin-bottom:4px}.designation-checkbox:hover{background:var(--bg-elevated)}.designation-checkbox input[type=checkbox]{margin-top:3px;width:16px;height:16px;flex-shrink:0}.designation-checkbox-title{font-weight:500;font-size:14px;color:var(--text-primary)}.designation-checkbox-desc{font-size:12px;color:var(--text-muted)}.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)}.role-option.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}@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{--sa-bg-base: #0f172a;--sa-bg-card: #1e293b;--sa-bg-elevated: #273447;--sa-border: #334155;--sa-text-primary: #f1f5f9;--sa-text-secondary: #94a3b8;--sa-text-muted: #64748b;--sa-accent-blue: #60a5fa;--sa-accent-green: #22c55e;--sa-accent-amber: #f59e0b;--sa-accent-red: #ef4444;--sa-accent-orange: #f97316;--sa-accent-purple: #a78bfa;min-height:100vh;background:var(--sa-bg-base);color:#e2e8f0;padding-bottom:48px}.sa-header{background:var(--sa-bg-card);border-bottom:1px solid var(--sa-border);padding:16px 0}.sa-subtitle{color:var(--sa-text-secondary);font-size:14px;margin:0}.sa-nav{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.sa-nav-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;font-family:var(--font-family);color:var(--sa-text-secondary);background:var(--sa-bg-elevated);border:1px solid var(--sa-border);border-radius:var(--radius-full);text-decoration:none;transition:all .15s;white-space:nowrap}.sa-nav-btn:hover{color:var(--sa-text-primary);background:var(--sa-border);border-color:var(--sa-accent-blue)}.sa-nav-btn-active{color:#fff;background:var(--sa-accent-blue);border-color:var(--sa-accent-blue)}.sa-nav-btn-active:hover{background:#4d94f8}.super-admin>main.container{padding-top:20px}.sa-back{background:none;border:none;color:var(--sa-text-secondary);cursor:pointer;font-size:14px;padding:0 0 4px;display:block}.sa-back:hover{color:var(--sa-text-primary)}.sa-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 16px}.sa-kpi-card{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-left:3px solid var(--sa-border);border-radius:var(--radius-md);padding:12px 14px 8px;transition:background-color .2s,box-shadow .2s;text-decoration:none;color:inherit;display:block}.sa-kpi-card:hover{background:var(--sa-bg-elevated);box-shadow:0 4px 12px #0000004d}.sa-kpi-card-link{cursor:pointer}.sa-kpi-card-link:hover{border-color:#ffffff26}.sa-kpi-header{display:flex;align-items:center;gap:6px}.sa-kpi-icon{font-size:14px;line-height:1}.sa-kpi-label{color:var(--sa-text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;flex:1}.sa-kpi-today{display:inline-flex;align-items:center;font-size:11px;font-weight:600;color:var(--sa-accent-green);background:#22c55e1f;border-radius:4px;padding:1px 6px;line-height:1.4;flex-shrink:0}.sa-kpi-number{font-size:32px;font-weight:700;color:var(--sa-text-primary);line-height:1;display:flex;align-items:center;gap:8px;margin:4px 0 2px}.sa-kpi-breakdown{font-size:11px;color:var(--sa-text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sa-kpi-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--sa-accent-amber);animation:sa-pulse 2s ease-in-out infinite}@keyframes sa-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.sa-minichart{width:100%;height:64px;margin-top:6px}.sa-minichart .recharts-tooltip-wrapper{z-index:10}.sa-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.sa-charts-row-triple{grid-template-columns:1fr 1fr 1fr}.sa-chart-panel{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column}.sa-chart-title{font-size:15px;font-weight:600;color:var(--sa-text-primary);margin:0 0 12px;display:flex;align-items:center;gap:8px}.sa-chart-subtitle{font-size:12px;font-weight:400;color:var(--sa-text-muted)}.sa-chart-container{height:180px;display:flex;align-items:center;justify-content:center}.sa-chart-container-pie{height:160px}.sa-chart-content-row{display:flex;gap:16px;align-items:center;flex:1}.sa-chart-content-row .sa-chart-container-pie{flex:1;min-width:0}.sa-chart-empty{color:var(--sa-text-muted);font-size:14px;text-align:center}.sa-chart-legend{display:flex;flex-direction:column;gap:8px;min-width:120px}.sa-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.sa-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sa-legend-label{color:var(--sa-text-secondary);flex:1}.sa-legend-value{color:var(--sa-text-primary);font-weight:600;font-variant-numeric:tabular-nums}.sa-legend-pct{color:var(--sa-text-muted);font-size:11px;min-width:32px;text-align:right}.sa-badge-count{display:inline-flex;align-items:center;justify-content:center;background:var(--sa-accent-orange);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;padding:0 6px;border-radius:10px}.sa-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.sa-two-col-stretch{align-items:stretch}.sa-two-col-stretch>.sa-section{display:flex;flex-direction:column}.sa-two-col-stretch .sa-table-wrap{flex:1}.sa-section-flex{display:flex;flex-direction:column}.sa-table-scroll{max-height:400px;overflow-y:auto}.sa-pending-list{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto;max-height:280px}.sa-pending-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);text-decoration:none;color:inherit;transition:background-color .15s}.sa-pending-item:hover{background:var(--sa-bg-elevated)}.sa-pending-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sa-pending-info{display:flex;flex-direction:column;gap:2px;min-width:0}.sa-pending-name{font-size:13px;font-weight:500;color:var(--sa-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sa-pending-meta{font-size:11px;color:var(--sa-text-muted)}.sa-pending-empty{color:var(--sa-text-muted);font-size:14px;text-align:center;padding:32px 0}.sa-pending-more{font-size:12px;color:var(--sa-text-muted);text-align:center;padding:8px 0}.sa-activity-feed{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);padding:8px 0;max-height:280px;overflow-y:auto}.sa-activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 20px;transition:background-color .15s}.sa-activity-item:hover{background:var(--sa-bg-elevated)}.sa-activity-dot{width:6px;height:6px;border-radius:50%;background:var(--sa-accent-blue);flex-shrink:0;margin-top:7px}.sa-activity-content{flex:1;min-width:0;font-size:13px;line-height:1.4}.sa-activity-action{color:var(--sa-text-primary);font-weight:500}.sa-activity-resource{color:var(--sa-text-muted)}.sa-activity-actor{display:block;color:var(--sa-text-muted);font-size:12px;margin-top:2px}.sa-activity-time{color:var(--sa-text-muted);font-size:12px;white-space:nowrap;flex-shrink:0}.sa-activity-empty{color:var(--sa-text-muted);font-size:14px;text-align:center;padding:24px 0}.sa-filter-pills{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.sa-filter-pill{background:transparent;border:1px solid var(--sa-border);border-radius:var(--radius-full);color:var(--sa-text-secondary);font-size:13px;font-family:var(--font-family);padding:5px 14px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.sa-filter-pill:hover{background:var(--sa-bg-elevated);color:var(--sa-text-primary)}.sa-filter-pill-active{background:var(--sa-accent-blue);border-color:var(--sa-accent-blue);color:#fff}.sa-filter-pill-active:hover{background:#4d94f8;color:#fff}.sa-filter-count{font-size:11px;font-weight:600;opacity:.8}.sa-quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.sa-quick-link{display:flex;align-items:center;gap:10px;background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);padding:14px 16px;color:var(--sa-text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all .15s}.sa-quick-link:hover{background:var(--sa-bg-elevated);color:var(--sa-text-primary);border-color:var(--sa-accent-blue)}.sa-quick-link-icon{font-size:18px}.sa-section{margin:24px 0}.sa-section-no-margin{margin: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:var(--sa-text-primary);margin:0 0 12px}.sa-section-header h2{margin:0}.sa-search{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-sm);color:#e2e8f0;padding:8px 12px;font-size:14px;font-family:var(--font-family);width:240px}.sa-search::placeholder{color:var(--sa-text-muted)}.sa-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--sa-border)}.sa-table{width:100%;border-collapse:collapse;background:var(--sa-bg-card)}.sa-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--sa-text-muted);border-bottom:1px solid var(--sa-border);background:var(--sa-bg-base)}.sa-table td{padding:12px 16px;font-size:14px;color:#cbd5e1;border-bottom:1px solid var(--sa-bg-card)}.sa-table tr:last-child td{border-bottom:none}.sa-table tr:hover td{background:var(--sa-bg-elevated)}.sa-clinic-name{font-weight:500;color:var(--sa-text-primary)}.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:var(--sa-text-muted);padding:32px!important}.sa-link{color:var(--sa-accent-blue);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:var(--sa-bg-card);border:1px solid var(--sa-border);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:var(--sa-text-primary);margin:0}.sa-panel p{margin:0;font-size:14px;color:var(--sa-text-secondary)}.sa-select,.sa-input{background:var(--sa-bg-base);border:1px solid var(--sa-border);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:var(--sa-accent-amber)}@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:var(--sa-text-secondary);background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);padding:12px 16px}.sa-ticket-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:8px}.sa-empty-widget{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);padding:24px;text-align:center;color:var(--sa-text-muted);font-size:14px}.sa-filters-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.sa-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sa-sortable:hover{color:#e2e8f0}.sa-panel-wrap{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column}.sa-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--sa-bg-elevated);border-bottom:1px solid var(--sa-border);min-height:40px}.sa-panel-header h3{font-size:13px;font-weight:600;color:var(--sa-text-primary);margin:0;text-transform:uppercase;letter-spacing:.04em}.sa-panel-header-right{display:flex;align-items:center;gap:4px}.sa-panel-body{padding:12px 16px;flex:1;overflow-y:auto}.sa-panel-body .sa-table-wrap{border:none;border-radius:0}.sa-panel-body .sa-table th{background:var(--sa-bg-card)}.sa-insights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.sa-engagement-stats{display:flex;justify-content:space-around;margin:8px 0}.sa-engagement-item{display:flex;flex-direction:column;align-items:center;gap:2px}.sa-engagement-number{font-size:24px;font-weight:700;color:var(--sa-text-primary)}.sa-engagement-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--sa-text-muted)}.sa-engagement-bar{position:relative;height:6px;background:var(--sa-bg-base);border-radius:3px;overflow:hidden;margin-top:8px}.sa-engagement-fill{position:absolute;top:0;left:0;height:100%;border-radius:3px}.sa-engagement-fill-30d{background:var(--sa-accent-green);opacity:.4}.sa-engagement-fill-7d{background:var(--sa-accent-blue);z-index:1}.sa-health-score{display:flex;align-items:center;gap:8px;min-width:80px}.sa-health-bar{flex:1;height:6px;background:var(--sa-bg-base);border-radius:3px;overflow:hidden}.sa-health-fill{height:100%;border-radius:3px;transition:width .3s}@media(max-width:1200px){.sa-kpi-grid{grid-template-columns:repeat(3,1fr)}.sa-charts-row-triple{grid-template-columns:1fr 1fr}.sa-insights-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sa-kpi-grid{grid-template-columns:repeat(2,1fr)}.sa-charts-row,.sa-charts-row-triple,.sa-two-col,.sa-insights-grid{grid-template-columns:1fr}.sa-chart-content-row{flex-direction:column}.sa-chart-legend{flex-direction:row;flex-wrap:wrap;gap:12px}.sa-quick-links{grid-template-columns:repeat(2,1fr)}.sa-kpi-number{font-size:28px}}@media(max-width:480px){.sa-kpi-grid{grid-template-columns:1fr 1fr;gap:8px}.sa-kpi-number{font-size:24px}.sa-kpi-breakdown{font-size:10px}.sa-quick-links{grid-template-columns:1fr}.sa-search{width:100%}.sa-section-header{flex-direction:column;align-items:flex-start;gap:8px}}.help-page{min-height:100vh;background:var(--bg-page);transition:background-color var(--duration-slow)}.help-main{padding-top:20px;padding-bottom:64px;max-width:960px;margin:0 auto}.help-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-bottom:28px}.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-hero{text-align:center;padding:24px 0 28px}.help-hero-title{font-family:var(--font-family);font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 20px;letter-spacing:-.01em;line-height:1.2}.help-search-bar{position:relative;display:flex;align-items:center;max-width:520px;margin:0 auto;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);padding:0 16px;box-shadow:var(--shadow-sm);transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.help-search-bar:focus-within{border-color:var(--primary-btn);box-shadow:0 0 0 3px var(--primary-bg)}.help-search-icon{flex-shrink:0;color:var(--text-muted);margin-right:10px}.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;padding:4px 6px;border-radius:4px;display:flex;align-items:center;transition:background var(--duration-fast),color var(--duration-fast)}.help-search-clear:hover{background:var(--bg-elevated);color:var(--text-primary)}.help-search-kbd{font-family:var(--font-family);font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;padding:2px 7px;line-height:1.4}.help-chips-wrap{position:relative;margin-bottom:24px}.help-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:4px 0}@media(max-width:640px){.help-chips{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.help-chips::-webkit-scrollbar{display:none}.help-chips:after{content:"";flex-shrink:0;width:1px}}.help-chip{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:8px 14px;border-radius:var(--radius-full);border:1.5px solid var(--border-color);background:var(--bg-card);font-family:var(--font-family);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);flex-shrink:0}.help-chip:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-elevated)}.help-chip-active{background:var(--primary-bg);border-color:var(--primary-border);color:var(--primary-text);font-weight:600}.help-chip-active:hover{background:var(--primary-bg-hover);border-color:var(--primary-border);color:var(--primary-text)}.help-chip-emoji{font-size:15px;line-height:1}.help-chip-count{font-size:11px;font-weight:600;background:var(--bg-elevated);color:var(--text-muted);padding:1px 6px;border-radius:var(--radius-full);line-height:1.4}.help-chip-active .help-chip-count{background:var(--primary-bg-hover);color:var(--primary-text)}.help-search-result-info{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.help-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(max-width:640px){.help-grid{grid-template-columns:1fr}}@keyframes helpCardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.help-card{display:flex;align-items:flex-start;gap:14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:18px;cursor:pointer;text-align:left;width:100%;animation:helpCardIn .3s var(--ease-smooth) both;transition:border-color var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth),transform var(--duration-fast) var(--ease-smooth)}.help-card:hover{border-color:var(--primary-border);box-shadow:var(--shadow-md);transform:translateY(-2px)}.help-card-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);color:var(--primary-text);border-radius:var(--radius-sm)}.help-card-body{flex:1;min-width:0}.help-card-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 4px;line-height:1.3}.help-card-excerpt{font-size:13px;color:var(--text-muted);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.help-card-arrow{color:var(--text-muted);flex-shrink:0;margin-top:2px;transition:transform var(--duration-fast),color var(--duration-fast)}.help-card:hover .help-card-arrow{color:var(--primary-text);transform:translate(3px)}.help-article-view{max-width:720px;animation:helpCardIn .25s var(--ease-smooth) both}.help-back-btn{background:none;border:none;color:var(--primary-text);font-size:14px;font-family:var(--font-family);font-weight:500;cursor:pointer;padding:0;margin-bottom:20px;display:inline-flex;align-items:center;gap:6px;transition:opacity var(--duration-fast)}.help-back-btn:hover{opacity:.7}.help-article-detail{background:var(--bg-card);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.help-article-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.help-article-icon{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);color:var(--primary-text);border-radius:var(--radius-md)}.help-article-category-tag{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-text);margin-bottom:6px}.help-article-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.help-article-body{color:var(--text-primary);line-height:1.75}.help-article-para{margin:0 0 12px;font-size:15px}.help-article-para:last-child{margin-bottom:0}.help-section-heading{font-size:16px;font-weight:700;color:var(--text-primary);margin:28px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.help-section-heading:first-child{margin-top:0}.help-step{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}.help-step-number{flex-shrink:0;width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);color:var(--primary-text);font-size:13px;font-weight:700;border-radius:50%;margin-top:1px}.help-step-text{font-size:15px;line-height:1.6;padding-top:2px}.help-faq-list{display:flex;flex-direction:column;gap:8px}.help-faq-item{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--duration-fast) var(--ease-smooth)}.help-faq-open{border-color:var(--primary-border)}.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 var(--duration-fast)}.help-faq-question:hover{background:var(--bg-elevated)}.help-faq-chevron{color:var(--text-muted);flex-shrink:0;transition:color var(--duration-fast),transform var(--duration-fast)}.help-faq-open .help-faq-chevron{color:var(--primary-text)}.help-faq-answer-wrap{max-height:0;overflow:hidden;transition:max-height .3s var(--ease-smooth)}.help-faq-answer-open{max-height:400px}.help-faq-answer{padding:12px 16px 14px;font-size:14px;color:var(--text-secondary);line-height:1.65;border-top:1px solid var(--border-color)}.help-article-feedback{display:flex;align-items:center;gap:12px;margin-top:32px;padding-top:20px;border-top:1px solid var(--border-color);flex-wrap:wrap}.help-feedback-label{font-size:14px;color:var(--text-secondary)}.help-feedback-actions{display:flex;gap:8px}.help-feedback-btn{background:none;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 16px;font-size:14px;font-family:var(--font-family);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth)}.help-feedback-yes:hover{background:var(--success-50);border-color:var(--success-500);color:var(--success-600)}.help-feedback-no:hover{background:var(--error-50);border-color:var(--error-500);color:var(--error-600)}.help-feedback-thanks{font-size:14px;color:var(--success-500);font-weight:500;margin:0}.help-loading{padding:64px 0;text-align:center;color:var(--text-muted);font-size:15px}.help-empty-state{text-align:center;padding:56px 20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.help-empty-icon{color:var(--text-muted);margin-bottom:12px}.help-empty-state p{color:var(--text-secondary);font-size:15px;margin:0 0 16px}.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:16px 18px;cursor:pointer;text-align:left;width:100%;transition:border-color var(--duration-fast),box-shadow var(--duration-fast),transform var(--duration-fast)}.st-ticket-row:hover{border-color:var(--primary-border);box-shadow:var(--shadow-md);transform:translateY(-1px)}.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;animation:helpCardIn .25s var(--ease-smooth) both}.st-detail-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:16px}.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);border:1px solid var(--border-color);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:var(--primary-border)}.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;transition:border-color var(--duration-fast)}.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}@media(max-width:640px){.help-hero-title{font-size:24px}.help-article-detail{padding:24px 18px}.help-article-title{font-size:19px}.help-article-header{gap:12px}.help-article-icon{width:44px;height:44px;font-size:28px}}.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-detail-3col{display:grid;grid-template-columns:15% 45% 40%;gap:16px;margin:24px 0;align-items:start}.sat-col-details{font-size:13px}.sat-detail-list{display:flex;flex-direction:column;gap:10px}.sat-detail-row{display:flex;flex-direction:column;gap:2px}.sat-detail-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:600}.sat-detail-val{color:#cbd5e1;font-size:13px;word-break:break-word}.sat-detail-mono{font-family:monospace;font-size:12px}.sat-col-context{overflow:hidden}.sat-col-comments{display:flex;flex-direction:column}.sat-comment-input-col{display:flex;flex-direction:column;gap:8px}.sat-comment-input-col .sa-input{resize:vertical;min-height:120px}@media(max-width:1100px){.sat-detail-3col{grid-template-columns:1fr 1fr}.sat-col-details{grid-column:1 / -1}}@media(max-width:768px){.sat-detail-3col{grid-template-columns:1fr}}.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}.doc-manager-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.doc-manager-card{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-md);padding:16px;position:relative;transition:border-color var(--duration-fast)}.doc-manager-card.has-doc{border-color:var(--success-600)}.doc-manager-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.doc-manager-card-type{font-size:14px;font-weight:600;color:var(--text-primary)}.doc-manager-card-body{position:relative}.doc-manager-file-info{display:flex;align-items:baseline;gap:8px;margin-bottom:10px;padding:8px 10px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.doc-manager-file-name{font-size:13px;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.doc-manager-file-size{font-size:11px;color:var(--text-muted);flex-shrink:0}.doc-manager-actions{display:flex;gap:6px;flex-wrap:wrap}.doc-manager-actions .btn{font-size:12px;padding:5px 10px}.doc-manager-drop-overlay{position:absolute;inset:0;border-radius:var(--radius-md);z-index:2;pointer-events:none}.doc-manager-drop-overlay.active{pointer-events:auto;background:#0ea5e91f;border:2px dashed var(--primary-btn)}.doc-manager-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:24px 16px;text-align:center;cursor:pointer;transition:all var(--duration-fast);min-height:100px;display:flex;align-items:center;justify-content:center}.doc-manager-dropzone:hover,.doc-manager-dropzone.dragover{border-color:var(--primary-btn);background:var(--primary-bg)}.doc-manager-dropzone.uploading{opacity:.7;cursor:wait}.doc-manager-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:4px}.doc-manager-dropzone-icon{font-size:28px;line-height:1;color:var(--text-muted)}.doc-manager-dropzone-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.doc-manager-dropzone-hint{font-size:12px;color:var(--text-muted)}.doc-manager-dropzone-formats{font-size:11px;color:var(--text-disabled);margin-top:2px}@media(max-width:640px){.doc-manager-grid{grid-template-columns:1fr}}.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:var(--error-500);background:var(--error-50)}.ad-card.ad-row-soon{border-left-color:var(--warning-500);background:var(--warning-50)}.ad-card.ad-row-upcoming{border-left-color:var(--warning-600);background:var(--warning-100)}[data-theme=dark] .ad-card.ad-row-critical{background:#ef44441a}[data-theme=dark] .ad-card.ad-row-soon{background:#f59e0b1a}[data-theme=dark] .ad-card.ad-row-upcoming{background:#d9770614}.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:var(--error-500);animation:ad-pulse 2s infinite}.ad-countdown-label.ad-row-soon{color:var(--warning-500)}.ad-countdown-label.ad-row-upcoming{color:var(--warning-600)}@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:var(--info-100);color:var(--info-600)}.status-opened{background:var(--success-50);color:var(--success-600)}.status-depleted{background:var(--bg-elevated);color:var(--text-muted)}[data-theme=dark] .status-purchased{background:#3b82f626;color:var(--info-500)}[data-theme=dark] .status-opened{background:#22c55e26;color:var(--success-500)}[data-theme=dark] .status-depleted{background:#6b728026;color:var(--text-disabled)}@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(--warning-100);color:var(--warning-700)}.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(--warning-600)}.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(--warning-700)}.budget-pct--warning{color:var(--warning-600)}.budget-pct--danger{color:var(--error-600)}.costs-vat-card,.vat-rate-group{margin-bottom:20px}.vat-rate-group label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:var(--text-secondary)}.vat-rate-group .cost-input-wrapper{width:120px}.vat-toggle-group{margin-bottom:20px}.vat-edit-section{display:flex;flex-direction:column;gap:16px}.vat-info{display:flex;align-items:center;gap:12px}.vat-rate-display{font-size:20px;font-weight:700;color:var(--text-primary)}.costs-summary-grid--vat{border-top:2px solid var(--border-color);padding-top:16px;margin-top:-8px}.cost-card--net .cost-card-value{color:var(--success-600)}.cost-card--gross .cost-card-value{color:var(--primary-btn)}.cost-card--vat .cost-card-value{color:var(--text-secondary)}.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;padding:11px 14px;font-size:15px;font-family:var(--font-family);font-variant-numeric:tabular-nums;text-align:right;color:var(--text-primary);background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.cost-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}@media(min-width:1024px){.suppliers-list{grid-template-columns:repeat(4,1fr)}}@media(min-width:1400px){.suppliers-list{grid-template-columns:repeat(5,1fr)}}.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,transform .15s;display:flex;flex-direction:column;min-height:140px}.supplier-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.supplier-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.supplier-card-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.supplier-card-name h3{display:flex;align-items:center;gap:6px}.supplier-vat{font-size:11px;color:var(--text-muted);font-family:monospace;word-break:break-all;margin-bottom:8px}.supplier-card-details{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary);margin-top:auto}.supplier-card-details span{display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.supplier-lock-icon{color:var(--text-muted);flex-shrink:0}.supplier-card-actions{flex-shrink:0;margin-left:4px}.supplier-edit-btn{padding:3px 6px!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)}.products-search{margin-bottom:16px;display:flex;gap:10px;align-items:stretch}.products-search .search-wrapper{position:relative;flex:1}.category-filter-select{min-width:140px;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);font-size:.875rem}@media(max-width:480px){.products-search{flex-direction:column}}.products-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.products-search .search-input-full{width:100%;padding-left:36px}.products-search .search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.products-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}@media(min-width:1024px){.products-list{grid-template-columns:repeat(4,1fr)}}@media(min-width:1400px){.products-list{grid-template-columns:repeat(5,1fr)}}.product-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column;min-height:140px}.product-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.product-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.product-card-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-name{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.product-clinic-badge{font-size:10px;padding:1px 7px;border-radius:10px;background:var(--bg-elevated);color:var(--text-muted);font-weight:500;white-space:nowrap;align-self:flex-start}.product-card-actions{flex-shrink:0;margin-left:4px}.product-edit-btn{padding:3px 6px!important;min-width:unset!important}.product-card-details{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary);margin-bottom:10px;flex:1}.product-card-details span{display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-card-suppliers{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.supplier-overflow{flex-shrink:0;font-size:10px;padding:0 5px;border-radius:8px;background:var(--bg-elevated);color:var(--text-secondary);font-weight:600}.product-card-counts{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}.count-badge{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}.count-stock{background:#e8f5e9;color:#2e7d32}[data-theme=dark] .count-stock{background:#2e7d3233;color:#81c784}.count-use{background:#e3f2fd;color:#1565c0}[data-theme=dark] .count-use{background:#1565c033;color:#64b5f6}.count-none{background:var(--bg-elevated);color:var(--text-muted)}.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:480px){.product-detail-grid{grid-template-columns:1fr}}.product-detail-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;display:block}.product-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-mode-toggle{display:flex;gap:0;margin-bottom:16px;border:1px solid var(--border-color);border-radius:var(--radius-sm, 6px);overflow:hidden;width:fit-content}.recall-mode-btn{padding:8px 20px;border:none;background:var(--bg-elevated);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.recall-mode-btn:not(:last-child){border-right:1px solid var(--border-color)}.recall-mode-btn:hover{background:var(--bg-card);color:var(--text-primary)}.recall-mode-btn--active,.recall-mode-btn--active:hover{background:var(--primary-btn);color:#fff}.recall-search-input-row{display:flex;gap:12px}.recall-search-input-row input{flex:1;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}.recall-search-input-row input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.recall-search-input-row input::placeholder{color:var(--text-disabled)}.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:var(--warning-50);color:var(--warning-600);border:1px solid var(--warning-500)}[data-theme=dark] .recall-count-banner--active{background:#f59e0b1f;color:var(--warning-500);border-color:#f59e0b4d}.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-checkbox-col{width:40px;text-align:center}.recall-checkbox-col input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-btn)}.recall-preview-table tr.recall-row--selected{background:#0ea5e90f}[data-theme=dark] .recall-preview-table tr.recall-row--selected{background:#0ea5e91a}.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;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}.recall-reason-field input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.recall-reason-field input::placeholder{color:var(--text-disabled)}.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:var(--warning-100);color:var(--warning-600)}[data-theme=dark] .badge-orange{background:#f59e0b2e;color:var(--warning-500)}.recall-row--undone{opacity:.6}.recall-undo-confirm{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-secondary)}.recall-undone-banner{display:flex;align-items:center;gap:10px;font-size:14px}.recall-undone-date{color:var(--text-muted);font-size:13px}.badge-muted{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border-color)}.btn-warning{background:var(--warning-500);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm, 6px);font-weight:600;cursor:pointer;transition:background .15s}.btn-warning:hover{background:var(--warning-600)}.btn-warning:disabled{opacity:.5;cursor:not-allowed}@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}}.manufacturers-search{margin-bottom:16px}.manufacturers-search .search-wrapper{position:relative}.manufacturers-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.manufacturers-search .search-input-full{width:100%;padding-left:36px}.manufacturers-search .search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.manufacturers-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}@media(min-width:1024px){.manufacturers-list{grid-template-columns:repeat(4,1fr)}}@media(min-width:1400px){.manufacturers-list{grid-template-columns:repeat(5,1fr)}}.manufacturer-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column;min-height:120px}.manufacturer-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.manufacturer-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.manufacturer-card-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.manufacturer-card-name h3{display:flex;align-items:center;gap:6px}.manufacturer-country{font-size:12px;color:var(--text-muted);margin-bottom:8px}.manufacturer-card-details{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary);margin-top:auto}.manufacturer-card-details span{display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manufacturer-lock-icon{color:var(--text-muted);flex-shrink:0}.manufacturer-card-actions{flex-shrink:0;margin-left:4px}.manufacturer-edit-btn{padding:3px 6px!important;min-width:unset!important}.manufacturer-edit-btn:disabled{opacity:.4;cursor:not-allowed}.manufacturer-edits-remaining{font-size:13px;color:var(--text-muted);margin-bottom:12px;padding:6px 10px;background:var(--bg-elevated);border-radius:var(--radius-md)}.manufacturer-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:480px){.manufacturer-detail-grid{grid-template-columns:1fr}}.manufacturer-detail-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;display:block}.manufacturer-detail-value{font-size:14px;color:var(--text-primary)}.entity-detail-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:0;margin-bottom:16px;transition:color .15s}.entity-detail-back:hover{color:var(--text-primary)}.entity-detail-header{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;margin-bottom:16px}.entity-detail-header h2{margin:0 0 12px;font-size:20px;font-weight:700;color:var(--text-primary)}.entity-detail-info{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--text-secondary)}.entity-detail-info span{display:inline-flex;align-items:center;gap:4px}.entity-detail-info a{color:var(--primary-btn);text-decoration:none}.entity-detail-info a:hover{text-decoration:underline}.entity-detail-badge{display:inline-flex;align-items:center;gap:4px;background:var(--bg-elevated);padding:2px 8px;border-radius:var(--radius-sm, 4px);font-size:12px;color:var(--text-secondary)}.entity-detail-toolbar{display:flex;gap:10px;margin-bottom:10px;align-items:stretch}.entity-detail-toolbar .search-wrapper{flex:1;position:relative}.entity-detail-toolbar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.entity-detail-toolbar .search-input-full{width:100%;padding-left:36px}.entity-detail-toolbar .search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.entity-detail-filters{display:flex;gap:8px}.entity-detail-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);font-size:13px;min-width:140px}.entity-detail-sort-bar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.entity-detail-sort-label{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.entity-detail-sort-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px 10px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.entity-detail-sort-btn:hover{border-color:var(--primary-btn);color:var(--primary-btn)}.entity-detail-sort-btn.active{background:var(--primary-btn);border-color:var(--primary-btn);color:#fff}.entity-detail-products{display:flex;flex-direction:column;gap:8px}.entity-detail-product-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 16px;display:flex;align-items:center;gap:16px;transition:box-shadow .15s}.entity-detail-product-card:hover{box-shadow:var(--shadow-sm)}.entity-detail-product-name{flex:1;min-width:0}.entity-detail-product-name h4{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entity-detail-barcode{font-size:11px;color:var(--text-muted);font-family:monospace}.entity-detail-product-meta{display:flex;gap:12px;font-size:12px;color:var(--text-secondary);flex-shrink:0}.entity-detail-product-meta span{display:inline-flex;align-items:center;gap:3px;white-space:nowrap}.entity-detail-product-stock{display:flex;gap:6px;flex-shrink:0}.entity-detail-product-stock .stock-badge{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}.entity-detail-product-stock .stock-purchased{background:#dbeafe;color:#1d4ed8}.entity-detail-product-stock .stock-opened{background:#fef3c7;color:#92400e}[data-theme=dark] .entity-detail-product-stock .stock-purchased{background:#3b82f626;color:#93bbfd}[data-theme=dark] .entity-detail-product-stock .stock-opened{background:#f59e0b26;color:#fbbf24}@media(max-width:640px){.entity-detail-toolbar{flex-direction:column}.entity-detail-product-card{flex-direction:column;align-items:flex-start;gap:8px}.entity-detail-product-meta{flex-wrap:wrap}.entity-detail-product-stock{align-self:flex-end}.entity-detail-info{flex-direction:column;gap:6px}}.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);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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(--warning-100);color:var(--warning-700);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}}.sa-add-btn{display:inline-flex;align-items:center;gap:6px;background:var(--sa-accent-blue);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:14px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:background-color .15s;white-space:nowrap}.sa-add-btn:hover{background:#4d94f8}.sa-add-btn:disabled{opacity:.5;cursor:not-allowed}.sa-add-card{background:var(--sa-bg-card);border:1px solid var(--sa-border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.categories-add-form{display:flex;gap:8px;align-items:center}.category-edit-row{display:flex;gap:8px;align-items:center;width:100%}.sel-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.sel-total-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 8px;margin-left:10px;background:#ef4444;color:#fff;font-size:13px;font-weight:600;border-radius:12px;vertical-align:middle}.sel-row{cursor:pointer;transition:background .15s}.sel-row:hover{background:var(--sa-bg-elevated, #273447)!important}.sel-row-active{background:var(--sa-bg-elevated, #273447)!important;outline:1px solid var(--sa-border, #334155)}.sel-time{white-space:nowrap;font-size:13px;color:#94a3b8}.sel-method{font-weight:600;font-size:12px;font-family:monospace;text-transform:uppercase}.sel-endpoint{font-family:monospace;font-size:13px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#cbd5e1}.sel-message{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#f1f5f9}.sel-clinic,.sel-user{font-size:13px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sel-page{font-family:monospace;font-size:12px;color:#64748b;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sel-no-data{color:#475569}.sel-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.sel-modal{background:#1e293b;border:1px solid #334155;border-radius:12px;width:100%;max-width:700px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 50px #0006}.sel-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #334155}.sel-modal-header h2{margin:0;font-size:16px;color:#f1f5f9}.sel-modal-close{background:none;border:none;color:#94a3b8;font-size:24px;cursor:pointer;padding:0 4px;line-height:1}.sel-modal-close:hover{color:#f1f5f9}.sel-modal-body{padding:20px}.sel-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.sel-detail-full{grid-column:1 / -1}.sel-detail-item{display:flex;flex-direction:column;gap:4px}.sel-detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.sel-detail-value{font-size:14px;color:#e2e8f0;word-break:break-word}.sel-mono{font-family:monospace;font-size:13px}.sel-small{font-size:12px;line-height:1.5}.sel-code-section{margin-top:20px}.sel-code-section h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin:0 0 8px}.sel-code-block{background:#0f172a;border:1px solid #1e293b;border-radius:8px;padding:12px 16px;font-family:monospace;font-size:12px;line-height:1.6;color:#cbd5e1;overflow-x:auto;white-space:pre-wrap;word-break:break-word;margin:0;max-height:300px;overflow-y:auto}@media(max-width:768px){.sel-detail-grid{grid-template-columns:1fr}.sat-filters{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)}.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:15px;padding:11px 14px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.stm-field select:focus,.stm-field textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg),0 0 12px #0ea5e91a}.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)}.update-banner{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:10000;background:var(--primary-btn);color:#fff;padding:10px 16px;border-radius:var(--radius-md);display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg, 0 4px 16px rgba(0, 0, 0, .2));animation:update-banner-in .3s ease-out}@keyframes update-banner-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.update-banner-text{white-space:nowrap}.update-banner-actions{display:flex;gap:8px}.update-banner-refresh{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;padding:4px 12px;cursor:pointer;font-weight:600;font-family:var(--font-family);font-size:13px}.update-banner-refresh:hover{background:#ffffff4d}.update-banner-dismiss{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fffc;padding:4px 10px;cursor:pointer;font-family:var(--font-family);font-size:13px}.update-banner-dismiss:hover{background:#ffffff1a}@media(max-width:480px){.update-banner{left:12px;right:12px;bottom:16px;transform:none;justify-content:space-between}@keyframes update-banner-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}}.page-transition--enter{will-change:opacity,transform;animation:pageEnter .25s cubic-bezier(.4,0,.2,1) forwards}.page-transition--idle{opacity:1}.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}.page-transition--enter{opacity:1}}.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)}}.avatar-dropdown{position:relative;display:inline-flex;align-items:center}.avatar-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-card);color:var(--primary-500);border:1.5px solid var(--border-color);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),border-color var(--duration-fast) var(--ease-smooth);flex-shrink:0;line-height:1;letter-spacing:.02em}.avatar-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.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}.global-header{position:sticky;top:0;height:var(--global-header-height);background:var(--bg-sidebar);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 20px;gap:12px;z-index:100}.global-header-menu-btn{display:none;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:none;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;flex-shrink:0}.global-header-menu-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.global-header-back{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:none;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:background var(--duration-fast),color var(--duration-fast)}.global-header-back:hover{background:var(--bg-elevated);color:var(--text-primary)}.global-header-title{flex:1;font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-header-actions{display:flex;align-items:center;gap:4px;margin-left:auto}@media(max-width:768px){.global-header{padding:0 16px}.global-header-menu-btn{display:flex}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:200;transition:width var(--duration-slow) var(--ease-smooth);overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar-logo{display:flex;align-items:center;gap:10px;height:var(--global-header-height);padding:0 16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-logo-icon{width:24px;height:24px;flex-shrink:0}.sidebar-logo-text{font-size:16px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;letter-spacing:-.01em}.sidebar-mobile-close{display:none;margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm)}.sidebar-mobile-close:hover{color:var(--text-primary);background:var(--bg-elevated)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 8px 0;display:flex;flex-direction:column;gap:1px}.sidebar-nav::-webkit-scrollbar{width:0}.sidebar-item{display:flex;align-items:center;gap:10px;height:36px;padding:0 10px;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;transition:background var(--duration-fast) var(--ease-smooth),color var(--duration-fast) var(--ease-smooth);border:none;background:none;cursor:pointer;width:100%;text-align:left}.sidebar-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-item--active{background:var(--primary-bg);color:var(--primary-text);font-weight:600}.sidebar-item--active .sidebar-item-icon{color:var(--cyan-500)}.sidebar-item-icon{flex-shrink:0;color:inherit}.sidebar-item-label{overflow:hidden;text-overflow:ellipsis}.sidebar-bottom{padding:8px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:1px}.sidebar-collapse-btn{display:flex;align-items:center;gap:8px;height:32px;padding:0 10px;border-radius:var(--radius-md);color:var(--text-muted);font-size:12px;font-weight:500;background:none;border:none;cursor:pointer;white-space:nowrap;overflow:hidden;transition:all var(--duration-fast);margin-top:4px}.sidebar-collapse-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#020817b3;z-index:199}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--duration-slow) var(--ease-smooth),width var(--duration-slow) var(--ease-smooth);width:var(--sidebar-width)!important}.sidebar--mobile-open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-mobile-close{display:flex}.sidebar-collapse-btn{display:none}}.supplier-layout{min-height:100vh;background:var(--bg-page)}.supplier-header{background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.supplier-header-left{display:flex;align-items:center;gap:16px}.supplier-header-left img{height:32px}.supplier-header-left h1{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.supplier-header-left .supplier-badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-text)}.supplier-header-right{display:flex;align-items:center;gap:12px}.supplier-header-user{font-size:14px;color:var(--text-secondary)}.supplier-nav{display:flex;gap:4px;padding:0 24px;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.supplier-nav a{padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-muted);text-decoration:none;border-bottom:2px solid transparent;transition:all var(--duration-fast)}.supplier-nav a:hover{color:var(--text-primary)}.supplier-nav a.active{color:var(--primary-text);border-bottom-color:var(--primary-btn)}.supplier-content{padding:24px;max-width:1200px;margin:0 auto}.supplier-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.supplier-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px}.supplier-stat-card .stat-label{font-size:13px;color:var(--text-muted);margin-bottom:4px}.supplier-stat-card .stat-value{font-size:28px;font-weight:700;color:var(--text-primary)}.supplier-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.supplier-charts-grid .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)}.supplier-charts-grid .panel:hover{box-shadow:var(--shadow-md)}.supplier-charts-grid .panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.supplier-charts-grid .panel-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}.supplier-charts-grid .chart-container{padding:8px 16px 16px;height:220px;display:flex;align-items:center;justify-content:center}.supplier-charts-grid .chart-loading,.supplier-charts-grid .chart-no-data{color:var(--text-muted);font-size:14px;text-align:center;padding:40px}.supplier-charts-grid .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}.supplier-charts-grid .chart-tooltip-label{font-weight:600;color:var(--text-primary);margin-bottom:6px}.supplier-charts-grid .chart-tooltip-row{display:flex;align-items:center;gap:6px;padding:2px 0}.supplier-charts-grid .chart-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.supplier-charts-grid .chart-tooltip-name{color:var(--text-secondary);flex:1}.supplier-charts-grid .chart-tooltip-value{font-weight:700;color:var(--text-primary);margin-left:12px}.supplier-donut-layout{display:flex;align-items:center;width:100%;height:100%;gap:8px}.supplier-donut-chart{flex:0 0 55%}.supplier-donut-legend{flex:1;display:flex;flex-direction:column;gap:6px}.supplier-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.supplier-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.supplier-legend-name{color:var(--text-secondary);flex:1}.supplier-legend-value{font-weight:700;color:var(--text-primary)}@media(max-width:900px){.supplier-charts-grid{grid-template-columns:1fr}}.supplier-search{position:relative;max-width:400px;margin-bottom:16px}.supplier-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.supplier-search .search-input-full{width:100%;padding-left:36px}.supplier-product-grid{display:grid;gap:12px}.supplier-product-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all var(--duration-fast)}.supplier-product-card:hover{border-color:var(--primary-btn);box-shadow:var(--shadow-sm)}.supplier-product-info{flex:1;min-width:0}.supplier-product-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.supplier-product-meta{font-size:13px;color:var(--text-muted);display:flex;gap:16px;flex-wrap:wrap}.supplier-product-docs{display:flex;gap:6px;flex-shrink:0}.doc-indicator{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:1.5px solid var(--border-color);color:var(--text-muted);background:var(--bg-elevated)}.doc-indicator.has-doc{border-color:var(--success-600);color:var(--success-600);background:var(--success-50)}.doc-indicator.missing-doc{border-color:var(--error-600);color:var(--error-600);background:var(--error-50)}.product-detail-header{margin-bottom:24px}.product-detail-header h2{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.product-detail-header .product-detail-meta{font-size:14px;color:var(--text-muted);display:flex;gap:16px}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.document-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px}.document-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.document-card-type{font-size:14px;font-weight:600;color:var(--text-primary)}.document-card-status{font-size:12px;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm)}.document-card-status.uploaded{background:var(--success-50);color:var(--success-600)}.document-card-status.missing{background:var(--bg-elevated);color:var(--text-muted)}.document-card-file{font-size:13px;color:var(--text-secondary);margin-bottom:12px;word-break:break-all}.document-card-actions{display:flex;gap:8px}.document-card-actions .btn{font-size:13px;padding:6px 12px}.upload-area{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:24px;text-align:center;cursor:pointer;transition:all var(--duration-fast)}.upload-area:hover,.upload-area.dragover{border-color:var(--primary-btn);background:var(--primary-bg)}.upload-area-icon{font-size:32px;margin-bottom:8px}.upload-area-text{font-size:14px;color:var(--text-secondary)}.upload-area-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.supplier-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.supplier-modal{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:480px;max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:var(--shadow-lg)}.supplier-modal h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:20px}.supplier-modal .form-group{margin-bottom:16px}.supplier-modal .modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}@media(max-width:640px){.supplier-header{padding:0 16px}.supplier-nav{padding:0 16px;overflow-x:auto}.supplier-content{padding:16px}.supplier-product-card{flex-direction:column;align-items:flex-start;gap:12px}.documents-grid{grid-template-columns:1fr}}
