*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep:#020308;--bg-surface:#060a16;--bg-card:#080e20b8;--bg-card-hover:#0e1630d1;--border:#00b4ff1a;--border-active:#00c8ff66;--border-glow:#00c8ff8c;--cyan:#00d4ff;--cyan-dim:#00d4ff1f;--cyan-glow:#00d4ff4d;--violet:#8b5cf6;--violet-dim:#8b5cf61f;--violet-glow:#8b5cf64d;--pink:#ec4899;--pink-dim:#ec48991f;--green:#4ade80;--amber:#fbbf24;--red:#f87171;--grad-brand:linear-gradient(135deg, #00d4ff 0%, #8b5cf6 50%, #ec4899 100%);--grad-brand-2:linear-gradient(135deg, #06b6d4 0%, #6366f1 50%, #a855f7 100%);--grad-card:linear-gradient(145deg, #00d4ff0d 0%, #8b5cf608 100%);--grad-glass:linear-gradient(135deg, #ffffff0a 0%, #ffffff03 100%);--grad-glow:radial-gradient(ellipse at 50% 0%, #00d4ff26 0%, transparent 70%);--grad-aurora:linear-gradient(180deg, #00d4ff08 0%, #8b5cf60a 30%, #ec489905 60%, transparent 100%);--font-display:"Outfit", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--radius-xs:6px;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 24px #00000080;--shadow-glow:0 0 40px #00d4ff1a, 0 0 80px #8b5cf60f, 0 8px 32px #0009;--shadow-neon:0 0 20px #00d4ff26, 0 0 60px #00d4ff0d}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-deep);color:#c8d6e5;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(120% 80% at 15% 5%,#00d4ff12 0%,#0000 55%),radial-gradient(90% 60% at 85% 15%,#8b5cf60f 0%,#0000 55%),radial-gradient(100% 70% at 50% 90%,#ec48990a 0%,#0000 55%),radial-gradient(60% 40% at 70%,#06b6d408 0%,#0000 50%);animation:20s ease-in-out infinite alternate auroraShift;position:fixed;inset:0}body:after{content:"";filter:blur(60px);pointer-events:none;z-index:0;background:radial-gradient(100% 50% at 30% 100%,#00d4ff0f 0%,#0000 60%),radial-gradient(80% 40% at 70% 100%,#8b5cf60d 0%,#0000 50%);width:140%;height:80%;animation:15s ease-in-out infinite alternate waveFlow;position:fixed;bottom:-40%;left:-20%}@keyframes auroraShift{0%{opacity:.6;transform:scale(1)translateY(0)}50%{opacity:1;transform:scale(1.05)translateY(-10px)}to{opacity:.7;transform:scale(1.02)translateY(5px)}}@keyframes waveFlow{0%{opacity:.6;transform:translate(-5%)rotate(-1deg)}50%{opacity:1;transform:translate(3%)rotate(.5deg)}to{opacity:.8;transform:translate(-2%)rotate(-.5deg)}}#root{z-index:1;position:relative}.app:before{content:"";pointer-events:none;z-index:0;opacity:.8;background-image:radial-gradient(1px 1px at 10% 20%,#00d4ff66 0%,#0000 100%),radial-gradient(1px 1px at 25% 60%,#8b5cf64d 0%,#0000 100%),radial-gradient(1px 1px at 40% 10%,#00d4ff59 0%,#0000 100%),radial-gradient(1px 1px at 55% 45%,#ec489940 0%,#0000 100%),radial-gradient(1px 1px at 70% 80%,#00d4ff4d 0%,#0000 100%),radial-gradient(1px 1px at 85% 30%,#8b5cf659 0%,#0000 100%),radial-gradient(1.5px 1.5px at 15% 85%,#00d4ff80 0%,#0000 100%),radial-gradient(1.5px 1.5px at 65% 5%,#8b5cf666 0%,#0000 100%),radial-gradient(1px 1px at 90% 55%,#ec489933 0%,#0000 100%),radial-gradient(1px 1px at 35% 35%,#00d4ff40 0%,#0000 100%),radial-gradient(2px 2px,#00d4ff26 0%,#0000 100%),radial-gradient(1px 1px at 78% 18%,#8b5cf633 0%,#0000 100%),radial-gradient(1px 1px at 5%,#00d4ff4d 0%,#0000 100%),radial-gradient(1px 1px at 92% 10%,#00d4ff40 0%,#0000 100%),radial-gradient(1px 1px at 48% 75%,#8b5cf64d 0%,#0000 100%);animation:30s ease-in-out infinite alternate particleDrift;position:fixed;inset:0}@keyframes particleDrift{0%{transform:translate(0)scale(1)}33%{transform:translate(3px,-5px)scale(1.02)}66%{transform:translate(-2px,3px)scale(.98)}to{transform:translate(1px,-2px)scale(1.01)}}.app{flex-direction:column;min-height:100vh;display:flex;position:relative}.app-header{-webkit-backdrop-filter:blur(28px)saturate(1.3);z-index:100;background:linear-gradient(#080e20d1 0%,#040814bf 100%);border-bottom:1px solid #00c8ff14;justify-content:space-between;align-items:center;padding:14px 40px;display:flex;position:sticky;top:0;box-shadow:0 1px #00d4ff0f,0 4px 30px #0006}.app-header:after{content:"";background:linear-gradient(90deg,#0000 0%,#00d4ff40 30%,#8b5cf633 50%,#00d4ff40 70%,#0000 100%);width:80%;height:1px;position:absolute;bottom:0;left:10%}.logo{align-items:center;gap:14px;display:flex}.header-logo-img{object-fit:cover;border:1.5px solid #00d4ff40;border-radius:12px;flex-shrink:0;width:42px;height:42px;transition:box-shadow .3s,transform .3s;box-shadow:0 0 16px #00d4ff59,0 0 40px #8b5cf626}.header-logo-img:hover{transform:scale(1.05);box-shadow:0 0 24px #00d4ff80,0 0 60px #8b5cf640}.logo-text{font-family:var(--font-display);background:var(--grad-brand);-webkit-text-fill-color:transparent;letter-spacing:-.02em;filter:drop-shadow(0 0 8px #00d4ff33);-webkit-background-clip:text;background-clip:text;font-size:1.45rem;font-weight:800}.logo-sub{color:#ffffff4d;letter-spacing:.15em;text-transform:uppercase;margin-top:3px;font-size:.65rem;font-weight:600;line-height:1}.header-badge{letter-spacing:.04em;border:1px solid;border-radius:100px;align-items:center;gap:8px;padding:6px 14px;font-size:.72rem;font-weight:600;transition:all .3s;display:flex}.status-dot{background:var(--green);width:7px;height:7px;box-shadow:0 0 8px var(--green);border-radius:50%;animation:2s ease-in-out infinite pulse-dot}.status-dot.loading{background:var(--amber);box-shadow:0 0 8px var(--amber)}.status-dot.error{background:var(--red);box-shadow:0 0 8px var(--red);animation:none}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.75)}}.user-chip{border:1px solid var(--border);cursor:default;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff08;border-radius:100px;align-items:center;gap:10px;padding:6px 14px;font-size:1.05rem;transition:all .3s;display:flex}.user-chip:hover{border-color:var(--border-active);background:#00d4ff0a}.user-dropdown{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#060a16f2;border:1px solid #00d4ff26;flex-direction:column;gap:4px;width:200px;padding:8px;animation:.2s cubic-bezier(.16,1,.3,1) dropIn;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 24px #0009,0 0 16px #00d4ff14}@keyframes dropIn{0%{opacity:0;transform:translateY(-10px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.dropdown-item{color:#ffffffb3;width:100%;font-family:var(--font-display);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:10px 14px;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.dropdown-item:hover{color:var(--cyan);background:#00d4ff14;border-color:#00d4ff33}.dropdown-item.danger:hover{color:var(--red);background:#f871711a;border-color:#f8717140}.dropdown-divider{background:#ffffff0f;height:1px;margin:4px 0}.main-content{z-index:1;flex:1;grid-template-rows:auto 1fr;grid-template-columns:1fr 1fr;gap:24px;width:100%;max-width:1440px;margin:0 auto;padding:36px 40px;display:grid;position:relative}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px)saturate(1.2);transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.card:before{content:"";opacity:0;background:linear-gradient(90deg,#0000 0%,#00d4ff4d 20%,#8b5cf640 50%,#ec489933 80%,#0000 100%);height:1px;transition:opacity .4s;position:absolute;top:0;left:0;right:0}.card:hover{box-shadow:var(--shadow-glow);background:var(--bg-card-hover);border-color:#00c8ff4d;transform:translateY(-2px)}.card:hover:before{opacity:1}.card-header{background:linear-gradient(#ffffff04 0%,#0000 100%);border-bottom:1px solid #ffffff0a;align-items:center;gap:12px;padding:20px 26px 14px;display:flex}.card-icon{background:var(--grad-card);border:1px solid var(--border);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.15rem;display:flex;box-shadow:0 0 12px #00d4ff14}.card-title{font-family:var(--font-display);color:#f0f4f8;letter-spacing:-.01em;font-size:.95rem;font-weight:700}.card-subtitle{color:#ffffff59;letter-spacing:.02em;margin-top:2px;font-size:.72rem}.card-body{padding:22px 26px}.upload-card{grid-area:1/1}.drop-zone{border-radius:var(--radius-md);text-align:center;cursor:pointer;background:#00d4ff04;border:2px dashed #00c8ff2e;padding:42px 24px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.drop-zone:before{content:"";opacity:0;border-radius:inherit;background:radial-gradient(#00d4ff14 0%,#8b5cf60a 50%,#0000 80%);transition:opacity .4s;position:absolute;inset:0}.drop-zone:after{content:"";border-radius:inherit;opacity:0;pointer-events:none;background:radial-gradient(circle at 0 0,#00d4ff26 0%,#0000 25%),radial-gradient(circle at 100% 0,#8b5cf61a 0%,#0000 25%),radial-gradient(circle at 0 100%,#8b5cf614 0%,#0000 25%),radial-gradient(circle at 100% 100%,#00d4ff1a 0%,#0000 25%);transition:opacity .4s;position:absolute;inset:-1px}.drop-zone:hover,.drop-zone.dragging{border-color:#00d4ff80;transform:scale(1.005);box-shadow:0 0 30px #00d4ff1a,inset 0 0 40px #00d4ff08}.drop-zone:hover:before,.drop-zone.dragging:before,.drop-zone:hover:after,.drop-zone.dragging:after{opacity:1}.drop-zone-content{z-index:1;position:relative}.drop-icon{filter:drop-shadow(0 0 18px #00d4ff80);margin-bottom:16px;font-size:2.8rem;animation:4s ease-in-out infinite iconFloat;display:block}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.drop-title{font-family:var(--font-display);color:#f0f4f8;margin-bottom:6px;font-size:1rem;font-weight:700}.drop-subtitle{color:#ffffff59;margin-bottom:22px;font-size:.78rem}.drop-formats{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.format-badge{color:var(--cyan);letter-spacing:.08em;background:#00d4ff0f;border:1px solid #00d4ff26;border-radius:100px;padding:4px 13px;font-size:.68rem;font-weight:700;transition:all .2s}.format-badge:hover{background:#00d4ff1f;border-color:#00d4ff4d;box-shadow:0 0 8px #00d4ff1a}.preview-area{border-radius:var(--radius-md);background:#00000059;border:1px solid #00c8ff14;justify-content:center;align-items:center;min-height:200px;margin-top:18px;display:flex;position:relative;overflow:hidden}.preview-img{object-fit:contain;border-radius:var(--radius-md);width:100%;max-height:400px;display:block}.preview-placeholder{color:#ffffff2e;text-align:center;padding:48px;font-size:.82rem;font-style:italic}.webcam-card{grid-area:1/2}.webcam-wrapper{border-radius:var(--radius-md);aspect-ratio:4/3;background:#000;border:1px solid #00c8ff1a;position:relative;overflow:hidden;box-shadow:inset 0 0 60px #0006}.webcam-video{object-fit:cover;width:100%;height:100%;display:block}.webcam-overlay-canvas{pointer-events:none;position:absolute;inset:0}.webcam-off-state{color:#ffffff4d;letter-spacing:.03em;background:radial-gradient(#00000080 0%,#000c 100%);flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:.88rem;font-weight:500;display:flex;position:absolute;inset:0}.webcam-off-icon{opacity:.25;filter:drop-shadow(0 0 10px #00d4ff26);font-size:3rem;animation:5s ease-in-out infinite iconFloat}.webcam-controls{gap:10px;margin-top:16px;display:flex}.scan-line{background:linear-gradient(90deg, transparent, var(--cyan), transparent);width:100%;height:2px;box-shadow:0 0 16px var(--cyan), 0 0 40px #00d4ff4d;pointer-events:none;z-index:5;animation:3s linear infinite scan;position:absolute}@keyframes scan{0%{opacity:0;top:0%}5%{opacity:1}90%{opacity:1;top:100%}to{opacity:0;top:100%}}.results-card{grid-area:2/1/auto/-1}.results-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.face-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;padding:20px;transition:all .35s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.face-card:before{content:"";background:var(--grad-brand);opacity:0;width:100%;height:2px;transition:opacity .35s;position:absolute;top:0;left:0}.face-card:hover{background:#00d4ff08;border-color:#00c8ff40;transform:translateY(-2px);box-shadow:0 0 20px #00d4ff0f}.face-card:hover:before{opacity:1}.face-card-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.face-number{background:var(--grad-brand);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.75rem;font-weight:800;display:flex;box-shadow:0 0 12px #00d4ff33}.face-label{font-family:var(--font-display);color:#f0f4f8;font-size:.88rem;font-weight:700}.face-conf{color:var(--green);background:#4ade8014;border:1px solid #4ade802e;border-radius:100px;margin-left:auto;padding:3px 11px;font-size:.72rem;font-weight:700}.face-attrs{grid-template-columns:1fr 1fr;gap:10px;display:grid}.attr-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff0d;padding:10px 12px;transition:border-color .2s}.attr-item:hover{border-color:#00d4ff26}.attr-label{color:#ffffff4d;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px;font-size:.65rem;font-weight:700}.attr-value{font-family:var(--font-display);color:var(--cyan);font-size:.95rem;font-weight:700}.attr-value.female{color:var(--pink)}.attr-value.male{color:#818cf8}.bbox-item{grid-column:1/-1}.bbox-coords{font-family:var(--font-mono);color:#fff6;letter-spacing:.03em;background:#0000004d;border:1px solid #ffffff0a;border-radius:6px;padding:7px 11px;font-size:.7rem}.stats-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-badge{border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;background:#ffffff05;padding:16px 18px;transition:all .3s;position:relative;overflow:hidden}.stat-badge:after{content:"";background:var(--grad-brand);opacity:0;height:1px;transition:opacity .3s;position:absolute;bottom:0;left:20%;right:20%}.stat-badge:hover{background:#00d4ff08;border-color:#00c8ff33}.stat-badge:hover:after{opacity:1}.stat-value{font-family:var(--font-display);background:var(--grad-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800;line-height:1.1}.stat-label{color:#ffffff4d;text-transform:uppercase;letter-spacing:.1em;margin-top:5px;font-size:.67rem;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-display);white-space:nowrap;letter-spacing:.02em;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 22px;font-size:.82rem;font-weight:600;transition:all .25s cubic-bezier(.16,1,.3,1);display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:0 4px 20px #00d4ff33}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 30px #00d4ff4d,0 0 60px #00d4ff1a}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-outline{color:var(--cyan);background:0 0;border:1px solid #00c8ff4d}.btn-outline:hover:not(:disabled){background:var(--cyan-dim);border-color:#00c8ff80;box-shadow:0 0 20px #00d4ff14}.btn-ghost{color:#fff9;border:1px solid var(--border);background:#ffffff0a}.btn-ghost:hover:not(:disabled){color:#fff;background:#ffffff14;border-color:#ffffff1f}.btn-danger{color:var(--red);background:#f8717114;border:1px solid #f871712e}.btn-danger:hover:not(:disabled){background:#f8717126;box-shadow:0 0 12px #f871711a}.btn-sm{padding:6px 14px;font-size:.75rem}.btn-full{width:100%}.processing-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-md);z-index:10;background:#020308d9;flex-direction:column;justify-content:center;align-items:center;gap:18px;display:flex;position:absolute;inset:0}.spinner{border:3px solid #00d4ff14;border-top-color:var(--cyan);border-radius:50%;width:44px;height:44px;animation:.75s linear infinite spin;box-shadow:0 0 12px #00d4ff26}@keyframes spin{to{transform:rotate(360deg)}}.processing-text{font-family:var(--font-display);color:var(--cyan);letter-spacing:.06em;text-shadow:0 0 12px #00d4ff40;font-size:.85rem;font-weight:600}.empty-state{text-align:center;color:#ffffff40;padding:48px 24px}.empty-icon{opacity:.35;filter:drop-shadow(0 0 12px #00d4ff26);margin-bottom:14px;font-size:3.5rem}.empty-title{font-family:var(--font-display);color:#ffffff73;margin-bottom:8px;font-size:1rem;font-weight:700}.empty-text{font-size:.8rem;line-height:1.5}.error-banner{border-radius:var(--radius-sm);color:var(--red);background:#f871710f;border:1px solid #f8717133;align-items:flex-start;gap:10px;margin-top:16px;padding:12px 18px;font-size:.8rem;display:flex}.mode-tabs{border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff08;gap:4px;margin-bottom:20px;padding:4px;display:flex}.mode-tab{cursor:pointer;font-family:var(--font-display);color:#ffffff59;letter-spacing:.03em;background:0 0;border:none;border-radius:8px;flex:1;padding:8px 16px;font-size:.78rem;font-weight:600;transition:all .2s}.mode-tab.active{background:var(--cyan-dim);color:var(--cyan);border:1px solid #00c8ff4d;box-shadow:0 0 12px #00d4ff14}.app-footer{text-align:center;color:#ffffff2e;letter-spacing:.04em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#02030899;border-top:1px solid #00c8ff0f;padding:16px 40px;font-size:.72rem}.footer-link{color:var(--cyan);opacity:.55;text-decoration:none;transition:all .2s}.footer-link:hover{opacity:1;text-shadow:0 0 8px #00d4ff4d}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#00d4ff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00d4ff4d}@media (width<=1024px){.main-content{grid-template-columns:1fr;padding:24px}.upload-card{grid-area:1/1}.webcam-card{grid-area:2/1}.results-card{grid-area:3/1}.stats-row{grid-template-columns:repeat(2,1fr)}.app-header{padding:14px 20px}.df-mode-toggle{display:none}}@media (width<=640px){.app-header{padding:12px 16px}.logo-text{font-size:1.1rem}.main-content{gap:16px;padding:16px}.card-body{padding:16px}.stats-row{grid-template-columns:1fr 1fr}}.login-root{min-height:100vh;display:flex;position:relative;overflow:hidden}.login-particles{pointer-events:none;z-index:0;position:fixed;inset:0}.particle{opacity:0;background:radial-gradient(circle,#00d4ff99,#0000);border-radius:50%;animation:linear infinite floatParticle;position:absolute}@keyframes floatParticle{0%{opacity:0;transform:translateY(20px)scale(.5)}20%{opacity:.5}80%{opacity:.5}to{opacity:0;transform:translateY(-80px)scale(1.2)}}.login-left{z-index:1;background:url(/wallpaper.png) 50%/cover no-repeat;flex:1.2;align-items:flex-end;display:flex;position:relative}.login-left:before{content:"";background:linear-gradient(135deg,#020308b3 0%,#060a1680 50%,#8b5cf61f 100%);position:absolute;inset:0}.login-brand-overlay{z-index:1;background:linear-gradient(#0000 0%,#020308f2 100%);flex-direction:column;gap:24px;width:100%;padding:48px;display:flex;position:relative}.login-brand{flex-direction:column;gap:10px;display:flex}.login-logo-img{object-fit:cover;border:2px solid #00d4ff33;border-radius:18px;width:72px;height:72px;margin-bottom:8px;box-shadow:0 0 30px #00d4ff59,0 0 70px #8b5cf626}.login-brand-name{font-family:var(--font-display);background:var(--grad-brand);-webkit-text-fill-color:transparent;letter-spacing:-.03em;filter:drop-shadow(0 0 20px #00d4ff33);-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:800;line-height:1}.login-brand-tagline{color:#ffffff80;letter-spacing:.04em;font-size:1rem;font-weight:400}.login-features{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.login-feature-chip{color:#ffffffa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00d4ff0f;border:1px solid #00d4ff26;border-radius:100px;align-items:center;gap:8px;padding:8px 16px;font-size:.78rem;font-weight:600;transition:all .25s;display:flex}.login-feature-chip:hover{color:#fff;background:#00d4ff1f;border-color:#00c8ff66;box-shadow:0 0 12px #00d4ff1a}.login-tech-stack{flex-wrap:wrap;gap:8px;display:flex}.tech-badge{color:#ffffff59;letter-spacing:.06em;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:4px 12px;font-size:.68rem;font-weight:600}.login-right{-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);z-index:1;background:#020308f0;flex:.8;justify-content:center;align-items:center;padding:48px 40px;display:flex;box-shadow:-30px 0 60px #0000004d}.login-card{width:100%;max-width:400px}.login-card-top{text-align:center;margin-bottom:36px}.login-card-logo{object-fit:cover;border:2px solid #00d4ff2e;border-radius:16px;width:64px;height:64px;margin-bottom:22px;box-shadow:0 0 24px #00d4ff4d,0 0 50px #8b5cf61f}.login-card-title{font-family:var(--font-display);color:#f0f4f8;letter-spacing:-.02em;margin-bottom:6px;font-size:1.75rem;font-weight:800}.login-card-subtitle{color:#ffffff59;font-size:.82rem}.login-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:#ffffff80;letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:700}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{pointer-events:none;z-index:1;font-size:.9rem;position:absolute;left:14px}.form-input{border-radius:var(--radius-sm);color:#f0f4f8;width:100%;font-family:var(--font-body);background:#ffffff0a;border:1px solid #00c8ff1a;outline:none;padding:13px 14px 13px 42px;font-size:.88rem;transition:all .25s}.form-input::placeholder{color:#fff3}.form-input:focus{background:#00d4ff0a;border-color:#00c8ff66;box-shadow:0 0 0 3px #00d4ff0f,0 0 20px #00d4ff0d}.input-eye-btn{cursor:pointer;opacity:.4;background:0 0;border:none;padding:4px;font-size:.95rem;line-height:1;transition:opacity .2s;position:absolute;right:12px}.input-eye-btn:hover{opacity:.9}.login-error{border-radius:var(--radius-sm);color:var(--red);background:#f8717114;border:1px solid #f8717133;align-items:center;gap:8px;padding:11px 14px;font-size:.8rem;display:flex}.login-submit{letter-spacing:.03em;margin-top:4px;padding:14px;font-size:.92rem}.login-demo-hint{border-top:1px solid #00c8ff0f;flex-direction:column;align-items:center;gap:8px;margin-top:28px;padding-top:22px;display:flex}.demo-hint-label{color:#ffffff40;text-transform:uppercase;letter-spacing:.12em;margin-bottom:4px;font-size:.68rem;font-weight:700}.demo-cred-btn{border-radius:var(--radius-sm);color:#ffffff80;width:100%;font-family:var(--font-display);cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #00c8ff14;padding:9px 16px;font-size:.78rem;font-weight:600;transition:all .25s}.demo-cred-btn:hover{color:var(--cyan);background:#00d4ff0f;border-color:#00c8ff40;box-shadow:0 0 8px #00d4ff0f}@media (width<=768px){.login-left{display:none}.login-right{flex:1}}.history-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:500;background:#0000008c;justify-content:flex-end;display:flex;position:fixed;inset:0}.history-panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#060a16f7;border-left:1px solid #00c8ff14;flex-direction:column;width:min(520px,100vw);height:100vh;animation:.35s cubic-bezier(.16,1,.3,1) slideIn;display:flex;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.history-header{background:#00d4ff05;border-bottom:1px solid #00c8ff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.history-content{flex-direction:column;flex:1;gap:10px;padding:12px;display:flex;overflow-y:auto}.history-item{border-radius:var(--radius-md);background:#ffffff05;border:1px solid #ffffff0a;gap:12px;padding:14px;transition:all .25s;display:flex}.history-item:hover{background:#00d4ff08;border-color:#00c8ff2e}.history-thumb-wrap{flex-shrink:0;position:relative}.history-thumb{object-fit:cover;border-radius:var(--radius-sm);border:1px solid #ffffff0f;width:68px;height:68px}.history-thumb-badge{background:#060a16f2;border:1px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.85rem;display:flex;position:absolute;bottom:-4px;right:-4px}.history-item-info{flex:1;min-width:0}.history-item-id{font-family:var(--font-mono);color:var(--cyan);font-size:.7rem;font-weight:700}.history-item-time{color:#ffffff40;font-size:.68rem}.history-item-stats{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.hist-stat{color:#fff6;background:#ffffff08;border:1px solid #ffffff0f;border-radius:100px;padding:2px 9px;font-size:.7rem;font-weight:600}.source-badge.image{color:#818cf8;background:#818cf80f;border-color:#818cf840}.source-badge.webcam{color:#4ade80;background:#4ade800f;border-color:#4ade8040}.history-faces-row{flex-wrap:wrap;gap:6px;display:flex}.history-face-chip{background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;align-items:center;gap:6px;padding:5px 9px;display:flex}.emotion-bar-wrap{flex-direction:column;gap:6px;display:flex}.emotion-bar-label{font-family:var(--font-display);align-items:center;gap:8px;font-size:.88rem;font-weight:700;display:flex}.emotion-bar-track{background:#ffffff0a;border-radius:3px;height:5px;overflow:hidden}.emotion-bar-fill{border-radius:3px;height:100%;transition:width .6s cubic-bezier(.16,1,.3,1);box-shadow:0 0 6px}.df-mode-toggle{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff08;border:1px solid #00c8ff14;border-radius:14px;gap:4px;padding:4px;display:flex}.df-mode-btn{color:#ffffff59;font-family:var(--font-display);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:7px 20px;font-size:.78rem;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.df-mode-btn>span{font-size:1.15rem}.df-mode-btn:hover{color:#ffffffb3;background:#ffffff0a}.df-mode-btn.active{color:var(--cyan);background:#00d4ff1a;border-color:#00c8ff4d;box-shadow:0 0 16px #00d4ff14,inset 0 0 12px #00d4ff0a}.df-mode-btn.deepface.active{color:var(--amber);background:#fbbf2414;border-color:#fbbf244d;box-shadow:0 0 16px #fbbf2414,inset 0 0 12px #fbbf240a}.deepface-badge{color:var(--amber);letter-spacing:.06em;white-space:nowrap;background:#fbbf2414;border:1px solid #fbbf2438;border-radius:100px;padding:4px 12px;font-size:.68rem;font-weight:700}.drop-zone.deepface-drop{background:#fbbf2404;border-color:#fbbf242e}.drop-zone.deepface-drop:hover,.drop-zone.deepface-drop.dragging{border-color:#fbbf2473;box-shadow:0 0 30px #fbbf2414}.deepface-attribution{border-radius:var(--radius-sm);color:#fff6;background:#fbbf240a;border:1px solid #fbbf241a;align-items:flex-start;gap:10px;margin-top:20px;padding:12px 16px;font-size:.75rem;line-height:1.5;display:flex}.deepface-attribution>span:first-child{flex-shrink:0;font-size:1rem}::selection{color:#fff;background:#00d4ff40}:focus-visible{outline-offset:2px;outline:2px solid #00d4ff66}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.upload-card,.webcam-card{animation:.5s cubic-bezier(.16,1,.3,1) both fadeInUp}.webcam-card{animation-delay:80ms}.results-card{animation:.5s cubic-bezier(.16,1,.3,1) .16s both fadeInUp}.App{all:unset}
