:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.landing-page{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background:#fff;overflow:hidden;padding:0;margin:0}.landing-container{width:100%;max-width:480px;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;padding:40px 20px;box-sizing:border-box;background:linear-gradient(135deg,#eb9dff,#83ffe6);box-shadow:0 0 40px #00000080}.landing-title{font-size:56px;font-weight:700;color:#00d948;text-align:center;margin:0;text-shadow:0 4px 8px rgba(0,0,0,.3);animation:fadeInDown .8s ease-out}.landing-subtitle{font-size:22px;font-weight:500;color:#000;text-align:center;margin:0;animation:fadeIn 1s ease-out .3s both}.start-button{width:100%;max-width:400px;padding:18px 32px;font-size:18px;font-weight:600;color:#fff;background-color:#00d948;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00ff884d;animation:fadeInUp 1s ease-out .5s both;-webkit-tap-highlight-color:transparent}.start-button:hover{background-color:#00e67a;transform:translateY(-2px);box-shadow:0 6px 16px #0f86}.start-button:active{transform:translateY(0)}.history-button{width:100%;max-width:400px;padding:18px 32px;font-size:18px;font-weight:600;color:#fff;background-color:#d90000;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #ef44444d;animation:fadeInUp 1s ease-out .7s both;-webkit-tap-highlight-color:transparent}.history-button:hover{background-color:#dc2626;transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.history-button:active{transform:translateY(0)}@media(max-width:480px){.landing-page{background:transparent}.landing-container{box-shadow:none}.landing-title{font-size:48px}.landing-subtitle{font-size:20px}.start-button,.history-button{font-size:16px;padding:16px 28px}}.camera-page{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#fff;overflow:hidden}.camera-container{position:relative;width:100%;max-width:480px;height:100%;background-color:#000;display:flex;justify-content:center;align-items:center}.camera-video,.camera-canvas{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-video{z-index:1}.camera-canvas{z-index:50;background-color:transparent;pointer-events:none}.face-guide-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;display:flex;flex-direction:column;justify-content:center;align-items:center;pointer-events:none}.face-guide-icon{width:150%;height:auto;opacity:.5;filter:drop-shadow(0 0 5px rgba(255,255,255,.5))}.alignment-indicator{position:absolute;top:10%;padding:8px 16px;background-color:#f00c;color:#fff;border-radius:20px;font-weight:700;transition:background-color .3s}.alignment-indicator.aligned{background-color:#00c800cc}.loading-message,.error-message{position:absolute;z-index:200;background:#000c;color:#fff;padding:20px;border-radius:10px;text-align:center}.back-button{position:absolute;top:20px;left:20px;z-index:200;padding:12px 24px;background:#fffffff2;border:none;border-radius:8px;cursor:pointer;pointer-events:auto;font-size:16px;font-weight:600;color:#333;box-shadow:0 2px 8px #0003;transition:all .2s ease}.back-button:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.back-button:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.detecting-page{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background:#fff;overflow:hidden;padding:0;margin:0}.detecting-container{width:100%;max-width:480px;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;background:linear-gradient(135deg,#4ecdc4,#5effda);box-shadow:0 0 40px #00000080;position:relative}.frame-corners,.corner{display:none}.silhouette-icon{width:200px;height:200px;display:flex;align-items:center;justify-content:center;animation:pulse 2s ease-in-out infinite}.silhouette-image{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.silhouette-icon svg{width:100%;height:100%;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.detecting-text{font-size:32px;font-weight:600;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2);animation:fadeIn 1s ease-out}.detecting-text .dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}@media(max-width:480px){.detecting-page{background:transparent}.detecting-container{box-shadow:none}.silhouette-icon{width:180px;height:180px}.detecting-text{font-size:28px}}.detection-complete-page{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#fff;overflow:hidden}.complete-container{width:100%;max-width:480px;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px;text-align:center;background:linear-gradient(135deg,#4ecdc4,#5effda)}.complete-title{font-size:32px;font-weight:700;color:#be74ff;margin-bottom:40px;text-shadow:0 2px 4px rgba(0,0,0,.1);animation:fadeInScale .6s ease-out}.start-exercise-button{padding:18px 50px;font-size:20px;font-weight:600;color:#fff;background:linear-gradient(135deg,#a855f7,#be74ff);border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #a855f766;transition:all .3s ease;animation:fadeInUp .6s ease-out .3s both}.start-exercise-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #a855f780;background:linear-gradient(135deg,#9333ea,#7c3aed)}.start-exercise-button:active{transform:translateY(0);box-shadow:0 2px 10px #a855f766}.exercise-page{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#fff;overflow:hidden}.exercise-container{position:relative;width:100%;max-width:480px;height:100%;background-color:#000;display:flex;justify-content:center;align-items:center}.exercise-video,.exercise-canvas{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.exercise-video{z-index:1}.exercise-canvas{z-index:50;background-color:transparent;pointer-events:none}.calibration-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#00000080;z-index:100}.calibration-title{font-size:32px;font-weight:700;color:#fff;margin-bottom:20px;text-shadow:0 2px 4px rgba(0,0,0,.5);animation:fadeInScale .5s ease-out}.calibration-countdown{font-size:120px;font-weight:700;color:gold;text-shadow:0 4px 8px rgba(0,0,0,.5);animation:pulse 1s ease-in-out infinite}.calibration-text{font-size:18px;color:#fffc;margin-top:20px}.target-dot{position:absolute;width:60px;height:60px;background-color:#ff6b35;border-radius:50%;z-index:100;box-shadow:0 0 20px #ff6b3599;animation:pulse 1.5s ease-in-out infinite}.instruction-text{position:absolute;bottom:15%;left:50%;transform:translate(-50%);z-index:200;padding:12px 24px;background-color:#ff6b35e6;color:#fff;font-size:20px;font-weight:600;border-radius:8px;text-align:center;white-space:nowrap}.countdown-text{font-size:24px;font-weight:700;color:#0f8}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.exercise-finished-page{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#fff;overflow:hidden}.finished-container{width:100%;max-width:480px;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px;text-align:center;background:linear-gradient(135deg,#4ecdc4,#5effda)}.finished-title{font-size:36px;font-weight:700;color:#be74ff;margin-bottom:40px;text-shadow:0 2px 4px rgba(0,0,0,.1);animation:fadeInScale .6s ease-out}.evaluate-button{padding:18px 50px;font-size:20px;font-weight:600;color:#fff;background:linear-gradient(135deg,#a855f7,#be74ff);border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #a855f766;transition:all .3s ease;animation:fadeInUp .6s ease-out .3s both}.evaluate-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #a855f780;background:linear-gradient(135deg,#9333ea,#7c3aed)}.evaluate-button:active{transform:translateY(0);box-shadow:0 2px 10px #a855f766}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.analyzing-page{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#fff;overflow:hidden}.analyzing-container{width:100%;max-width:480px;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#4ecdc4,#5effda)}.brain-icon{width:200px;height:200px;margin-bottom:40px;animation:pulse 2s ease-in-out infinite}.brain-image,.brain-svg{width:100%;height:100%;filter:drop-shadow(0 4px 15px rgba(168,85,247,.4))}.analyzing-text{font-size:32px;font-weight:600;color:#4900b1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}@keyframes pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.1);opacity:1}}.result-page{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background:#fff;overflow-y:auto;padding:0;margin:0}.result-container{width:100%;max-width:480px;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:40px 20px;box-sizing:border-box;background:linear-gradient(135deg,#4ecdc4,#5effda);box-shadow:0 0 40px #00000080}.score-label{font-size:24px;font-weight:600;color:#be74ff;margin:0;animation:fadeIn .5s ease-out}.score-value{font-size:96px;font-weight:700;margin:0;text-shadow:0 4px 8px rgba(0,0,0,.3);animation:scaleIn .6s ease-out .2s both}.recommendation-box{width:100%;max-width:400px;background-color:#fff;border-radius:16px;padding:24px;box-sizing:border-box;box-shadow:0 8px 24px #00000026;animation:fadeInUp .6s ease-out .4s both}.recommendation-title{font-size:24px;font-weight:700;color:#000;margin:0 0 16px;text-align:center}.recommendation-text{font-size:16px;line-height:1.6;color:#374151;margin:0;text-align:left}.compare-button{width:100%;max-width:400px;padding:18px 32px;font-size:18px;font-weight:600;color:#fff;background:linear-gradient(135deg,#a855f7,#be74ff);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #a855f74d;animation:fadeInUp .6s ease-out .6s both;-webkit-tap-highlight-color:transparent;box-sizing:border-box}.compare-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #a855f766}.compare-button:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(max-width:480px){.result-page{background:transparent}.result-container{box-shadow:none}.score-label{font-size:22px}.score-value{font-size:80px}.recommendation-box{padding:20px}.recommendation-title{font-size:22px}.recommendation-text{font-size:15px}.compare-button{font-size:16px;padding:16px 28px}}.history-page{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background:#fff;overflow-y:auto;padding:0;margin:0}.history-container{width:100%;max-width:480px;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:40px 20px;box-sizing:border-box;background:linear-gradient(135deg,#4ecdc4,#5effda);box-shadow:0 0 40px #00000080}.history-title{font-size:32px;font-weight:700;color:#be74ff;margin:0;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.2);animation:fadeInDown .6s ease-out}.error-message{color:#fff;background-color:#ef4444e6;padding:12px 20px;border-radius:8px;font-size:14px}.no-records{color:#fff;font-size:18px;text-align:center;padding:40px 20px}.records-table-wrapper{width:100%;max-width:400px;background:linear-gradient(135deg,#4ecdc4,#5effda);border-radius:16px;padding:4px;box-shadow:0 8px 24px #00000026;animation:fadeInUp .6s ease-out .2s both;box-sizing:border-box}.records-table{width:100%;background-color:#fff;border-radius:12px;border-collapse:collapse;overflow:hidden}.records-table thead{background:linear-gradient(135deg,#a855f7,#ba8cff)}.records-table th{padding:14px 12px;font-size:16px;font-weight:600;color:#fff;text-align:center}.records-table tbody tr{border-bottom:1px solid #E5E7EB}.records-table tbody tr:last-child{border-bottom:none}.records-table tbody tr:nth-child(2n){background-color:#f9fafb}.records-table td{padding:14px 12px;font-size:16px;color:#1f2937;text-align:center}.time-cell{display:flex;flex-direction:column;gap:2px;align-items:center}.time-cell div:first-child{font-weight:600}.time-cell div:last-child{font-size:14px;color:#6b7280}.restart-button{width:100%;max-width:400px;padding:18px 32px;font-size:18px;font-weight:600;color:#fff;background:linear-gradient(135deg,#a855f7,#be74ff);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #a855f74d;animation:fadeInUp .6s ease-out .4s both;-webkit-tap-highlight-color:transparent;box-sizing:border-box}.restart-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #a855f766}.restart-button:active{transform:translateY(0)}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:18px;color:#fff;margin-top:20px}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.history-page{background:transparent}.history-container{box-shadow:none}.history-title{font-size:28px}.records-table th,.records-table td{padding:12px 8px;font-size:15px}.time-cell div:last-child{font-size:13px}.restart-button{font-size:16px;padding:16px 28px}}
