*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{width:100%;height:100%;overflow:hidden;background:#000;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{width:100%;height:100%}.app{position:relative;width:100%;height:100%;overflow:hidden;background:#08090c;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif}.camera-view{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-hidden{visibility:hidden}.topbar{position:absolute;top:0;left:0;right:0;padding:calc(env(safe-area-inset-top,12px) + 10px) 20px 14px;background:linear-gradient(to bottom,rgba(0,0,0,.62),transparent);display:flex;align-items:center;justify-content:space-between;z-index:10;pointer-events:none}.app-logo{display:flex;align-items:center;gap:7px;font-size:15px;font-weight:700;color:#fff;letter-spacing:.03em}.logo-icon{font-size:18px;background:linear-gradient(135deg,#4f8ef7,#7c5cf5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.status-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#00000059;border:1px solid rgba(255,255,255,.08);font-size:11px;font-weight:600;pointer-events:auto}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-moving .status-dot{background:#5a6278}.status-moving{color:#5a6278}.status-stable .status-dot{background:#4f8ef7;box-shadow:0 0 6px #4f8ef7;animation:dot-pulse .9s ease-in-out infinite}.status-stable{color:#4f8ef7}@keyframes dot-pulse{0%,to{opacity:1}50%{opacity:.3}}.aim-guide{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;pointer-events:none}.aim-frame{position:relative;width:80%;aspect-ratio:4/3;max-height:50vh}.vf-corner{position:absolute;width:22px;height:22px;border-color:#ffffffb3;border-style:solid}.vf-corner.tl{top:0;left:0;border-width:3px 0 0 3px;border-radius:4px 0 0}.vf-corner.tr{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 4px 0 0}.vf-corner.bl{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 4px}.vf-corner.br{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 4px}.scan-line{position:absolute;left:2px;right:2px;height:2px;background:linear-gradient(90deg,transparent,#4f8ef7cc,#7c5cf5cc,transparent);box-shadow:0 0 10px #4f8ef766;animation:scan 2s ease-in-out infinite}@keyframes scan{0%{top:2px;opacity:0}8%{opacity:1}92%{opacity:1}to{top:calc(100% - 4px);opacity:0}}.aim-hint{font-size:13px;color:#ffffff8c;text-shadow:0 1px 6px rgba(0,0,0,.8);font-family:Noto Sans KR,sans-serif;word-break:keep-all}.camera-error{position:absolute;top:80px;left:20px;right:20px;background:#f03c3c2e;border:1px solid rgba(240,60,60,.3);color:#f07878;font-size:13px;padding:10px 16px;border-radius:12px;text-align:center;z-index:20}.analyzing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#08090ce0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:30}.pulse-ring{position:absolute;width:80px;height:80px;border-radius:50%;border:2px solid #4f8ef740;animation:pulse-ring 1.6s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(.8);opacity:1}to{transform:scale(2.4);opacity:0}}.analyzing-icon{font-size:42px;background:linear-gradient(135deg,#4f8ef7,#7c5cf5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:icon-breathe 1.4s ease-in-out infinite}@keyframes icon-breathe{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.9);opacity:.6}}.analyzing-title{font-size:20px;font-weight:700;color:#eaedf5;font-family:Noto Sans KR,sans-serif}.dot-row{display:flex;gap:6px;margin-top:4px}.dot{width:6px;height:6px;border-radius:50%;background:#4f8ef7;animation:dot-bounce 1.2s ease-in-out infinite}@keyframes dot-bounce{0%,80%,to{transform:translateY(0);opacity:.35}40%{transform:translateY(-7px);opacity:1}}.tip-card{position:absolute;bottom:calc(env(safe-area-inset-bottom,24px) + 28px);left:20px;right:20px;background:#ffffff14;border:1px solid rgba(255,255,255,.13);border-radius:20px;padding:18px 20px 14px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:tip-fade-in .5s ease forwards}@keyframes tip-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tip-header{display:flex;align-items:center;gap:7px;margin-bottom:8px}.tip-icon{font-size:18px;line-height:1}.tip-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff6}.tip-title{font-size:15px;font-weight:700;color:#ffffffeb;margin-bottom:6px;font-family:Noto Sans KR,sans-serif}.tip-body{font-size:13px;line-height:1.75;color:#fff9;font-family:Noto Sans KR,sans-serif;word-break:keep-all;margin-bottom:14px}.tip-dots{display:flex;gap:5px;justify-content:center}.tip-dot{width:5px;height:5px;border-radius:50%;background:#fff3;transition:background .3s,transform .3s}.tip-dot.active{background:#4f8ef7;transform:scale(1.3)}.result-view{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:#f0f2f7;animation:fade-in-screen .3s ease forwards;z-index:40}@keyframes fade-in-screen{0%{opacity:0}to{opacity:1}}.result-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 14px 16px}.result-topbar{display:flex;align-items:center;justify-content:space-between;padding:calc(env(safe-area-inset-top,12px) + 14px) 0 14px;position:sticky;top:0;background:#f0f2f7;z-index:5}.topbar-right{display:flex;align-items:center;gap:8px}.result-topbar .app-logo{color:#1a1d2e}.result-topbar .logo-icon{background:linear-gradient(135deg,#4f8ef7,#7c5cf5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.result-badge{font-size:11px;font-weight:700;color:#1db88a;background:#1db88a1f;border:1px solid rgba(29,184,138,.28);padding:4px 12px;border-radius:100px;letter-spacing:.03em}.result-bottom-spacer{height:16px}.retake-bar{flex-shrink:0;padding:10px 14px calc(env(safe-area-inset-bottom,16px) + 10px);background:linear-gradient(to top,#f0f2f7 75%,transparent)}.retake-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:17px;border-radius:18px;background:linear-gradient(135deg,#4f8ef7,#7c5cf5);border:none;color:#fff;font-size:17px;font-weight:700;letter-spacing:.01em;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s,transform .12s;box-shadow:0 6px 24px #4f8ef761}.retake-btn:active{opacity:.85;transform:scale(.97)}.bilingual-list{display:flex;flex-direction:column;gap:10px}.bilingual-card{background:#fff;border-radius:18px;padding:16px 16px 14px;box-shadow:0 2px 12px #00000012,0 1px 3px #0000000a;animation:item-in .35s ease forwards;opacity:0;transition:box-shadow .3s,background .3s}.bilingual-card:nth-child(1){animation-delay:0s}.bilingual-card:nth-child(2){animation-delay:.06s}.bilingual-card:nth-child(3){animation-delay:.12s}.bilingual-card:nth-child(4){animation-delay:.18s}.bilingual-card:nth-child(5){animation-delay:.24s}.bilingual-card:nth-child(6){animation-delay:.3s}.bilingual-card.has-pattern{background:#fffbf2;box-shadow:0 2px 12px #f7b94f24,0 1px 3px #0000000a}.bilingual-card.is-speaking{opacity:1;background:#e8f0fe!important;box-shadow:0 0 0 2.5px #4f8ef7,0 6px 24px #4f8ef738!important;animation:sentence-reading-pulse 1.5s ease-in-out infinite}.card-tts-row{display:flex;justify-content:flex-end;margin-bottom:10px}.card-tts-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:100px;border:1.5px solid rgba(79,142,247,.2);background:#4f8ef712;color:#6a8fd8;font-size:12px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s,border-color .15s}.card-tts-btn.is-speaking{background:#4f8ef726;border-color:#4f8ef773;color:#4f8ef7}.bilingual-sentence--divider{margin-top:14px;padding-top:14px;border-top:1px solid rgba(0,0,0,.06)}.bilingual-card.is-speaking .bilingual-sentence--divider{border-top-color:#4f8ef726}.bilingual-en-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.bilingual-en{font-size:16px;line-height:1.8;color:#2e3458;font-family:Georgia,serif;flex:1}.bilingual-card.is-speaking .bilingual-en{color:#2a5cc8}.bilingual-ko{font-size:17px;line-height:1.95;color:#1a1d2e;font-family:"Noto Serif KR",serif;word-break:keep-all;margin-bottom:12px;margin-left:32px;padding-left:12px;border-left:2.5px solid rgba(124,92,245,.25)}.tts-btn{display:flex;align-items:center;gap:5px;margin-left:auto;padding:5px 12px;border-radius:100px;border:1.5px solid rgba(79,142,247,.2);background:#4f8ef712;color:#6a8fd8;font-size:11px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.tts-btn.is-speaking,.tts-btn.is-loading{background:#4f8ef726;border-color:#4f8ef773;color:#4f8ef7}@keyframes sentence-reading-pulse{0%,to{box-shadow:0 0 0 2.5px #4f8ef7,0 4px 16px #4f8ef726}50%{box-shadow:0 0 0 2.5px #3b7ef0,0 8px 30px #4f8ef752}}@keyframes item-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sentence-num{width:22px;height:22px;border-radius:50%;background:#4f8ef71f;color:#4f8ef7;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;transition:background .3s,color .3s,box-shadow .3s}.sentence-num.is-speaking{background:#4f8ef7;color:#fff;box-shadow:0 0 8px #4f8ef799;animation:num-breathe 1.5s ease-in-out infinite}@keyframes num-breathe{0%,to{transform:scale(1);box-shadow:0 0 6px #4f8ef780}50%{transform:scale(1.2);box-shadow:0 0 12px #4f8ef7cc}}.tts-inline-btn{flex-shrink:0;margin-top:2px;width:28px;height:28px;border-radius:50%;background:#4f8ef714;border:1.5px solid rgba(79,142,247,.18);color:#7a9ed8;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}.tts-inline-btn.is-speaking,.tts-inline-btn:active{background:#4f8ef72e;border-color:#4f8ef773;color:#4f8ef7}.sentence-structure{display:flex;align-items:flex-start;gap:7px;background:#7c5cf50f;border:1px solid rgba(124,92,245,.16);border-radius:10px;padding:9px 12px;margin-bottom:9px}.structure-icon{font-size:12px;color:#8b6ef5;flex-shrink:0;margin-top:1px}.structure-text{font-size:12px;color:#7060a8;line-height:1.65}.common-pattern{display:flex;align-items:center;gap:6px;background:#f7b94f1a;border:1px solid rgba(247,185,79,.3);border-radius:10px;padding:8px 12px}.pattern-star{font-size:11px;color:#e8a020;flex-shrink:0}.pattern-label{font-size:10px;font-weight:800;color:#c87800;letter-spacing:.05em;text-transform:uppercase;flex-shrink:0}.pattern-name{font-size:12px;color:#a06010;line-height:1.4}.capture-bar{position:absolute;bottom:calc(env(safe-area-inset-bottom,20px) + 24px);left:0;right:0;display:flex;align-items:center;justify-content:center;z-index:10}.capture-btn{position:relative;width:90px;height:90px;border-radius:50%;border:none;background:transparent;cursor:pointer;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;padding:0;touch-action:none;-webkit-user-select:none;user-select:none}.capture-progress-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:rotate(-90deg);pointer-events:none}.capture-track{fill:none;stroke:#ffffff2e;stroke-width:8}.capture-ring{fill:none;stroke-width:8;stroke-linecap:round;stroke-dasharray:188.5;stroke-dashoffset:188.5;filter:drop-shadow(0 0 8px rgba(59,158,255,.9))}.capture-btn.is-holding .capture-ring{animation:capture-ring-fill 1s linear forwards}@keyframes capture-ring-fill{0%{stroke-dashoffset:188.5}to{stroke-dashoffset:0}}.capture-inner{width:66px;height:66px;border-radius:50%;background:#ffffffeb;transition:transform .12s ease,background .12s ease;box-shadow:0 2px 16px #0006}.capture-btn.is-holding .capture-inner{transform:scale(.88);background:#fff}.capture-btn:active .capture-inner{transform:scale(.88)}@keyframes spin{to{transform:rotate(360deg)}}.mini-spinner{display:inline-block;width:11px;height:11px;border:2px solid rgba(79,142,247,.25);border-top-color:#4f8ef7;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}
