@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{min-height:100vh;line-height:1.5}img,video{display:block;max-width:100%}button{font-family:inherit}:root{--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--ink: #1a1714;--ink-2: #3d3830;--ink-3: #6b6259;--ink-muted: #9a9088;--cream: #f7f3ee;--cream-2: #ede8e1;--cream-3: #e0d9cf;--cream-4: #cfc7bb;--amber: #c8863a;--amber-light: #e8a838;--amber-dark: #9e6420;--amber-faint: rgba(200, 134, 58, .1);--amber-glow: rgba(200, 134, 58, .25);--surface: #ffffff;--surface-2: #faf8f5;--surface-3: #f2ede6;--border: rgba(26, 23, 20, .08);--border-2: rgba(26, 23, 20, .14);--green: #4a7c59;--green-faint: rgba(74, 124, 89, .1);--red: #b84040;--red-faint: rgba(184, 64, 64, .08);--shadow-xs: 0 1px 3px rgba(26,23,20,.06), 0 1px 2px rgba(26,23,20,.04);--shadow-sm: 0 2px 8px rgba(26,23,20,.07), 0 1px 3px rgba(26,23,20,.04);--shadow-md: 0 4px 20px rgba(26,23,20,.09), 0 2px 6px rgba(26,23,20,.05);--shadow-lg: 0 12px 40px rgba(26,23,20,.12), 0 4px 12px rgba(26,23,20,.06);--shadow-amber: 0 4px 20px rgba(200,134,58,.3);--r-sm: 6px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--r-2xl: 32px;--ease: cubic-bezier(.25, .1, .25, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--cream);color:var(--ink);min-height:100vh;line-height:1.6}button{font-family:inherit;cursor:pointer;border:none;background:none}a{text-decoration:none;color:inherit}.app-root{display:flex;flex-direction:column;min-height:100vh}.page-wrap{flex:1;transition:opacity .18s var(--ease),transform .18s var(--ease)}.page-wrap.fading{opacity:0;transform:translateY(6px)}.navbar{position:sticky;top:0;z-index:100;background:#f7f3eed9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}.navbar.scrolled{border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}.navbar-inner{max-width:1080px;margin:0 auto;padding:0 1.5rem;height:60px;display:flex;align-items:center;gap:2rem}.nav-logo{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--ink);letter-spacing:-.02em;transition:opacity .2s;margin-right:auto}.nav-logo:hover{opacity:.75}.nav-logo-icon{font-size:1.3rem;color:var(--amber);line-height:1}.nav-links{display:flex;align-items:center;gap:.25rem}.nav-link{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:var(--r-md);font-size:.875rem;font-weight:500;color:var(--ink-3);transition:background .18s,color .18s}.nav-link:hover{background:var(--cream-2);color:var(--ink)}.nav-link.active{background:var(--cream-3);color:var(--ink);font-weight:600}.nav-cta{padding:.45rem 1.1rem;border-radius:var(--r-md);background:var(--ink);color:var(--cream);font-size:.85rem;font-weight:600;transition:background .2s,transform .15s;letter-spacing:.01em}.nav-cta:hover{background:var(--ink-2);transform:translateY(-1px)}.section-tag{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:.85rem}.section-tag:before{content:"";display:inline-block;width:18px;height:1.5px;background:var(--amber);border-radius:2px}.section-title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--ink);margin-bottom:.9rem}.section-desc{font-size:1rem;color:var(--ink-3);max-width:520px;line-height:1.7;margin-bottom:2.5rem}.home-page{--container: 1080px}.hero{position:relative;overflow:hidden;min-height:78vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 1.5rem 5rem;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(200,134,58,.08) 0%,transparent 70%),var(--cream)}.hero:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.hero>*{position:relative;z-index:1}.hero-tag{display:inline-flex;align-items:center;gap:.55rem;background:var(--amber-faint);border:1px solid rgba(200,134,58,.22);color:var(--amber-dark);font-size:.75rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;padding:.38rem 1rem;border-radius:999px;margin-bottom:2rem;animation:fade-up .6s var(--ease-out) both}.hero-tag-dot{width:6px;height:6px;background:var(--amber);border-radius:50%;animation:breathe-amber 2.4s ease-in-out infinite}@keyframes breathe-amber{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.hero-title{font-family:var(--font-display);font-size:clamp(3rem,8vw,5.5rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:var(--ink);margin-bottom:1.25rem;animation:fade-up .6s .1s var(--ease-out) both}.hero-title-accent{color:var(--amber);position:relative;display:inline-block}.hero-title-accent:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:4px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='4'%3E%3Cpath d='M0 2 Q5 0 10 2 Q15 4 20 2 Q25 0 30 2 Q35 4 40 2' stroke='%23c8863a' stroke-width='1.5' fill='none' opacity='0.5'/%3E%3C/svg%3E");background-size:40px 4px;background-repeat:repeat-x}.hero-subtitle{font-size:clamp(1rem,2.5vw,1.15rem);color:var(--ink-3);max-width:540px;margin:0 auto 2.5rem;line-height:1.75;font-weight:400;animation:fade-up .6s .2s var(--ease-out) both}.hero-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center;animation:fade-up .6s .3s var(--ease-out) both}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn-hero-primary{display:inline-flex;align-items:center;gap:.6rem;padding:.8rem 1.6rem;background:var(--ink);color:var(--cream);border-radius:var(--r-lg);font-weight:600;font-size:.95rem;letter-spacing:.01em;transition:background .2s,transform .2s var(--ease-spring),box-shadow .2s;box-shadow:var(--shadow-md)}.btn-hero-primary:hover{background:var(--ink-2);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-hero-primary:active{transform:translateY(0)}.btn-hero-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.4rem;background:var(--surface);color:var(--ink-2);border-radius:var(--r-lg);font-weight:500;font-size:.9rem;border:1px solid var(--border-2);transition:background .18s,border-color .18s,transform .18s;box-shadow:var(--shadow-xs)}.btn-hero-secondary:hover{background:var(--cream-2);border-color:var(--cream-4);transform:translateY(-1px)}.emotion-orbit{margin-top:3.5rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;max-width:600px;animation:fade-up .6s .5s var(--ease-out) both}.emotion-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:.82rem;font-weight:500;color:var(--ink-2);box-shadow:var(--shadow-xs);animation:chip-float var(--delay, 0s) 3s ease-in-out infinite alternate;transition:transform .2s,box-shadow .2s}.emotion-chip:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}@keyframes chip-float{0%{transform:translateY(0)}to{transform:translateY(-5px)}}.chip-emoji{font-size:1rem}.chip-label{letter-spacing:.01em}.stats-strip{display:flex;justify-content:center;gap:0;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0;overflow:hidden}.stat-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.75rem 1rem;border-right:1px solid var(--border);text-align:center;transition:background .18s}.stat-item:last-child{border-right:none}.stat-item:hover{background:var(--surface-2)}.stat-value{font-family:var(--font-display);font-size:1.9rem;font-weight:700;color:var(--ink);letter-spacing:-.03em;line-height:1}.stat-label{font-size:.77rem;color:var(--ink-muted);margin-top:.35rem;font-weight:500;letter-spacing:.01em}.showcase{max-width:var(--container, 1080px);margin:0 auto;padding:5rem 1.5rem}.emotion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.emotion-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.5rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;box-shadow:var(--shadow-xs);overflow:hidden;transition:transform .2s var(--ease-spring),box-shadow .2s;cursor:default}.emotion-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-color, var(--amber));border-radius:var(--r-lg) var(--r-lg) 0 0;opacity:.7}.emotion-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}.emotion-card-emoji{font-size:2.2rem;line-height:1;transition:transform .2s var(--ease-spring)}.emotion-card:hover .emotion-card-emoji{transform:scale(1.15)}.emotion-card-name{font-size:.8rem;font-weight:600;color:var(--ink-2);letter-spacing:.01em}.emotion-card-bar{width:32px;height:3px;border-radius:99px;background:var(--card-color, var(--amber));opacity:.35}.features{background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:5rem 1.5rem}.features>*{max-width:var(--container, 1080px);margin-left:auto;margin-right:auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;max-width:var(--container, 1080px);margin:0 auto}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:2rem;box-shadow:var(--shadow-xs);transition:box-shadow .2s,transform .2s}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.feature-icon{width:48px;height:48px;background:var(--amber-faint);border:1px solid rgba(200,134,58,.18);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--amber);margin-bottom:1.25rem}.feature-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;margin-bottom:.5rem}.feature-desc{font-size:.9rem;color:var(--ink-3);line-height:1.7}.cta-banner{padding:5rem 1.5rem;background:var(--cream)}.cta-banner-inner{max-width:640px;margin:0 auto;text-align:center}.cta-banner h2{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;letter-spacing:-.03em;color:var(--ink);margin-bottom:.75rem}.cta-banner p{color:var(--ink-3);font-size:1rem;margin-bottom:2rem;line-height:1.7}.detect-page{max-width:1080px;margin:0 auto;padding:3rem 1.5rem 4rem}.detect-header{text-align:center;margin-bottom:2.5rem}.detect-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.9rem}.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.ok{background:var(--green);box-shadow:0 0 8px #4a7c5980;animation:pulse-green 2s infinite}.status-dot.err{background:var(--red)}.status-dot.idle{background:var(--ink-muted)}@keyframes pulse-green{0%,to{box-shadow:0 0 6px #4a7c5966}50%{box-shadow:0 0 14px #4a7c59b3}}.detect-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.035em;color:var(--ink);margin-bottom:.6rem}.detect-sub{color:var(--ink-3);font-size:.97rem}.error-banner{display:flex;align-items:center;gap:.75rem;background:var(--red-faint);color:var(--red);border:1px solid rgba(184,64,64,.2);padding:.875rem 1.25rem;border-radius:var(--r-md);font-size:.88rem;font-weight:500;margin-bottom:2rem;animation:slide-down .3s var(--ease-out)}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.detect-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:820px){.detect-grid{grid-template-columns:1.35fr 1fr;align-items:start}}.d-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.5rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.d-card:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.6) 50%,transparent 90%)}.d-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.d-card-label{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}.live-badge{display:inline-flex;align-items:center;gap:.45rem;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);background:var(--surface-3);border:1px solid var(--border);padding:.28rem .7rem;border-radius:999px}.live-badge.live{color:var(--green);background:var(--green-faint);border-color:#4a7c5933}.live-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.live-badge.live .live-dot{animation:live-blink 1.4s ease-in-out infinite}@keyframes live-blink{0%,to{opacity:1}50%{opacity:.3}}.video-wrap{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:var(--r-lg);overflow:hidden;background:var(--surface-3);border:1px solid var(--border);margin-bottom:1.25rem}.corner{position:absolute;width:20px;height:20px;z-index:5;pointer-events:none}.corner.tl{top:10px;left:10px;border-top:2px solid var(--amber);border-left:2px solid var(--amber);border-radius:3px 0 0}.corner.tr{top:10px;right:10px;border-top:2px solid var(--amber);border-right:2px solid var(--amber);border-radius:0 3px 0 0}.corner.bl{bottom:10px;left:10px;border-bottom:2px solid var(--amber);border-left:2px solid var(--amber);border-radius:0 0 0 3px}.corner.br{bottom:10px;right:10px;border-bottom:2px solid var(--amber);border-right:2px solid var(--amber);border-radius:0 0 3px}.scan-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--amber-light),transparent);z-index:6;animation:scan-anim 2.5s linear infinite;opacity:.8}@keyframes scan-anim{0%{top:0%}to{top:100%}}.video-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--ink-3);z-index:3}.cam-icon-wrap{width:52px;height:52px;border-radius:50%;background:var(--cream-3);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;color:var(--ink-muted)}.video-placeholder p{font-weight:500;font-size:.95rem;color:var(--ink-2)}.video-placeholder span{font-size:.8rem;color:var(--ink-muted)}.video-el{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);position:relative;z-index:2}.cam-controls{display:flex;gap:.75rem}.btn-start{flex:1;display:flex;align-items:center;justify-content:center;gap:.55rem;padding:.8rem 1.25rem;background:var(--ink);color:var(--cream);border-radius:var(--r-md);font-weight:600;font-size:.9rem;transition:background .2s,transform .15s var(--ease-spring),box-shadow .2s;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.btn-start:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.08) 50%,transparent 60%);transform:translate(-100%);transition:transform .5s var(--ease)}.btn-start:hover:not(:disabled):after{transform:translate(100%)}.btn-start:hover:not(:disabled){background:var(--ink-2);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-start:active:not(:disabled){transform:translateY(0)}.btn-start:disabled{opacity:.38;cursor:not-allowed}.btn-stop-detection{flex:1;display:flex;align-items:center;justify-content:center;gap:.55rem;padding:.8rem 1.25rem;background:var(--red-faint);color:var(--red);border:1px solid rgba(184,64,64,.22);border-radius:var(--r-md);font-weight:600;font-size:.9rem;transition:background .18s,border-color .18s,transform .15s}.btn-stop-detection:hover{background:#b8404021;border-color:#b8404059;transform:translateY(-1px)}.results-card{min-height:300px;display:flex;flex-direction:column}.empty-result{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem 1rem;gap:.85rem;color:var(--ink-3)}.empty-orb{position:relative;width:80px;height:80px;margin-bottom:.5rem}.orb-emoji{position:absolute;font-size:1.5rem;animation:orbit-spin 8s linear infinite;animation-delay:calc(var(--oi) * -2s)}.orb-emoji:nth-child(1){top:0;left:50%;transform:translate(-50%)}.orb-emoji:nth-child(2){top:50%;right:0;transform:translateY(-50%)}.orb-emoji:nth-child(3){bottom:0;left:50%;transform:translate(-50%)}.orb-emoji:nth-child(4){top:50%;left:0;transform:translateY(-50%)}@keyframes orbit-spin{0%{transform:rotate(0) translate(30px) rotate(0)}to{transform:rotate(360deg) translate(30px) rotate(-360deg)}}.empty-result h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--ink-2)}.empty-result p{font-size:.85rem;color:var(--ink-muted);max-width:200px;line-height:1.6}.result-content{display:flex;flex-direction:column;gap:1.5rem}.primary-result{display:flex;align-items:center;gap:1.25rem;padding:1.25rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);position:relative;overflow:hidden}.primary-result:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--emotion-color, var(--amber));border-radius:3px 0 0 3px}.primary-emoji-wrap{width:70px;height:70px;border-radius:50%;background:var(--cream-2);border:2px solid var(--cream-4);display:flex;align-items:center;justify-content:center;flex-shrink:0;animation:float-gentle 3s ease-in-out infinite}@keyframes float-gentle{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.primary-emoji{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.15))}.primary-label{font-family:var(--font-display);font-size:1.7rem;font-weight:700;letter-spacing:-.025em;color:var(--ink);text-transform:capitalize;margin-bottom:.4rem}.confidence-pill{display:inline-flex;align-items:center;gap:.35rem;background:var(--amber-faint);border:1px solid rgba(200,134,58,.2);color:var(--amber-dark);padding:.25rem .75rem;border-radius:999px;font-size:.78rem;font-weight:600;letter-spacing:.02em}.confidence-pill:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--amber)}.probs-section{display:flex;flex-direction:column;gap:.85rem}.probs-heading{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted)}.probs-list{display:flex;flex-direction:column;gap:.6rem}.prob-row{display:flex;flex-direction:column;gap:.28rem}.prob-meta{display:flex;align-items:center;gap:.4rem}.prob-emoji{font-size:.85rem}.prob-name{font-size:.82rem;font-weight:500;color:var(--ink-3);text-transform:capitalize;flex:1}.prob-row.top .prob-name{color:var(--ink);font-weight:600}.prob-pct{font-size:.78rem;font-weight:600;color:var(--ink-muted);font-variant-numeric:tabular-nums}.prob-row.top .prob-pct{color:var(--amber-dark)}.prob-track{height:5px;background:var(--cream-3);border-radius:999px;overflow:hidden}.prob-fill{height:100%;border-radius:999px;background:var(--fill-color, var(--amber));transition:width .5s var(--ease-out);opacity:.7}.prob-row.top .prob-fill{opacity:1}.site-footer{text-align:center;padding:2rem 1.5rem;border-top:1px solid var(--border);background:var(--surface)}.site-footer p{font-size:.78rem;color:var(--ink-muted);letter-spacing:.01em}@media(max-width:640px){.stats-strip{flex-wrap:wrap}.stat-item{flex:1 1 48%;border-bottom:1px solid var(--border)}.nav-links{display:none}.hero-title{font-size:2.6rem}.emotion-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}@media(max-width:480px){.detect-page{padding:2rem 1rem 3rem}.d-card{padding:1.25rem}.primary-result{flex-direction:column;text-align:center}.primary-result:before{width:100%;height:3px;bottom:auto;right:0;border-radius:3px 3px 0 0}}
