:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#102215;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#102215}#root{width:100%;max-width:500px;margin:0 auto}h1,h2,h3,h4,h5,h6,p{margin:0}ul{margin:0;padding:0}button{border:none;background:none;cursor:pointer;font-family:inherit}a{font-weight:500;color:#39ff14;text-decoration:inherit}.app{min-height:100vh;background-color:#102215}.upload-container{text-align:center;padding:5rem 1.5rem 2rem;min-height:100vh;background-color:#102215}.upload-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#2bee5b;font-weight:900;font-style:italic}.tagline{color:#fff9;font-size:1rem;margin-bottom:2rem}.upload-box{border:3px dashed #2bee5b;border-radius:20px;padding:3rem 2rem;cursor:pointer;transition:all .3s ease;background:#39ff140d}.upload-box:hover{border-color:#2bee5b;background:#39ff141a;transform:scale(1.02)}.upload-box.dragging{border-color:#2bee5b;background:#39ff1426;transform:scale(1.05);border-style:solid;box-shadow:0 0 30px #39ff144d}.upload-icon{font-size:4rem;margin-bottom:1rem}.upload-text{font-size:1.2rem;font-weight:600;color:#fff;margin-bottom:.5rem}.upload-hint{color:#ffffff80;font-size:.9rem}.uploaded-box{border:3px solid #2bee5b;border-radius:20px;padding:2rem;background:#39ff141a;text-align:center}.uploaded-icon{font-size:3rem;margin-bottom:.5rem}.uploaded-file{font-size:1.1rem;font-weight:600;color:#2bee5b;margin-bottom:1rem;word-break:break-all}.remove-file-btn{background:transparent;border:none;color:#ffffff80;font-size:.9rem;cursor:pointer;text-decoration:underline}.remove-file-btn:hover{color:#ffffffb3}.start-analysis-btn{width:100%;margin-top:1.5rem;padding:1.2rem 2rem;font-size:1.1rem;font-weight:900;color:#102215;background:#2bee5b;border:none;border-radius:2rem;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 0 30px #39ff144d;text-transform:uppercase}.start-analysis-btn:hover{transform:scale(1.03);box-shadow:0 0 40px #39ff1480}.start-analysis-btn:active{transform:scale(.95)}.upload-tips{margin-top:2rem;text-align:left;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:1rem 1.5rem;border-radius:12px}.upload-tips p{font-weight:600;margin-bottom:.5rem;color:#fff}.upload-tips ul{margin:0;padding-left:1.5rem;color:#fff9;list-style:disc}.upload-tips li{margin:.3rem 0}.analyzing-container{text-align:center;padding:6rem 2rem;min-height:100vh;background-color:#102215}.analyzing-spinner{width:80px;height:80px;border:4px solid rgba(57,255,20,.2);border-top-color:#2bee5b;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}@keyframes spin{to{transform:rotate(360deg)}}.analyzing-container h2{color:#fff;margin-bottom:.5rem}.analyzing-file{color:#2bee5b;font-weight:500;margin-bottom:1rem}.analyzing-text{color:#ffffff80;font-size:.95rem}.demo-banner{display:flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,#ffc80026,#ffa0001a);border:1px solid rgba(255,200,0,.4);border-radius:12px;padding:.75rem 1rem;margin-bottom:1.5rem;flex-wrap:wrap}.demo-banner-icon{font-size:1.2rem;flex-shrink:0}.demo-banner-text{flex:1;font-size:.78rem;color:#ffdc50f2;text-align:left;line-height:1.4}.demo-banner-cta{background:#ffc80033;border:1px solid rgba(255,200,0,.5);color:gold;border-radius:8px;padding:.35rem .75rem;font-size:.75rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s}.demo-banner-cta:hover{background:#ffc80059}.result-container{text-align:center;padding:2rem 1.5rem 4rem;min-height:100vh;background-color:#102215;max-width:480px;margin:0 auto}.result-title{font-size:1.6rem;color:#2bee5b;margin:0 0 .25rem;font-weight:900;letter-spacing:.05em}.report-header{margin-bottom:1.5rem}.report-badge{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.1em}.summary-row{display:flex;align-items:center;gap:1.5rem;padding:1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;margin-bottom:1.5rem}.score-ring{position:relative;width:100px;height:100px;flex-shrink:0}.score-svg{width:100%;height:100%}.score-text-group{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center}.score-number{font-size:2rem;font-weight:900;color:#2bee5b;line-height:1}.score-label{font-size:.6rem;color:#fff6;text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.match-info-block{display:flex;flex-direction:column;gap:.25rem;text-align:left}.match-label{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.05em}.match-player-name{font-size:1.2rem;font-weight:700;color:#fff}.match-pct-badge{display:inline-block;background:#2bee5b26;color:#2bee5b;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:700;width:fit-content}.section-heading{font-size:.85rem;font-weight:700;color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;margin:0 0 1rem;text-align:left}.phase-scores-section{margin-bottom:1.5rem}.phase-score-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.phase-score-row.primary{background:#ff4d4d0f;border:1px solid rgba(255,77,77,.15);border-radius:10px;padding:.6rem .75rem;margin-left:-.75rem;margin-right:-.75rem}.phase-score-label{display:flex;flex-direction:column;min-width:100px;text-align:left}.phase-name{font-size:.85rem;font-weight:600;color:#ffffffd9}.primary-tag{font-size:.6rem;color:#ff4d4d;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.phase-score-bar-track{flex:1;height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.phase-score-bar-fill{height:100%;border-radius:4px;transition:width 1s ease-out}.phase-score-value{font-size:.9rem;font-weight:700;color:#ffffffe6;min-width:28px;text-align:right}.primary-phase-section{margin-bottom:1.5rem}.primary-phase-card{display:flex;align-items:center;gap:1.5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.5rem}.phase-image-wrapper{width:140px;height:180px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#ffffff08;border-radius:12px;overflow:hidden}.phase-silhouette{width:100%;height:100%;object-fit:contain;filter:brightness(0) invert(1) opacity(.7)}.primary-phase-info{display:flex;flex-direction:column;gap:.75rem;text-align:left}.primary-phase-name{font-size:1.1rem;font-weight:700;color:#ff4d4d}.metric-row,.gap-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.06)}.metric-label,.gap-label{font-size:.8rem;color:#ffffff80}.metric-score{font-size:1.1rem;font-weight:700;color:#f0c040}.gap-value{font-size:1.1rem;font-weight:700;color:#ff4d4d}.overview-section{margin-bottom:1.5rem}.overview-text{color:#fffc;font-size:.9rem;line-height:1.7;margin:0;text-align:left;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:1.25rem}.growth-section{margin-bottom:2rem}.growth-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.5rem}.growth-scores{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:1rem}.growth-current,.growth-projected{display:flex;flex-direction:column;align-items:center}.growth-num{font-size:2rem;font-weight:900;color:#fff;line-height:1}.growth-current .growth-num{color:#2bee5b}.growth-projected .growth-num{color:gold}.growth-label{font-size:.65rem;color:#fff6;text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.growth-arrow{color:#ffffff4d}.growth-bar-track{position:relative;height:10px;background:#ffffff14;border-radius:5px;margin-bottom:1rem;overflow:hidden}.growth-bar-current{position:absolute;top:0;left:0;height:100%;background:#2bee5b;border-radius:5px;z-index:2;transition:width 1.5s ease-out}.growth-bar-projected{position:absolute;top:0;left:0;height:100%;background:#ffd7004d;border-radius:5px;z-index:1;transition:width 1.5s ease-out}.growth-condition{color:#fff9;font-size:.85rem;line-height:1.5;margin:0;text-align:center}.action-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.share-button{background:#2bee5b;color:#102215;border:none;padding:1rem;border-radius:2rem;font-size:1rem;font-weight:900;cursor:pointer;transition:transform .2s;box-shadow:0 0 20px #39ff144d}.share-button:hover{transform:scale(1.02)}.retry-button{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:.8rem;border-radius:2rem;font-size:1rem;cursor:pointer;transition:background .2s}.retry-button:hover{background:#ffffff26}.report-disclaimer{padding:1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px}.report-disclaimer p{color:#ffffff4d;font-size:.7rem;line-height:1.6;margin:0;text-align:center}.highlight{color:#2bee5b;font-weight:700}.payment-container{text-align:center;padding:3rem 1.5rem 2rem;min-height:100vh;background-color:#102215}.payment-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#2bee5b;font-weight:900;font-style:italic}.payment-info{margin:2rem 0}.uploaded-file-info{display:flex;align-items:center;justify-content:center;gap:.5rem;background:#39ff141a;border:1px solid rgba(57,255,20,.2);border-radius:12px;padding:1rem;margin-bottom:1.5rem}.file-icon{font-size:1.5rem}.file-name{color:#2bee5b;font-weight:600;word-break:break-all}.analysis-preview{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;text-align:left}.analysis-preview h3{color:#fff;margin:0 0 1rem;font-size:1rem;text-align:center}.preview-list{list-style:none;padding:0;margin:0}.preview-list li{padding:.6rem 0;color:#fffc;border-bottom:1px solid rgba(255,255,255,.05)}.preview-list li:last-child{border-bottom:none}.price-tag{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.5rem}.price{font-size:2.5rem;font-weight:900;color:#2bee5b}.price-note{color:#ffffff80;font-size:.85rem}.payment-btn{width:100%;padding:1.2rem 2rem;font-size:1.1rem;font-weight:900;color:#102215;background:#2bee5b;border:none;border-radius:2rem;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 0 30px #39ff144d;margin-bottom:1rem}.payment-btn:hover{transform:scale(1.03);box-shadow:0 0 40px #39ff1480}.payment-btn:active{transform:scale(.95)}.payment-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.back-btn{background:transparent;border:none;color:#ffffff80;font-size:.95rem;cursor:pointer;padding:.5rem 1rem}.back-btn:hover{color:#ffffffb3}.back-btn:disabled{opacity:.5;cursor:not-allowed}.analysis-section{margin-top:1.5rem}.analysis-complete-badge{display:inline-flex;align-items:center;gap:.5rem;background:#39ff1426;border:1px solid rgba(57,255,20,.3);border-radius:50px;padding:.75rem 1.5rem;margin-bottom:2rem;color:#2bee5b;font-weight:600}.check-icon{font-size:1.2rem}.payment-guarantee{color:#ffffff80;font-size:.85rem;margin-top:1rem}.pro-match-header{text-align:center;margin-bottom:1.5rem;padding:1.5rem;background:#2bee5b0f;border:1px solid rgba(43,238,91,.2);border-radius:16px}.pro-match-label{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.12em;display:block;margin-bottom:.5rem}.pro-match-row{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem}.pro-match-name{font-size:1.5rem;font-weight:900;color:#fff}.pro-match-badge{background:#2bee5b26;color:#2bee5b;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:700}.pro-match-reason{color:#2bee5bbf;font-size:.82rem;margin:0 0 .5rem;line-height:1.5}.brief-message{color:#ffffff8c;font-size:.85rem;margin:0;line-height:1.5}.score-shot-row{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:1.5rem}.shot-shape-block{display:flex;flex-direction:column;align-items:flex-start;gap:.3rem}.shot-shape-label{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.08em}.shot-shape-value{font-size:1.4rem;font-weight:900;color:#fff}.tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;background:#ffffff0a;border-radius:12px;padding:.3rem}.tab-btn{flex:1;padding:.6rem .5rem;border:none;border-radius:8px;background:transparent;color:#ffffff73;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.tab-btn.active{background:#2bee5b;color:#102215}.tab-btn:not(.active):hover{color:#ffffffbf}.tab-content{margin-bottom:1.5rem}.content-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.25rem;margin-bottom:1rem}.content-text{color:#fffc;font-size:.9rem;line-height:1.7;margin:0;text-align:left}.swing-check-card{background:#ff4d4d0f;border:1px solid rgba(255,77,77,.2);border-radius:14px;padding:1.25rem;margin-bottom:1.25rem}.swing-check-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.swing-check-title{font-size:.85rem;font-weight:700;color:#ff6b6b;text-transform:uppercase;letter-spacing:.05em}.swing-check-phase{font-size:.75rem;color:#ff6b6bb3;background:#ff4d4d1a;padding:.2rem .6rem;border-radius:20px}.phase-section{margin-bottom:1.25rem}.phase-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.08)}.phase-section-name{font-size:.95rem;font-weight:700;color:#fff}.phase-section-score{font-size:1.1rem;font-weight:900}.metrics-grid{display:flex;flex-direction:column;gap:.6rem}.metric-card{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-left:3px solid;border-radius:10px;padding:.75rem 1rem}.metric-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.metric-icon{font-size:.9rem}.metric-name{font-size:.8rem;font-weight:700;color:#ffffffb3;flex:1}.metric-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.metric-desc{font-size:.82rem;color:#fff9;line-height:1.5;margin:0;text-align:left}.issue-card{background:#ff4d4d0f;border:1px solid rgba(255,77,77,.2);border-radius:14px;padding:1.25rem;margin-bottom:1rem}.issue-phase-tag{display:inline-block;font-size:.7rem;color:#ff6b6b;background:#ff4d4d1f;padding:.2rem .6rem;border-radius:20px;margin-bottom:.5rem;font-weight:700}.issue-label{font-size:.85rem;font-weight:700;color:#ff6b6b;margin:0 0 .75rem;text-align:left}.solution-card{background:#2bee5b0d;border:1px solid rgba(43,238,91,.15);border-radius:14px;padding:1.25rem;margin-bottom:1rem}.solution-label{font-size:.85rem;font-weight:700;color:#2bee5b;margin:0 0 .75rem;text-align:left}.priority-card{background:#ffd7000d;border:1px solid rgba(255,215,0,.15);border-radius:14px;padding:1.25rem}.priority-label{font-size:.85rem;font-weight:700;color:gold;margin:0 0 .75rem;text-align:left}.drill-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.25rem;margin-bottom:1rem}.drill-label{font-size:.85rem;font-weight:700;color:#ffffffb3;margin:0 0 .75rem;text-align:left}.growth-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.5rem}.growth-scores{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1rem}.growth-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.growth-num{font-size:2rem;font-weight:900;line-height:1}.growth-item-label{font-size:.65rem;color:#fff6;text-transform:uppercase;letter-spacing:.08em}.demo-section{margin-top:2rem;text-align:center}.demo-divider{color:#ffffff4d;font-size:.85rem;margin-bottom:1rem}.demo-btn{width:100%;padding:1rem 2rem;font-size:1rem;font-weight:700;color:#2bee5b;background:transparent;border:2px solid rgba(43,238,91,.4);border-radius:2rem;cursor:pointer;transition:all .2s}.demo-btn:hover{background:#2bee5b14;border-color:#2bee5b}.demo-btn:disabled{opacity:.5;cursor:not-allowed}.demo-hint{color:#ffffff4d;font-size:.78rem;margin-top:.5rem}.level-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;justify-content:center}.level-selector label{color:#ffffffb3;font-size:.9rem;font-weight:600}.level-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.9rem}.level-select option{background:#102215;color:#fff}.main-page{min-height:100vh;background-color:#102215;color:#fff;font-family:Space Grotesk,Inter,-apple-system,sans-serif}.main-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#102215cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.logo{display:flex;align-items:center;gap:.5rem}.logo-icon{color:#2bee5b;font-size:1.5rem}.logo-text{font-weight:700;font-size:1.2rem;letter-spacing:-.02em;text-transform:uppercase}.menu-btn{width:40px;height:40px;background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;border-radius:8px;transition:background .2s}.menu-btn:hover{background:#ffffff1a}.login-btn{background:#2bee5b1a;border:1px solid rgba(43,238,91,.3);color:#2bee5b;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-btn:hover{background:#2bee5b33;box-shadow:0 0 15px #2bee5b4d}.header-user{display:flex;align-items:center;gap:.75rem}.user-email{color:#fffc;font-size:.85rem;font-weight:600;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mypage-btn{background:#2bee5b1a;border:1px solid rgba(43,238,91,.3);color:#2bee5b;padding:.4rem .8rem;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mypage-btn:hover{background:#2bee5b33;box-shadow:0 0 15px #2bee5b4d}.logout-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:.4rem .8rem;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.logout-btn:hover{background:#ffffff26;color:#fff}.hero-section{position:relative;min-height:85vh;display:flex;flex-direction:column;justify-content:flex-end;padding-top:64px}.hero-bg{position:absolute;inset:0;background:url(https://images.unsplash.com/photo-1535131749006-b7f58c99034b?w=800) center/cover no-repeat;z-index:0}.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#10221566,#102215f2)}.hero-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem 3rem;gap:1.25rem}.ai-live-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#2bee5b33;border:1px solid rgba(43,238,91,.3);border-radius:50px;color:#2bee5b;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.pulse-dot{position:relative;width:8px;height:8px}.pulse-dot:before{content:"";position:absolute;inset:0;background:#2bee5b;border-radius:50%;animation:ping 1.5s cubic-bezier(0,0,.2,1) infinite}.pulse-dot:after{content:"";position:absolute;inset:0;background:#2bee5b;border-radius:50%}.pulse-dot.small{width:6px;height:6px}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.hero-title{font-size:2.8rem;font-weight:700;line-height:.95;letter-spacing:-.03em;text-transform:uppercase;margin:0}.hero-title .highlight{color:#2bee5b;font-style:italic}.hero-subtitle{color:#fffc;font-size:1.1rem;max-width:320px;line-height:1.5;margin:0}.hero-buttons{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;height:56px;background:#2bee5b;color:#102215;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 0 20px #2bee5b66;transition:transform .2s}.btn-primary:active{transform:scale(.98)}.btn-primary.large{max-width:320px;margin:0 auto}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;height:56px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s}.btn-secondary:hover{background:#ffffff26}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:0 1rem;margin-top:-1.5rem;position:relative;z-index:20}.stat-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem .5rem;background:#102215cc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:12px}.stat-value{color:#2bee5b;font-size:1.25rem;font-weight:700}.stat-label{color:#ffffff80;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.how-it-works{padding:3rem 1.5rem;background:#2bee5b08;border-top:1px solid rgba(255,255,255,.05)}.section-title{font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:-.02em;margin:0 0 2rem;text-align:center}.steps-list{display:flex;flex-direction:column;gap:1.5rem}.step-item{display:flex;align-items:flex-start;gap:1rem}.step-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#2bee5b;color:#102215;border-radius:50%;font-size:1.2rem;font-weight:700;flex-shrink:0}.step-content h3{font-size:1.1rem;font-weight:700;margin:0 0 .25rem}.step-content p{color:#fff9;font-size:.9rem;margin:0}.features-section{padding:4rem 1.5rem}.features-header{margin-bottom:2rem}.features-title{font-size:2.2rem;font-weight:700;line-height:1;letter-spacing:-.03em;text-transform:uppercase;margin:0 0 1rem}.features-desc{color:#fff9;font-size:1.1rem;line-height:1.5;margin:0 0 1rem}.system-badge{display:inline-flex;align-items:center;gap:.5rem;color:#2bee5b;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.features-list{display:flex;flex-direction:column;gap:1rem}.feature-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px}.feature-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#2bee5b1a;border-radius:12px;font-size:1.5rem;flex-shrink:0}.feature-content h3{font-size:1.1rem;font-weight:700;margin:0 0 .25rem}.feature-content p{color:#ffffff80;font-size:.9rem;line-height:1.4;margin:0}.disclaimer-section{padding:1.5rem;margin:0 1.5rem;background:#ffc8321a;border:1px solid rgba(255,200,50,.2);border-radius:12px}.disclaimer-text{color:#ffffffb3;font-size:.85rem;line-height:1.5;text-align:center;margin:0}.cta-section{padding:4rem 1.5rem;background:#2bee5b0d;border-top:1px solid rgba(255,255,255,.05);text-align:center;margin-top:2rem}.cta-title{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;text-transform:uppercase;margin:0 0 1rem}.cta-title .highlight{color:#2bee5b}.cta-desc{color:#fff9;font-size:1rem;max-width:300px;margin:0 auto 2rem;line-height:1.5}.main-footer{padding:3rem 1.5rem;border-top:1px solid rgba(255,255,255,.1);text-align:center}.footer-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#ffffff80;font-weight:700;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:1rem}.footer-logo span:first-child{color:#2bee5b80}.footer-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:1.5rem}.footer-links a{color:#fff6;font-size:.8rem;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#ffffffb3}.footer-link-btn{background:none;border:none;color:#fff6;font-size:.8rem;cursor:pointer;padding:0;transition:color .2s}.footer-link-btn:hover{color:#ffffffb3}.legal-overlay{position:fixed;inset:0;background:#000000bf;z-index:100;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.legal-modal{background:#1a2e1f;border:1px solid rgba(255,255,255,.1);border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column}.legal-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.legal-modal-title{font-size:1.1rem;font-weight:700;color:#fff;margin:0}.legal-close-btn{background:#ffffff1a;border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center}.legal-modal-body{overflow-y:auto;padding:1.5rem;color:#ffffffbf;font-size:.88rem;line-height:1.7}.legal-modal-body h3{color:#fff;font-size:.95rem;font-weight:700;margin:1.25rem 0 .5rem}.legal-modal-body h3:first-child{margin-top:0}.legal-modal-body p{margin:0 0 .75rem}.legal-modal-body ul{padding-left:1.25rem;margin:0 0 .75rem}.legal-modal-body li{margin-bottom:.35rem}.legal-updated{color:#ffffff59!important;font-size:.78rem!important}.legal-contact{color:#2bee5b!important;font-weight:700}.legal-note{color:#fff6!important;font-size:.82rem!important;margin-top:1rem!important}.contact-card{display:flex;align-items:center;gap:1rem;background:#2bee5b0f;border:1px solid rgba(43,238,91,.2);border-radius:12px;padding:1.25rem;margin:1rem 0}.contact-icon{font-size:1.5rem}.contact-label{font-size:.75rem;color:#fff6;margin:0 0 .25rem!important}.contact-email{color:#2bee5b;font-weight:700;font-size:.95rem;text-decoration:none}.contact-email:hover{text-decoration:underline}.footer-text{color:#fff3;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;margin:0}.auth-container{min-height:100vh;background-color:#102215;padding:2rem 1.5rem;display:flex;flex-direction:column}.auth-back-btn{background:transparent;border:none;color:#fff9;font-size:1rem;padding:.5rem 0;cursor:pointer;align-self:flex-start;margin-bottom:1rem;transition:color .2s}.auth-back-btn:hover{color:#ffffffe6}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem}.auth-logo .logo-icon{color:#2bee5b;font-size:2rem}.auth-logo .logo-text{font-weight:700;font-size:1.5rem;letter-spacing:-.02em;text-transform:uppercase;color:#fff}.auth-header h1{font-size:2rem;color:#fff;margin-bottom:.5rem;font-weight:900}.auth-subtitle{color:#fff9;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#fffc;font-size:.9rem;font-weight:600}.form-group input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;color:#fff;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#2bee5b;background:#39ff140d;box-shadow:0 0 0 3px #2bee5b1a}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group input::placeholder{color:#ffffff4d}.auth-error{background:#ff64321a;border:1px solid rgba(255,100,50,.3);border-radius:8px;padding:.75rem;color:#ff6b35;font-size:.9rem;text-align:center}.auth-submit-btn{width:100%;padding:1rem;background:#2bee5b;color:#102215;border:none;border-radius:12px;font-size:1.1rem;font-weight:900;cursor:pointer;transition:all .2s;box-shadow:0 0 20px #2bee5b4d;text-transform:uppercase}.auth-submit-btn:hover:not(:disabled){transform:scale(1.02);box-shadow:0 0 30px #2bee5b80}.auth-submit-btn:active:not(:disabled){transform:scale(.98)}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:#ffffff4d;font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.google-auth-btn{width:100%;padding:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:1rem;font-weight:700;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.75rem}.google-auth-btn:hover:not(:disabled){background:#ffffff26;transform:scale(1.01)}.google-auth-btn:disabled{opacity:.5;cursor:not-allowed}.google-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#fff;color:#102215;border-radius:50%;font-weight:700;font-size:.85rem}.auth-toggle{text-align:center;margin-top:1.5rem}.auth-toggle p{color:#fff9;font-size:.9rem}.toggle-link{background:transparent;border:none;color:#2bee5b;font-weight:700;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.toggle-link:hover{color:#39ff14}.auth-note{text-align:center;color:#fff6;font-size:.8rem;margin-top:2rem;padding:1rem;background:#ffffff08;border-radius:8px;line-height:1.5}.mypage-container{min-height:100vh;background-color:#102215;padding:2rem 1.5rem;display:flex;flex-direction:column;color:#fff}.mypage-back-btn{background:transparent;border:none;color:#fff9;font-size:1rem;padding:.5rem 0;cursor:pointer;align-self:flex-start;margin-bottom:1rem;transition:color .2s}.mypage-back-btn:hover{color:#ffffffe6}.mypage-header{text-align:center;margin-bottom:2rem}.mypage-avatar{width:80px;height:80px;border-radius:50%;background:#2bee5b26;border:2px solid rgba(43,238,91,.4);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;overflow:hidden}.mypage-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.mypage-avatar span{font-size:2rem;font-weight:700;color:#2bee5b}.mypage-header h1{font-size:1.8rem;font-weight:900;margin:0 0 .5rem}.mypage-email{color:#ffffff80;font-size:.95rem;margin:0}.mypage-tabs{display:flex;gap:.25rem;background:#ffffff0d;border-radius:12px;padding:4px;margin-bottom:1.5rem}.mypage-tab{flex:1;padding:.75rem .5rem;background:transparent;border:none;border-radius:10px;color:#ffffff80;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s}.mypage-tab.active{background:#2bee5b26;color:#2bee5b}.mypage-tab:hover:not(.active){color:#fffc}.mypage-content{flex:1}.info-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}.info-row{display:flex;justify-content:space-between;align-items:center;padding:1.15rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05)}.info-row:last-child{border-bottom:none}.info-label{color:#ffffff80;font-size:.9rem;font-weight:600}.info-value{color:#fff;font-size:.9rem;font-weight:600;text-align:right;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.info-value.id-value{font-family:Courier New,monospace;font-size:.8rem;color:#fff6}.info-card.edit-mode{border-color:#2bee5b33}.info-row.edit-row input{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.6rem .75rem;color:#fff;font-size:.9rem;font-weight:600;text-align:right;width:160px;transition:all .2s}.info-row.edit-row input:focus{outline:none;border-color:#2bee5b;background:#39ff140d;box-shadow:0 0 0 2px #2bee5b1a}.info-row.edit-row input::placeholder{color:#ffffff4d}.info-row.edit-row input:disabled{opacity:.5}.mypage-edit-btn{width:100%;padding:.85rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:1rem}.mypage-edit-btn:hover{background:#ffffff1f}.edit-actions{display:flex;gap:.75rem;margin-top:1rem}.edit-actions .mypage-submit-btn{margin-top:0}.mypage-cancel-btn{flex:1;padding:1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;color:#ffffffb3;font-size:1.1rem;font-weight:900;cursor:pointer;transition:all .2s;text-transform:uppercase}.mypage-cancel-btn:hover:not(:disabled){background:#ffffff1f;color:#fff}.mypage-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.mypage-info .mypage-message{margin-top:1rem}.password-form{display:flex;flex-direction:column;gap:1rem}.password-form .form-group{display:flex;flex-direction:column;gap:.5rem}.password-form .form-group label{color:#fffc;font-size:.9rem;font-weight:600}.password-form .form-group input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;color:#fff;font-size:1rem;transition:all .2s}.password-form .form-group input:focus{outline:none;border-color:#2bee5b;background:#39ff140d;box-shadow:0 0 0 3px #2bee5b1a}.password-form .form-group input:disabled{opacity:.5;cursor:not-allowed}.password-form .form-group input::placeholder{color:#ffffff4d}.password-notice{display:flex;align-items:flex-start;gap:.75rem;padding:1.25rem;background:#ffc83214;border:1px solid rgba(255,200,50,.2);border-radius:12px}.password-notice .notice-icon{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}.password-notice p{color:#ffffffb3;font-size:.9rem;line-height:1.5;margin:0}.mypage-message{padding:.75rem;border-radius:8px;font-size:.9rem;text-align:center}.mypage-message.success{background:#2bee5b1a;border:1px solid rgba(43,238,91,.3);color:#2bee5b}.mypage-message.error{background:#ff64321a;border:1px solid rgba(255,100,50,.3);color:#ff6b35}.mypage-submit-btn{width:100%;padding:1rem;background:#2bee5b;color:#102215;border:none;border-radius:12px;font-size:1.1rem;font-weight:900;cursor:pointer;transition:all .2s;box-shadow:0 0 20px #2bee5b4d;text-transform:uppercase;margin-top:.5rem}.mypage-submit-btn:hover:not(:disabled){transform:scale(1.02);box-shadow:0 0 30px #2bee5b80}.mypage-submit-btn:active:not(:disabled){transform:scale(.98)}.mypage-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.mypage-delete{display:flex;flex-direction:column;gap:1.5rem}.delete-warning{padding:1.5rem;background:#ff505014;border:1px solid rgba(255,80,80,.2);border-radius:16px}.delete-warning .warning-icon{font-size:1.5rem;display:block;margin-bottom:.75rem}.delete-warning h3{font-size:1.1rem;font-weight:700;color:#ff6b6b;margin:0 0 .75rem}.delete-warning ul{margin:0;padding-left:1.25rem;list-style:disc}.delete-warning li{color:#fff9;font-size:.9rem;line-height:1.8}.delete-confirm-section{display:flex;flex-direction:column;gap:.75rem}.delete-confirm-section label{color:#ffffffb3;font-size:.9rem;line-height:1.5}.delete-confirm-section label strong{color:#ff6b6b}.delete-confirm-section input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;color:#fff;font-size:1rem;transition:all .2s}.delete-confirm-section input:focus{outline:none;border-color:#ff6b6b;background:#ff50500d;box-shadow:0 0 0 3px #ff50501a}.delete-confirm-section input:disabled{opacity:.5;cursor:not-allowed}.delete-confirm-section input::placeholder{color:#ffffff4d}.delete-btn{width:100%;padding:1rem;background:#ff505026;color:#ff6b6b;border:1px solid rgba(255,80,80,.3);border-radius:12px;font-size:1.1rem;font-weight:900;cursor:pointer;transition:all .2s;text-transform:uppercase}.delete-btn:hover:not(:disabled){background:#ff505040;box-shadow:0 0 20px #ff505033}.delete-btn:disabled{opacity:.4;cursor:not-allowed}
