:root{--bg:#0a0a0f;--bg-deep:#060609;--surface:#ffffff08;--surface-hover:#ffffff0f;--surface-active:#ffffff17;--border:#ffffff0f;--border-hover:#ffffff1f;--primary:#00f0ff;--primary-dim:#00f0ff26;--primary-glow:#00f0ff66;--accent:#bf5af2;--accent-dim:#bf5af226;--accent-glow:#bf5af266;--success:#30d158;--success-dim:#30d15826;--danger:#ff453a;--danger-dim:#ff453a26;--warning:#ffd60a;--warning-dim:#ffd60a26;--text-primary:#f5f5f7;--text-secondary:#f5f5f799;--text-tertiary:#f5f5f759;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--sidebar-width:260px;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 8px 32px #0006;--shadow-lg:0 16px 64px #00000080;--shadow-glow-primary:0 0 20px #00f0ff26, 0 0 60px #00f0ff0d;--shadow-glow-accent:0 0 20px #bf5af226, 0 0 60px #bf5af20d;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-normal:.3s;--duration-slow:.5s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}#root{min-height:100vh}a{color:var(--primary);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}a:hover{color:var(--accent)}button{font-family:var(--font);cursor:pointer;background:0 0;border:none;outline:none}input,select,textarea{font-family:var(--font);outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-root{background:var(--bg);min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:32px 40px;position:relative;overflow-y:auto}.main-content.login-layout{margin-left:0;padding:0}.bg-mesh{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.bg-mesh:before{content:"";background:radial-gradient(at 20%,#00f0ff0f 0%,#0000 50%),radial-gradient(at 80% 20%,#bf5af20f 0%,#0000 50%),radial-gradient(at 50% 80%,#00f0ff08 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite meshFloat;position:absolute;top:-50%;left:-50%}@keyframes meshFloat{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(2%,-3%)rotate(1deg)}50%{transform:translate(-1%,2%)rotate(-.5deg)}75%{transform:translate(3%,1%)rotate(.5deg)}}.glass-card{background:var(--surface);-webkit-backdrop-filter:blur(40px)saturate(1.5);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), background var(--duration-normal) var(--ease-out);padding:24px;position:relative;overflow:hidden}.glass-card:hover{border-color:var(--border-hover);background:var(--surface-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.glass-card:before{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff14 30%,#ffffff1f 50%,#ffffff14 70%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.glass-card-glow{position:relative}.glass-card-glow:after{content:"";border-radius:inherit;-webkit-mask-composite:xor;pointer-events:none;opacity:0;transition:opacity var(--duration-normal) var(--ease-out);background:linear-gradient(135deg,#00f0ff4d,#0000 40% 60%,#bf5af24d);padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.glass-card-glow:hover:after{opacity:1}.sidebar{width:var(--sidebar-width);-webkit-backdrop-filter:blur(40px)saturate(1.8);border-right:1px solid var(--border);z-index:100;background:#0a0a0fd9;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-logo{border-bottom:1px solid var(--border);padding:28px 24px 20px}.sidebar-logo h1{letter-spacing:-.02em;background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:800;line-height:1.2}.sidebar-logo .logo-sub{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.15em;margin-top:4px;font-size:.7rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.sidebar-nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);align-items:center;gap:14px;padding:12px 16px;font-size:.9rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-nav-link:hover{background:var(--surface-hover);color:var(--text-primary);transform:translate(4px)}.sidebar-nav-link.active{background:var(--primary-dim);color:var(--primary);font-weight:600}.sidebar-nav-link.active:before{content:"";background:var(--primary);width:3px;height:20px;box-shadow:0 0 12px var(--primary-glow);border-radius:0 3px 3px 0;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.2rem;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.15em;color:var(--text-tertiary);padding:20px 16px 8px;font-size:.65rem;font-weight:600}.sidebar-footer{border-top:1px solid var(--border);padding:16px 20px}.sidebar-user{border-radius:var(--radius-md);transition:background var(--duration-fast) var(--ease-out);align-items:center;gap:12px;padding:10px 12px;display:flex}.sidebar-user:hover{background:var(--surface-hover)}.sidebar-avatar{background:linear-gradient(135deg, var(--primary), var(--accent));width:36px;height:36px;color:var(--bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.sidebar-user-info{overflow:hidden}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-tertiary);font-size:.7rem}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{z-index:0;background:linear-gradient(-45deg,#0a0a0f,#0f0a1a,#0a1520,#0d0a15) 0 0/400% 400%;animation:15s infinite loginGradient;position:absolute;inset:0}@keyframes loginGradient{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.login-bg-orb{filter:blur(80px);opacity:.5;border-radius:50%;animation:8s ease-in-out infinite orbPulse;position:absolute}.login-bg-orb.orb-1{background:radial-gradient(circle,#00f0ff33,#0000 70%);width:500px;height:500px;animation-delay:0s;top:-10%;right:-5%}.login-bg-orb.orb-2{background:radial-gradient(circle,#bf5af22e,#0000 70%);width:600px;height:600px;animation-delay:-4s;bottom:-15%;left:-10%}.login-bg-orb.orb-3{background:radial-gradient(circle,#00f0ff1a,#0000 70%);width:350px;height:350px;animation-delay:-2s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes orbPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}.login-card{z-index:1;-webkit-backdrop-filter:blur(60px)saturate(1.5);border-radius:var(--radius-xl);width:420px;max-width:90vw;box-shadow:var(--shadow-lg), 0 0 80px #00f0ff08, 0 0 160px #bf5af208;animation:loginCardIn .8s var(--ease-out) forwards;opacity:0;background:#0f0f14b3;border:1px solid #ffffff14;padding:48px 40px;position:relative;transform:translateY(20px)}@keyframes loginCardIn{to{opacity:1;transform:translateY(0)}}.login-card:before{content:"";background:linear-gradient(90deg,#0000 0%,#00f0ff4d 30%,#bf5af24d 70%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.login-header{text-align:center;margin-bottom:36px}.login-header h2{background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:1.6rem;font-weight:800}.login-header p{color:var(--text-tertiary);font-size:.85rem;font-weight:400}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600}.form-input{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:#ffffff0a;padding:14px 18px;font-size:.95rem}.form-input::placeholder{color:var(--text-tertiary)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #00f0ff1a, var(--shadow-glow-primary);background:#00f0ff08}.btn-primary{background:linear-gradient(135deg, var(--primary), #00c8d4);color:var(--bg);border-radius:var(--radius-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-normal) var(--ease-out);border:none;margin-top:8px;padding:14px 24px;font-size:.95rem;font-weight:700;position:relative;overflow:hidden}.btn-primary:before{content:"";transition:transform .6s var(--ease-out);background:linear-gradient(135deg,#0000,#fff3,#0000);position:absolute;inset:0;transform:translate(-100%)}.btn-primary:hover{transform:translateY(-2px)scale(1.01);box-shadow:0 8px 30px #00f0ff59,0 0 60px #00f0ff26}.btn-primary:hover:before{transform:translate(100%)}.btn-primary:active{transform:translateY(0)scale(.99)}.login-footer{text-align:center;color:var(--text-tertiary);margin-top:24px;font-size:.8rem}.login-footer a{color:var(--primary);font-weight:500}.page-header{margin-bottom:32px}.page-title{letter-spacing:-.03em;color:var(--text-primary);font-size:1.8rem;font-weight:800;line-height:1.2}.page-subtitle{color:var(--text-tertiary);margin-top:4px;font-size:.9rem;font-weight:400}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:32px;display:grid}.greeting-card{-webkit-backdrop-filter:blur(40px);border-radius:var(--radius-lg);background:linear-gradient(135deg,#00f0ff0f,#bf5af20f);border:1px solid #00f0ff1a;grid-column:1/-1;justify-content:space-between;align-items:center;padding:32px;display:flex;position:relative;overflow:hidden}.greeting-card:after{content:"";pointer-events:none;background:radial-gradient(at 100%,#bf5af214,#0000 70%);width:300px;height:100%;position:absolute;top:0;right:0}.greeting-text h2{letter-spacing:-.02em;margin-bottom:4px;font-size:1.5rem;font-weight:700}.greeting-text h2 span{background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.greeting-text p{color:var(--text-tertiary);font-size:.85rem}.greeting-date{color:var(--text-secondary);z-index:1;font-size:.85rem;font-weight:500}.metric-card{text-align:center;flex-direction:column;align-items:center;gap:18px;padding:28px;display:flex}.metric-card:hover{box-shadow:var(--shadow-glow-primary)}.metric-ring-wrap{width:110px;height:110px;position:relative}.metric-ring-svg{width:110px;height:110px;transform:rotate(-90deg)}.metric-ring-bg{fill:none;stroke:#ffffff0f;stroke-width:8px}.metric-ring-fill{fill:none;stroke-width:8px;stroke-linecap:round;transition:stroke-dashoffset 1.5s var(--ease-out);filter:drop-shadow(0 0 6px)}.metric-ring-fill.cyan{stroke:var(--primary);color:var(--primary)}.metric-ring-fill.purple{stroke:var(--accent);color:var(--accent)}.metric-ring-fill.green{stroke:var(--success);color:var(--success)}.metric-ring-fill.orange{stroke:var(--warning);color:var(--warning)}.metric-ring-value{color:var(--text-primary);font-size:1.3rem;font-weight:800;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.metric-ring-value small{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-top:4px;font-size:.55rem;font-weight:500;display:block}.metric-label{color:var(--text-secondary);font-size:.9rem;font-weight:600}.metric-detail{color:var(--text-tertiary);font-size:.75rem}.section-title{letter-spacing:-.01em;color:var(--text-primary);align-items:center;gap:10px;margin-bottom:18px;font-size:1.15rem;font-weight:700;display:flex}.section-title-icon{font-size:1.1rem}.insights-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:32px;display:grid}.insight-card{align-items:flex-start;gap:16px;padding:22px;display:flex}.insight-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.insight-icon.cyan{background:var(--primary-dim)}.insight-icon.purple{background:var(--accent-dim)}.insight-icon.green{background:var(--success-dim)}.insight-content h4{color:var(--text-primary);margin-bottom:4px;font-size:.85rem;font-weight:600}.insight-content p{color:var(--text-tertiary);font-size:.78rem;line-height:1.5}.activity-feed{margin-bottom:32px}.activity-item{border-bottom:1px solid var(--border);transition:background var(--duration-fast) var(--ease-out);align-items:center;gap:16px;padding:16px 20px;display:flex}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:var(--surface-hover)}.activity-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.activity-dot.cyan{background:var(--primary);box-shadow:0 0 8px var(--primary-glow)}.activity-dot.purple{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.activity-dot.green{background:var(--success)}.activity-text{color:var(--text-secondary);flex:1;font-size:.85rem}.activity-text strong{color:var(--text-primary);font-weight:600}.activity-time{color:var(--text-tertiary);white-space:nowrap;font-size:.72rem}.scanner-layout{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=900px){.scanner-layout{grid-template-columns:1fr}}.upload-zone{border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:border-color var(--duration-normal) var(--ease-out), background var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out);background:#00f0ff05;border:2px dashed #00f0ff33;padding:60px 32px;position:relative;overflow:hidden}.upload-zone:hover{box-shadow:var(--shadow-glow-primary);background:#00f0ff0a;border-color:#00f0ff66;transform:translateY(-2px)}.upload-zone.drag-over{border-color:var(--primary);background:#00f0ff14;box-shadow:0 0 40px #00f0ff33}.upload-icon{margin-bottom:16px;font-size:3.5rem;animation:3s ease-in-out infinite uploadFloat;display:block}@keyframes uploadFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.upload-text{color:var(--text-secondary);margin-bottom:8px;font-size:1rem;font-weight:600}.upload-subtext{color:var(--text-tertiary);font-size:.78rem}.meal-selector{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.meal-btn{border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);transition:background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-out);padding:10px 20px;font-size:.82rem;font-weight:600}.meal-btn:hover{background:var(--surface-hover);color:var(--text-primary);transform:translateY(-1px)}.meal-btn.active{background:var(--primary-dim);color:var(--primary);border-color:#00f0ff4d;box-shadow:0 0 20px #00f0ff1a}.analysis-results{padding:28px}.analysis-results h3{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:20px;font-size:1.1rem;font-weight:700;display:flex}.nutrition-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.nutrition-row:last-child{border-bottom:none}.nutrition-name{color:var(--text-secondary);font-size:.85rem;font-weight:500}.nutrition-value{color:var(--text-primary);font-size:.9rem;font-weight:700}.nutrition-bar-wrap{background:#ffffff0f;border-radius:3px;flex:1;max-width:120px;height:6px;margin:0 16px;overflow:hidden}.nutrition-bar{height:100%;transition:width 1s var(--ease-out);border-radius:3px}.nutrition-bar.cyan{background:var(--primary);box-shadow:0 0 8px var(--primary-glow)}.nutrition-bar.purple{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.nutrition-bar.green{background:var(--success)}.nutrition-bar.orange{background:var(--warning)}.scan-btn{background:linear-gradient(135deg, var(--accent), #9b3dd7);color:#fff;border-radius:var(--radius-md);width:100%;transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-normal) var(--ease-out);margin-top:20px;padding:14px;font-size:.9rem;font-weight:700}.scan-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #bf5af259}.scan-btn:active{transform:translateY(0)scale(.99)}.health-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:32px;display:grid}.health-service-card{cursor:default;align-items:flex-start;gap:18px;padding:24px;display:flex}.health-service-card:hover{box-shadow:var(--shadow-md)}.health-status-indicator{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.4rem;display:flex;position:relative}.health-status-indicator.online{background:var(--success-dim)}.health-status-indicator.offline{background:var(--danger-dim)}.health-status-indicator:after{content:"";border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.health-status-indicator.online:after{background:var(--success);box-shadow:0 0 8px var(--success);animation:2s ease-in-out infinite statusPulse}.health-status-indicator.offline:after{background:var(--danger);box-shadow:0 0 8px var(--danger)}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.health-service-info h4{color:var(--text-primary);margin-bottom:4px;font-size:.95rem;font-weight:600}.health-service-status{text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-size:.78rem;font-weight:600}.health-service-status.online{color:var(--success)}.health-service-status.offline{color:var(--danger)}.health-meta{flex-wrap:wrap;gap:16px;display:flex}.health-meta-item{color:var(--text-tertiary);font-size:.72rem}.health-meta-item strong{color:var(--text-secondary);font-weight:600}.uptime-section{margin-bottom:32px}.uptime-card{padding:28px}.uptime-bar-wrap{gap:3px;margin-top:16px;display:flex}.uptime-bar-segment{height:32px;transition:transform var(--duration-fast) var(--ease-out), opacity var(--duration-fast) var(--ease-out);border-radius:4px;flex:1;position:relative}.uptime-bar-segment.up{background:var(--success);opacity:.7}.uptime-bar-segment.down{background:var(--danger);opacity:.8}.uptime-bar-segment.partial{background:var(--warning);opacity:.7}.uptime-bar-segment:hover{opacity:1;transform:scaleY(1.3)}.uptime-legend{gap:20px;margin-top:12px;display:flex}.uptime-legend-item{color:var(--text-tertiary);align-items:center;gap:6px;font-size:.72rem;display:flex}.uptime-legend-dot{border-radius:50%;width:8px;height:8px}.uptime-legend-dot.up{background:var(--success)}.uptime-legend-dot.down{background:var(--danger)}.uptime-legend-dot.partial{background:var(--warning)}.uptime-stats{border-top:1px solid var(--border);gap:32px;margin-top:16px;padding-top:16px;display:flex}.uptime-stat{text-align:center}.uptime-stat-value{color:var(--primary);font-size:1.4rem;font-weight:800}.uptime-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-top:2px;font-size:.7rem}@media (width<=768px){:root{--sidebar-width:0px}.sidebar{transition:transform var(--duration-normal) var(--ease-out);transform:translate(-100%)}.sidebar.open{width:260px;transform:translate(0)}.main-content{margin-left:0;padding:20px 16px}.dashboard-grid{grid-template-columns:1fr}.greeting-card{flex-direction:column;align-items:flex-start;gap:12px}.scanner-layout,.health-grid{grid-template-columns:1fr}.page-title{font-size:1.4rem}}@media (width<=480px){.login-card{padding:32px 24px}.metric-ring-wrap,.metric-ring-svg{width:90px;height:90px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.animate-in{animation:fadeInUp .6s var(--ease-out) forwards;opacity:0}.animate-in-1{animation-delay:.1s}.animate-in-2{animation-delay:.2s}.animate-in-3{animation-delay:.3s}.animate-in-4{animation-delay:.4s}.animate-in-5{animation-delay:.5s}.animate-in-6{animation-delay:.6s}@keyframes ringDraw{0%{stroke-dashoffset:283px}}.neon-text{text-shadow:0 0 10px,0 0 40px}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f 50%,#ffffff08 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite shimmer}.badge{text-transform:uppercase;letter-spacing:.06em;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.68rem;font-weight:600;display:inline-flex}.badge.success{background:var(--success-dim);color:var(--success)}.badge.danger{background:var(--danger-dim);color:var(--danger)}.badge.warning{background:var(--warning-dim);color:var(--warning)}.badge.info{background:var(--primary-dim);color:var(--primary)}.particle{background:var(--primary);opacity:.3;pointer-events:none;border-radius:50%;width:2px;height:2px;animation:6s ease-in-out infinite particleFloat;position:absolute}@keyframes particleFloat{0%,to{opacity:.2;transform:translate(0)}25%{opacity:.5;transform:translate(15px,-25px)}50%{opacity:.3;transform:translate(-10px,-50px)}75%{opacity:.4;transform:translate(20px,-30px)}}.image-preview-wrap{border-radius:var(--radius-md);margin-bottom:16px;position:relative;overflow:hidden}.image-preview-wrap img{object-fit:cover;width:100%;height:200px;display:block}.image-preview-overlay{background:linear-gradient(#0000 50%,#0a0a0fcc);position:absolute;inset:0}.empty-state{text-align:center;color:var(--text-tertiary);padding:48px 24px}.empty-state-icon{opacity:.4;margin-bottom:16px;font-size:3rem}.empty-state h4{color:var(--text-secondary);margin-bottom:8px;font-size:1rem;font-weight:600}.empty-state p{max-width:300px;margin:0 auto;font-size:.82rem;line-height:1.5}.scanning-animation{flex-direction:column;align-items:center;gap:16px;padding:40px;display:flex}.scanning-rings{width:80px;height:80px;position:relative}.scanning-ring{border:2px solid #0000;border-top-color:var(--primary);border-radius:50%;animation:1s linear infinite spin;position:absolute;inset:0}.scanning-ring:nth-child(2){border-top-color:var(--accent);animation-duration:1.5s;animation-direction:reverse;inset:8px}.scanning-ring:nth-child(3){border-top-color:var(--primary);animation-duration:2s;inset:16px}@keyframes spin{to{transform:rotate(360deg)}}.scanning-text{color:var(--text-secondary);font-size:.85rem;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}
