@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap");:root{--background:#06060a;--foreground:#fafafa;--primary:#6366f1;--primary-hover:#4f46e5;--primary-glow:rgba(99,102,241,.4);--accent:#f43f5e;--accent-glow:rgba(244,63,94,.3);--success:#22c55e;--success-glow:rgba(34,197,94,.2);--warning:#f59e0b;--surface-1:hsla(0,0%,100%,.02);--surface-2:hsla(0,0%,100%,.04);--surface-3:hsla(0,0%,100%,.07);--surface-4:hsla(0,0%,100%,.1);--border:hsla(0,0%,100%,.08);--border-hover:hsla(0,0%,100%,.16);--border-active:rgba(99,102,241,.5);--radius-xs:6px;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px;--shadow-sm:0 2px 8px rgba(0,0,0,.2);--shadow-md:0 8px 24px rgba(0,0,0,.3);--shadow-lg:0 16px 48px rgba(0,0,0,.4);--shadow-glow:0 0 30px var(--primary-glow);--shadow-glow-accent:0 0 30px var(--accent-glow)}*{box-sizing:border-box;padding:0;margin:0}body{background-color:var(--background);color:var(--foreground);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden;position:relative}body:before{background:radial-gradient(ellipse 80% 50% at 20% 40%,rgba(99,102,241,.08),transparent),radial-gradient(ellipse 60% 40% at 80% 20%,rgba(244,63,94,.06),transparent),radial-gradient(ellipse 50% 60% at 50% 80%,rgba(34,197,94,.04),transparent);z-index:-2;animation:meshShift 20s ease-in-out infinite alternate}body:after,body:before{content:"";position:fixed;inset:0;pointer-events:none}body:after{background-image:radial-gradient(circle,hsla(0,0%,100%,.03) 1px,transparent 0);background-size:32px 32px;z-index:-1}@keyframes meshShift{0%{filter:hue-rotate(0deg);opacity:1}50%{filter:hue-rotate(15deg);opacity:.8}to{filter:hue-rotate(-10deg);opacity:1}}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif;font-weight:700;letter-spacing:-.03em}a{color:inherit;text-decoration:none}.navbar{position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:100;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 1.5rem;background:rgba(6,6,10,.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-full);box-shadow:var(--shadow-md);width:max-content;max-width:calc(100% - 2rem);transition:all .3s ease}.navbar:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-family:Outfit,sans-serif;font-weight:700;font-size:.95rem;color:#fff;white-space:nowrap}.navbar-brand .brand-icon,.navbar-brand svg{color:var(--primary)}.navbar-links{gap:.25rem}.navbar-link,.navbar-links{display:flex;align-items:center}.navbar-link{gap:.4rem;padding:.4rem .75rem;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;color:#a1a1aa;background:transparent;border:none;cursor:pointer;transition:all .2s ease;text-decoration:none}.navbar-link:hover{color:#fff;background:var(--surface-3)}.navbar-link.active{color:#fff;background:var(--surface-4)}.glass{background:var(--surface-1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.glass,.glass-panel{border:1px solid var(--border)}.glass-panel{background:var(--surface-2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1)}.glass-panel:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.glass-panel-static{background:var(--surface-2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.bento-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:1.25rem;gap:1.25rem}@media (max-width:900px){.bento-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.bento-grid{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.5rem;border-radius:var(--radius-full);font-weight:600;font-family:Inter,sans-serif;font-size:.9rem;cursor:pointer;border:none;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:linear-gradient(135deg,var(--primary) 0,#818cf8 100%);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 40px var(--primary-glow),0 8px 24px rgba(0,0,0,.3)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--surface-3);color:var(--foreground);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-4);border-color:var(--border-hover);transform:translateY(-1px)}.btn-ghost{background:transparent;color:#a1a1aa;border:none}.btn-ghost:hover{color:#fff;background:var(--surface-3)}.stepper{justify-content:center;gap:0;margin-bottom:3rem}.stepper,.stepper-step{display:flex;align-items:center}.stepper-step{gap:.6rem}.stepper-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;border:2px solid var(--border);background:var(--surface-2);color:#52525b;transition:all .4s cubic-bezier(.4,0,.2,1);flex-shrink:0}.stepper-circle.active{border-color:var(--primary);background:linear-gradient(135deg,var(--primary),#818cf8);color:#fff;box-shadow:0 0 20px var(--primary-glow);animation:stepPulse 2s ease-in-out infinite}.stepper-circle.completed{border-color:var(--success);background:var(--success);color:#fff;box-shadow:0 0 12px var(--success-glow)}.stepper-label{font-size:.8rem;font-weight:500;color:#52525b;transition:color .3s ease;white-space:nowrap}.stepper-label.active{color:#fff}.stepper-label.completed{color:var(--success)}.stepper-line{width:48px;height:2px;background:var(--border);margin:0 .5rem;border-radius:1px;transition:background .4s ease;flex-shrink:0}.stepper-line.completed{background:linear-gradient(90deg,var(--success),var(--primary))}@keyframes stepPulse{0%,to{box-shadow:0 0 20px var(--primary-glow)}50%{box-shadow:0 0 30px var(--primary-glow),0 0 60px rgba(99,102,241,.15)}}.score-gauge{position:relative;width:180px;height:180px;display:flex;align-items:center;justify-content:center}.score-gauge svg{transform:rotate(-90deg);overflow:visible}.score-gauge-bg{fill:none;stroke:var(--surface-3);stroke-width:8}.score-gauge-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1)}.score-gauge-text{position:absolute;display:flex;flex-direction:column;align-items:center;gap:.15rem}.score-gauge-value{font-family:Outfit,sans-serif;font-size:2.5rem;font-weight:800;letter-spacing:-.03em;line-height:1}.score-gauge-label{font-size:.75rem;color:#71717a;font-weight:500;text-transform:uppercase;letter-spacing:.1em}.confidence-bar-container{display:flex;flex-direction:column;gap:.6rem}.confidence-bar-item{display:flex;align-items:center;gap:.75rem}.confidence-bar-label{font-size:.85rem;color:#e4e4e7;min-width:120px;font-weight:500}.confidence-bar-track{flex:1 1;height:8px;background:var(--surface-3);overflow:hidden}.confidence-bar-fill,.confidence-bar-track{border-radius:var(--radius-full);position:relative}.confidence-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),#818cf8);transition:width 1s cubic-bezier(.4,0,.2,1)}.confidence-bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2));border-radius:inherit}.confidence-bar-value{font-size:.8rem;color:#a1a1aa;min-width:36px;text-align:right;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.history-toggle{position:fixed;right:1.5rem;top:50%;transform:translateY(-50%);z-index:90;writing-mode:vertical-rl;padding:.75rem .4rem;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:#a1a1aa;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem;letter-spacing:.05em}.history-toggle:hover{color:#fff;border-color:var(--border-hover);background:var(--surface-4)}.history-sidebar{position:fixed;top:0;right:0;width:340px;height:100vh;background:rgba(6,6,10,.95);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-left:1px solid var(--border);z-index:95;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,.4)}.history-sidebar.open{transform:translateX(0)}.history-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.history-sidebar-header h3{font-size:1rem;color:#fff}.history-sidebar-body{flex:1 1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.history-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.history-card:hover{border-color:var(--border-hover);background:var(--surface-3)}.history-card img{width:48px;height:48px;border-radius:var(--radius-xs);object-fit:cover}.history-card-info{flex:1 1;min-width:0}.history-card-name{font-size:.8rem;font-weight:600;color:#e4e4e7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-card-meta{font-size:.7rem;color:#71717a;margin-top:.15rem}.history-card-score{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700;flex-shrink:0}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#52525b;text-align:center;gap:.5rem}.dropzone{position:relative;padding:4rem 2rem;width:100%;max-width:700px;border:2px dashed var(--border);border-radius:var(--radius-xl);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--surface-1)}.dropzone:hover{border-color:var(--border-hover);background:var(--surface-2)}.dropzone.dragging{border-color:var(--primary);background:rgba(99,102,241,.05);box-shadow:0 0 40px rgba(99,102,241,.1)}.dropzone-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(129,140,248,.1));display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.result-card{padding:1.5rem;display:flex;flex-direction:column}.result-card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.25rem}.result-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.result-card-title{font-size:1rem;color:#fff;font-weight:600}.result-card-subtitle{font-size:.75rem;color:#71717a;margin-top:.1rem}.tag{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-full);font-size:.8rem;color:#e4e4e7;font-weight:500;transition:all .2s ease}.tag:hover{border-color:var(--border-hover);background:var(--surface-4)}.tag-value{color:var(--primary);font-weight:700;font-size:.75rem}.text-detection-item{padding:1rem 1.25rem;background:rgba(34,197,94,.04);border:1px solid rgba(34,197,94,.15);border-radius:var(--radius-md);transition:all .2s ease}.text-detection-item:hover{background:rgba(34,197,94,.07);border-color:rgba(34,197,94,.25)}.moderation-safe{padding:1.5rem;background:rgba(34,197,94,.05);border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-md);display:flex;align-items:center;gap:1rem}.moderation-warning{padding:1.25rem;background:rgba(244,63,94,.08);border:1px solid rgba(244,63,94,.25);display:flex;align-items:flex-start;gap:.75rem}.moderation-warning,.skeleton{border-radius:var(--radius-md)}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.footer{margin-top:auto;padding:2rem;text-align:center;border-top:1px solid var(--border)}.footer-badges{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.footer-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);font-size:.7rem;color:#71717a;font-weight:500}.footer-badge svg{width:12px;height:12px}.footer-text{font-size:.7rem;color:#3f3f46;margin-top:.75rem}.text-gradient{background:linear-gradient(135deg,#fff,#a1a1aa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-gradient-primary{background:linear-gradient(135deg,#818cf8,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.animate-fade-in{animation:fadeIn .6s cubic-bezier(.16,1,.3,1) forwards}.animate-fade-in-scale{animation:fadeInScale .5s cubic-bezier(.16,1,.3,1) forwards}.animate-spin{animation:spin 1s linear infinite}.delay-100{animation-delay:.1s;opacity:0}.delay-200{animation-delay:.2s;opacity:0}.delay-300{animation-delay:.3s;opacity:0}.delay-400{animation-delay:.4s;opacity:0}.delay-500{animation-delay:.5s;opacity:0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-4);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@media (max-width:768px){.navbar{top:.75rem;padding:.5rem 1rem}.stepper{margin-bottom:2rem}.stepper-label{display:none}.stepper-line{width:24px}.score-gauge{width:140px;height:140px}.score-gauge-value{font-size:2rem}.history-sidebar{width:100%}.history-toggle{display:none}}@media (max-width:480px){.stepper-circle{width:28px;height:28px;font-size:.7rem}.stepper-line{width:16px}}