:root{--color-bg: #FFF8F0;--color-bg-secondary: #FFF0E0;--color-surface: #FFFFFF;--color-primary: #2ECC71;--color-primary-dark: #27AE60;--color-primary-light: #A8E6CF;--color-accent: #FF6B35;--color-accent-dark: #E55A2B;--color-secondary: #6C5CE7;--color-secondary-light: #A29BFE;--color-text: #2D3436;--color-text-secondary: #636E72;--color-text-light: #B2BEC3;--color-border: #DFE6E9;--color-error: #E74C3C;--color-success: #2ECC71;--gradient-hero: linear-gradient(135deg, #A8E6CF 0%, #DCEDC1 50%, #FFD3B6 100%);--gradient-primary: linear-gradient(135deg, #2ECC71 0%, #27AE60 100%);--gradient-accent: linear-gradient(135deg, #FF6B35 0%, #F7DC6F 100%);--gradient-secondary: linear-gradient(135deg, #6C5CE7 0%, #A29BFE 100%);--gradient-scan: linear-gradient(180deg, transparent 0%, rgba(46, 204, 113, .3) 50%, transparent 100%);--font-family: "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1.125rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-4xl: 3rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .16);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--max-width: 480px;--header-height: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;overflow-x:hidden}img,svg{display:block;max-width:100%}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:700}#root{min-height:100vh;display:flex;flex-direction:column}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes scanLine{0%{top:0}to{top:100%}}@keyframes progressFill{0%{width:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-100%) translate(-50%)}to{opacity:1;transform:translateY(0) translate(-50%)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0) translate(-50%)}to{opacity:0;transform:translateY(-100%) translate(-50%)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}@keyframes detectBox{0%{opacity:0;transform:scale(1.2)}50%{opacity:1;transform:scale(1)}to{opacity:.6;transform:scale(.98)}}.animate-fadeInUp{animation:fadeInUp .6s ease both}.animate-fadeIn{animation:fadeIn .4s ease both}.animate-delay-1{animation-delay:.1s}.animate-delay-2{animation-delay:.2s}.animate-delay-3{animation-delay:.3s}.animate-delay-4{animation-delay:.4s}.animate-delay-5{animation-delay:.5s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.header{position:sticky;top:0;z-index:100;background:#fff8f0d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);height:var(--header-height)}.header__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-md);height:100%;display:flex;align-items:center}.header__logo{display:flex;align-items:center;gap:var(--space-sm);font-weight:800;font-size:var(--font-size-lg);color:var(--color-text);transition:opacity var(--transition-fast)}.header__logo:hover{opacity:.8}.header__logo-icon{font-size:1.5rem}.header__logo-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer{margin-top:auto;padding:var(--space-xl) var(--space-md);text-align:center;border-top:1px solid var(--color-border)}.footer__inner{max-width:var(--max-width);margin:0 auto}.footer__text{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.footer__disclaimer{font-size:var(--font-size-xs);color:var(--color-text-light);margin-top:var(--space-xs)}.hero{position:relative;padding:var(--space-3xl) 0 var(--space-xl);text-align:center;overflow:hidden}.hero__bg{position:absolute;inset:0;z-index:-1;overflow:hidden}.hero__orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.4}.hero__orb--1{width:200px;height:200px;background:var(--color-primary-light);top:-40px;right:-40px;animation:float 6s ease-in-out infinite}.hero__orb--2{width:160px;height:160px;background:#ffd3b6;bottom:-20px;left:-30px;animation:float 8s ease-in-out infinite 1s}.hero__orb--3{width:120px;height:120px;background:var(--color-secondary-light);top:40%;left:50%;animation:float 7s ease-in-out infinite .5s}.hero__content{position:relative}.hero__emoji{font-size:2.5rem;margin-bottom:var(--space-lg);letter-spacing:.2em;animation:float 4s ease-in-out infinite}.hero__title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text);margin-bottom:var(--space-md);letter-spacing:-.02em}.hero__title-accent{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__subtitle{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:1.7}@media(min-width:768px){.hero__title{font-size:var(--font-size-4xl)}.hero__emoji{font-size:3rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);font-weight:600;border-radius:var(--radius-lg);transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 12px #2ecc714d}.btn--primary:hover:not(:disabled){box-shadow:0 6px 20px #2ecc7166;transform:translateY(-1px)}.btn--secondary{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border)}.btn--secondary:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn--accent{background:var(--gradient-accent);color:#fff;box-shadow:0 4px 12px #ff6b354d}.btn--accent:hover:not(:disabled){box-shadow:0 6px 20px #ff6b3566;transform:translateY(-1px)}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--color-bg-secondary);color:var(--color-text)}.btn--sm{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn--md{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-base)}.btn--lg{padding:var(--space-lg) var(--space-2xl);font-size:var(--font-size-md);border-radius:var(--radius-xl)}.btn--full{width:100%}.upload{margin-top:var(--space-xl)}.upload__input{display:none}.upload__dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--color-surface)}.upload__dropzone:hover,.upload__dropzone--active{border-color:var(--color-primary);background:#2ecc710a}.upload__dropzone--active{transform:scale(1.01);box-shadow:0 0 0 4px #2ecc7126}.upload__icon{font-size:3rem;margin-bottom:var(--space-md)}.upload__text{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--space-sm);line-height:1.6}.upload__text-highlight{color:var(--color-primary);font-weight:600}.upload__hint{font-size:var(--font-size-xs);color:var(--color-text-light)}.upload__preview{display:flex;flex-direction:column;gap:var(--space-lg)}.upload__image-wrapper{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);animation:fadeInScale .4s ease}.upload__image{width:100%;aspect-ratio:1;object-fit:cover;display:block}.upload__remove{position:absolute;top:var(--space-sm);right:var(--space-sm);width:32px;height:32px;border-radius:50%;background:#00000080;color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);cursor:pointer;border:none}.upload__remove:hover{background:#000000b3}.upload__error{margin-top:var(--space-md);padding:var(--space-md);background:#e74c3c14;color:var(--color-error);border-radius:var(--radius-sm);font-size:var(--font-size-sm);text-align:center}.features{margin-top:var(--space-3xl);padding-bottom:var(--space-2xl)}.features__title{font-size:var(--font-size-lg);color:var(--color-text-secondary);text-align:center;margin-bottom:var(--space-xl);font-weight:600}.features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.feature-card{text-align:center;padding:var(--space-lg) var(--space-sm);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:transform var(--transition-base),box-shadow var(--transition-base);position:relative}.feature-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.feature-card__step{position:absolute;top:-10px;left:50%;transform:translate(-50%);width:22px;height:22px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:var(--font-size-xs);font-weight:700;display:flex;align-items:center;justify-content:center}.feature-card__icon{font-size:2rem;margin-bottom:var(--space-sm)}.feature-card__title{font-size:var(--font-size-sm);font-weight:700;margin-bottom:var(--space-xs)}.feature-card__desc{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.5}@media(max-width:374px){.features__grid{grid-template-columns:1fr;gap:var(--space-sm)}}.landing{flex:1;max-width:var(--max-width);margin:0 auto;width:100%;padding:0 var(--space-md)}.scanner{width:100%;max-width:280px;animation:fadeInScale .5s ease}.scanner__frame{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:1}.scanner__image{width:100%;height:100%;object-fit:cover;display:block}.scanner__overlay{position:absolute;inset:0;background:#00000026}.scanner__line{position:absolute;left:0;width:100%;height:3px;background:var(--color-primary);box-shadow:0 0 12px var(--color-primary),0 0 40px #2ecc714d;animation:scanLine 2s ease-in-out infinite;z-index:2}.scanner__corners{position:absolute;inset:12%;z-index:1}.scanner__corner{position:absolute;width:20px;height:20px;border-color:var(--color-primary);border-style:solid;border-width:0}.scanner__corner--tl{top:0;left:0;border-top-width:3px;border-left-width:3px;border-top-left-radius:4px}.scanner__corner--tr{top:0;right:0;border-top-width:3px;border-right-width:3px;border-top-right-radius:4px}.scanner__corner--bl{bottom:0;left:0;border-bottom-width:3px;border-left-width:3px;border-bottom-left-radius:4px}.scanner__corner--br{bottom:0;right:0;border-bottom-width:3px;border-right-width:3px;border-bottom-right-radius:4px}.scanner__detect-box{position:absolute;top:20%;left:22%;width:56%;height:55%;border:2px solid rgba(46,204,113,.6);border-radius:var(--radius-md);animation:detectBox 2s ease-in-out infinite;z-index:1}.scanner__grid-line{position:absolute;opacity:.15;background:var(--color-primary)}.scanner__grid-line--h{width:100%;height:1px;left:0}.scanner__grid-line--v{height:100%;width:1px;top:0}.steps{width:100%;margin-top:var(--space-2xl);animation:fadeInUp .5s ease .3s both}.steps__progress-bar{width:100%;height:6px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-xl)}.steps__progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .1s linear}.steps__indicators{display:flex;justify-content:space-between;gap:var(--space-xs);margin-bottom:var(--space-lg)}.steps__item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);opacity:.35;transition:all var(--transition-base);flex:1}.steps__item--active{opacity:1}.steps__item--done{opacity:.6}.steps__icon{font-size:1.5rem}.steps__item--active .steps__icon{animation:pulse 1s ease-in-out infinite}.steps__label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-align:center}.steps__item--active .steps__label{color:var(--color-primary)}.steps__message{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary);min-height:1.6em;animation:fadeIn .3s ease}.reveal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center}.reveal__backdrop{position:absolute;inset:0;background:var(--color-bg);animation:fadeIn .4s ease}.reveal__content{position:relative;text-align:center;animation:bounceIn .8s ease}.reveal__emoji{font-size:5rem;margin-bottom:var(--space-lg);animation:float 2s ease-in-out infinite}.reveal__name{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text);margin-bottom:var(--space-sm)}.reveal__tagline{font-size:var(--font-size-md);color:var(--color-text-secondary)}.analysis{flex:1;max-width:var(--max-width);margin:0 auto;width:100%;padding:0 var(--space-md);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height))}.char-card{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}.char-card__bg{position:absolute;inset:0;opacity:.15}.char-card__content{position:relative;padding:var(--space-2xl) var(--space-xl);text-align:center;background:var(--color-surface)}.char-card__emoji{font-size:4.5rem;margin-bottom:var(--space-md);animation:float 3s ease-in-out infinite}.char-card__name{font-size:var(--font-size-3xl);font-weight:800;margin-bottom:var(--space-xs)}.char-card__tagline{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.char-card__match{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.char-card__match-bar{width:100%;max-width:240px;height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.char-card__match-fill{height:100%;border-radius:var(--radius-full);animation:progressFill 1s ease .5s both}.char-card__match-label{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-secondary)}.report{margin-top:var(--space-xl)}.report__title{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-lg)}.report__traits{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.report__trait{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.report__trait-icon{font-size:1.5rem;flex-shrink:0}.report__trait-label{font-size:var(--font-size-xs);color:var(--color-text-light);margin-bottom:2px}.report__trait-value{font-size:var(--font-size-sm);font-weight:600}.report__keywords{margin-bottom:var(--space-xl)}.report__keywords-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:600;margin-bottom:var(--space-sm)}.report__badges{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.report__badge{padding:var(--space-xs) var(--space-md);border:1.5px solid;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.report__description{padding:var(--space-lg);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.8}.share-btn{margin-top:var(--space-xl)}.retry-btn{margin-top:var(--space-md);margin-bottom:var(--space-xl)}.toast{position:fixed;top:calc(var(--header-height) + var(--space-md));left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--color-text);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--shadow-lg);animation:toastSlideIn .3s ease,toastSlideOut .3s ease 2.2s forwards}.toast__icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--color-primary);border-radius:50%;font-size:12px}.toast__message{white-space:nowrap}.result{flex:1;max-width:var(--max-width);margin:0 auto;width:100%;padding:var(--space-xl) var(--space-md) var(--space-2xl)}
