:root{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#333;background-color:#fdfcfb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-width:320px;min-height:100vh}button{font-family:inherit}.home-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:2rem;background:linear-gradient(135deg,#fdfcfb,#e2d1c3);color:#333;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif}.home-header{text-align:center;margin-top:4rem}.logo-section{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}.logo-icon{color:#8e7dbe;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.home-header h1{font-size:2.5rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(to right,#6a11cb,#2575fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{font-size:1.1rem;color:#666;opacity:.8}.action-cards{display:flex;gap:2rem;width:100%;max-width:800px;justify-content:center;flex-wrap:wrap}.card{background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2.5rem;border-radius:24px;width:320px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.3);box-shadow:0 10px 30px #0000000d;display:flex;flex-direction:column;align-items:center}.card:hover{transform:translateY(-10px);background:#ffffffe6;box-shadow:0 20px 40px #0000001a}.card-icon{width:80px;height:80px;background:#f0f0f0;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:#555;transition:all .3s ease}.card:hover .card-icon{background:#8e7dbe;color:#fff;transform:scale(1.1)}.card h3{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.card p{font-size:1rem;color:#777}.home-footer{margin-bottom:2rem;color:#888;font-size:.9rem}@media(max-width:600px){.home-container{padding:1rem}.home-header{margin-top:2rem}.card{width:100%;padding:2rem}}.capture-container{height:100vh;display:flex;flex-direction:column;background:#000;color:#fff;position:relative;overflow:hidden}.capture-header{padding:1rem;display:flex;align-items:center;gap:1rem;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.back-button{background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;border-radius:50%;transition:background .3s}.back-button:hover{background:#ffffff1a}.camera-view{flex:1;display:flex;align-items:center;justify-content:center;position:relative}.video-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.face-guide{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:250px;height:350px;border:2px dashed rgba(255,255,255,.5);border-radius:150px;pointer-events:none;box-shadow:0 0 0 9999px #0000004d}.capture-controls{padding:2rem;text-align:center;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.guide-text{margin-bottom:1.5rem;font-size:.9rem;opacity:.8}.capture-button{width:80px;height:80px;border-radius:50%;background:#fff;padding:5px;border:none;cursor:pointer;transition:transform .2s}.capture-button:active{transform:scale(.9)}.inner-circle{width:100%;height:100%;border-radius:50%;border:2px solid #000;display:flex;align-items:center;justify-content:center;color:#000}.error-message{text-align:center;padding:2rem}.retry-button{margin-top:1rem;padding:.75rem 1.5rem;border-radius:30px;border:none;background:#fff;color:#000;display:flex;align-items:center;gap:.5rem;cursor:pointer}.preview-container{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa;color:#333}.preview-header{padding:1rem;display:flex;align-items:center;gap:1rem;background:#fff;border-bottom:1px solid #eee}.preview-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.image-wrapper{width:100%;max-width:400px;border-radius:24px;overflow:hidden;box-shadow:0 20px 40px #0000001a;margin-bottom:2rem}.image-wrapper img{width:100%;height:auto;display:block}.preview-hint{color:#666;font-size:1rem}.preview-actions{padding:2rem;display:flex;gap:1rem;background:#fff;border-top:1px solid #eee}.primary-button,.secondary-button{flex:1;padding:1rem;border-radius:16px;border:none;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:all .2s}.primary-button{background:#8e7dbe;color:#fff}.primary-button:hover{background:#7a6ab1}.secondary-button{background:#f0f0f0;color:#333}.secondary-button:hover{background:#e5e5e5}.error{justify-content:center;align-items:center;gap:1rem}.analysis-container{min-height:100vh;display:flex;flex-direction:column;background:#fff;color:#333}.analysis-header{padding:1rem;display:flex;align-items:center;gap:1rem;background:#fff}.analysis-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.loading-animation{position:relative;margin-bottom:2rem}.loading-icon{color:#8e7dbe;z-index:2;position:relative}.pulse-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;border-radius:50%;background:#8e7dbe;opacity:.2;animation:pulse 2s infinite}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:.5}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.thumbnail{margin-top:3rem;width:80px;height:80px;border-radius:50%;overflow:hidden;border:4px solid #f0f0f0}.thumbnail img{width:100%;height:100%;object-fit:cover}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
