*{margin:0;padding:0;box-sizing:border-box}:root{--gradient-start: #5FFBF1;--gradient-mid: #7FE87D;--gradient-end: #F4E84D;--primary: #7FE87D;--primary-dark: #5BC85A;--accent: #F4E84D;--text-dark: #1a1a1a;--text-light: #ffffff;--bg-light: #f9f9f9;--bg-white: #ffffff;--border: #e0e0e0;--shadow: rgba(0, 0, 0, .1);--error: #ef4444}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-light);color:var(--text-dark)}.gradient-bg{background:linear-gradient(135deg,var(--gradient-start) 0%,var(--gradient-mid) 50%,var(--gradient-end) 100%);min-height:100vh}.container{max-width:480px;margin:0 auto;padding:20px}.btn{padding:14px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--primary);color:var(--text-dark);box-shadow:0 4px 12px var(--shadow)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 16px var(--shadow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-white);color:var(--text-dark);border:2px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);background:var(--bg-light)}.btn-gradient{background:linear-gradient(90deg,var(--gradient-start),var(--gradient-mid),var(--gradient-end));color:var(--text-dark);font-weight:700}.btn-gradient:hover{opacity:.9;transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed}.input-group{margin-bottom:16px}.input-group label{display:block;margin-bottom:6px;font-weight:500;font-size:14px;color:var(--text-dark)}.input-group input,.input-group select,.input-group textarea{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:10px;font-size:16px;transition:all .2s ease;background:var(--bg-white)}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #7fe87d1a}.input-group textarea{resize:vertical;min-height:80px;font-family:inherit}.input-error{border-color:var(--error)!important}.error-text{color:var(--error);font-size:13px;margin-top:4px}.card{background:var(--bg-white);border-radius:16px;padding:24px;box-shadow:0 2px 8px var(--shadow);margin-bottom:16px}.logo{font-size:48px;font-weight:800;font-style:italic;color:var(--text-light);text-align:center;letter-spacing:-1px;margin-bottom:8px}.spinner{border:3px solid var(--border);border-top:3px solid var(--primary);border-radius:50%;width:24px;height:24px;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.text-center{text-align:center}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-16{margin-top:16px}.text-sm{font-size:14px}.text-muted{color:#666}a{color:var(--primary-dark);text-decoration:none;font-weight:500}a:hover{text-decoration:underline}@media(max-width:480px){.container{padding:16px}.logo{font-size:40px}.btn{padding:12px 20px}}.intro-page{display:flex;align-items:center;justify-content:center}.intro-content{width:100%;max-width:400px}.logo-section{text-align:center;margin-bottom:48px}.tagline{color:var(--text-light);font-size:18px;font-weight:500;margin-top:8px}.error-banner{background:#fee;color:var(--error);padding:12px;border-radius:8px;font-size:14px;text-align:center}.role-selection-page{display:flex;align-items:center;justify-content:center}.role-content{width:100%;max-width:450px}.roles-grid{display:flex;flex-direction:column;gap:12px}.role-card{background:var(--bg-white);border:2px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.role-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.role-card.selected{border-color:var(--primary);background:#7fe87d0d;box-shadow:0 4px 12px var(--shadow)}.role-title{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}.role-description{font-size:14px;color:var(--text-muted);margin:0}.player-setup-page{background:var(--bg-light);min-height:100vh;padding:20px 0}.setup-header{text-align:center;margin-bottom:32px}.logo-small{font-size:32px;font-weight:800;font-style:italic;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-mid),var(--gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.setup-header h2{font-size:24px;margin-bottom:8px}.section-title{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--text-dark)}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:480px){.input-row{grid-template-columns:1fr}}.messages-container{display:grid;grid-template-columns:300px 1fr;gap:16px;height:calc(100vh - 200px);max-height:600px}.conversations-list{background:#fff;border-radius:12px;overflow-y:auto;padding:12px 0}.conversation-item{display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer;transition:background .2s;position:relative}.conversation-item:hover{background:var(--bg-secondary)}.conversation-item.active{background:var(--bg-secondary);border-left:3px solid var(--primary)}.conversation-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary);color:var(--text-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px;flex-shrink:0}.conversation-info{flex:1;min-width:0}.conversation-name{font-weight:600;font-size:14px;margin-bottom:2px}.conversation-preview{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{width:10px;height:10px;background:var(--primary);border-radius:50%;flex-shrink:0}.messages-panel{background:#fff;border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.messages-header{padding:16px;border-bottom:1px solid #e0e0e0}.messages-header h3{margin:0;font-size:18px;font-weight:700}.messages-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.message{display:flex;width:100%}.message.sent{justify-content:flex-end}.message.received{justify-content:flex-start}.message-bubble{max-width:70%;padding:10px 14px;border-radius:12px;word-wrap:break-word}.message.sent .message-bubble{background:var(--primary);color:var(--text-dark);border-bottom-right-radius:4px}.message.received .message-bubble{background:var(--bg-secondary);color:var(--text-dark);border-bottom-left-radius:4px}.message-text{font-size:14px;line-height:1.4;margin-bottom:4px}.message-time{font-size:11px;opacity:.7;text-align:right}.message-input-form{display:flex;gap:12px;padding:16px;border-top:1px solid #e0e0e0}.message-input{flex:1;padding:10px 14px;border:1px solid #e0e0e0;border-radius:20px;font-size:14px;outline:none}.message-input:focus{border-color:var(--primary)}.messages-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;min-height:200px}@media(max-width:768px){.messages-container{grid-template-columns:1fr;height:auto;max-height:none}.conversations-list{max-height:300px}.messages-panel{min-height:400px}.message-bubble{max-width:85%}}.form-visualization{margin-top:20px;padding:20px;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;border:2px solid #e2e8f0;box-shadow:0 4px 12px #00000014}.p5-canvas{display:flex;justify-content:center;align-items:center;margin:0 auto 20px;overflow-x:auto}.p5-canvas canvas{border-radius:12px;box-shadow:0 6px 16px #0000001f;max-width:100%;height:auto}.corrections-detail{margin-top:24px;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;border-left:5px solid #f59e0b;box-shadow:0 2px 8px #f59e0b33}.corrections-detail h4{margin:0 0 16px;color:#92400e;font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}.corrections-detail h4:before{content:"💡";font-size:20px}.corrections-detail ul{margin:0;padding:0;list-style:none}.corrections-detail li{margin:12px 0;padding:12px 12px 12px 40px;position:relative;line-height:1.7;color:#78350f;background:#fff9;border-radius:8px;font-size:15px;font-weight:500}.correction-bullet{position:absolute;left:12px;color:#f59e0b;font-weight:700;font-size:18px}@media(max-width:480px){.form-visualization{padding:12px}.p5-canvas{overflow-x:auto}.p5-canvas canvas{max-width:100%}.corrections-detail{padding:16px}.corrections-detail li{font-size:14px;padding:10px 10px 10px 32px}}.player-dashboard{min-height:100vh;background:linear-gradient(180deg,#ecfdf5 0%,#f0fdf4 50%,var(--bg-light) 100%)}.dashboard-header{background:var(--bg-white);border-bottom:1px solid var(--border);padding:12px 0;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.header-content{display:flex;justify-content:space-between;align-items:center}.logo-small{color:var(--text-dark);font-weight:800;font-style:italic}.btn-logout{padding:8px 16px;border:2px solid var(--text-dark);border-radius:8px;background:transparent;color:var(--text-dark);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-logout:hover{background:var(--text-dark);color:var(--text-light)}.nav-tabs{background:var(--bg-white);border-bottom:1px solid var(--border);margin-bottom:24px}.tabs{display:flex;gap:8px;padding:12px 0;overflow-x:auto}.tab{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease;white-space:nowrap}.tab:hover{background:var(--bg-light);color:var(--text-dark)}.tab.active{background:var(--primary);color:var(--text-dark)}.page-title{font-size:24px;margin-bottom:20px}.badge{display:inline-block;padding:4px 10px;background:var(--bg-light);border-radius:6px;font-size:13px;color:var(--text-dark)}.leaderboard-list{display:flex;flex-direction:column;gap:12px}.leaderboard-item{display:flex;align-items:center;gap:16px;padding:12px;border-bottom:1px solid var(--border)}.leaderboard-item:last-child{border-bottom:none}.rank{font-size:20px;font-weight:700;color:var(--primary-dark);min-width:50px}.player-info{flex:1;display:flex;flex-direction:column;gap:4px}.rating{font-size:20px;font-weight:700;color:var(--primary-dark)}.profile-card{margin-top:0}.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--gradient-start),var(--gradient-mid),var(--gradient-end));display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--text-dark)}.profile-info h2{margin:0;font-size:24px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding-top:16px;border-top:1px solid var(--border)}.stat{text-align:center}.stat-value{font-size:28px;font-weight:700;color:var(--primary-dark)}.stat-label{font-size:14px;color:var(--text-muted);margin-top:4px}.upload-card{margin-bottom:24px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-header h3{margin:0;font-size:20px}.btn-close{background:none;border:none;font-size:32px;line-height:1;cursor:pointer;color:var(--text-muted);padding:0;width:32px;height:32px}.btn-close:hover{color:var(--text-dark)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{margin:0;font-size:20px}.empty-state{padding:48px 24px}.video-card{padding:0;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.video-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.video-player{width:100%;height:auto;max-height:400px;background:#000;border-radius:12px 12px 0 0;object-fit:cover}.video-info{padding:16px;background:linear-gradient(to bottom,#fff,#f9fafb)}.video-info h4{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--text-dark)}.ai-score{display:inline-block;background:linear-gradient(135deg,#7fe87d33,#7fe87d1a);color:var(--primary-dark);padding:8px 14px;border-radius:10px;font-size:14px;font-weight:600;margin-top:8px;border:1px solid rgba(127,232,125,.3)}.ai-feedback{margin-top:12px;padding:14px;background:var(--bg-light);border-radius:10px;border:1px solid var(--border)}.ai-feedback summary{cursor:pointer;font-weight:600;color:var(--primary-dark);font-size:14px;padding:4px 0;-webkit-user-select:none;user-select:none}.ai-feedback summary:hover{opacity:.8}.ai-feedback p{margin:12px 0 0;line-height:1.7;color:var(--text-dark)}.ai-feedback[open] summary{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.mt-8{margin-top:8px}@media(max-width:480px){.stats-grid{gap:12px}.stat-value{font-size:24px}.profile-info h2{font-size:20px}.profile-avatar{width:56px;height:56px;font-size:24px}.tabs{gap:4px;padding:8px 0}.tab{padding:8px 14px;font-size:14px}.page-title{font-size:20px;margin-bottom:16px}.video-info h4{font-size:16px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;position:relative}.player-profile-modal{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{margin:0;font-size:24px;font-weight:700;color:var(--text-dark)}.modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.modal-close:hover{background:#f0f0f0}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px;position:sticky;bottom:0;background:#fff}.player-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:var(--bg-secondary);padding:12px;border-radius:8px;text-align:center}.stat-card .stat-label{font-size:12px;color:#666;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-card .stat-value{font-size:18px;font-weight:700;color:var(--text-dark)}.profile-section{margin-bottom:24px}.profile-section h3{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--text-dark)}.profile-section p{font-size:14px;color:#666;line-height:1.6}.videos-grid{display:grid;gap:16px}.video-card{background:var(--bg-secondary);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;border:2px solid transparent}.video-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.video-thumbnail{position:relative;background:linear-gradient(135deg,#667eea,#764ba2);height:160px;display:flex;align-items:center;justify-content:center}.video-play-icon{font-size:48px;color:#fff;opacity:.9}.video-duration{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.video-info{padding:12px}.video-info h4{font-size:14px;font-weight:600;margin-bottom:4px;color:var(--text-dark)}.video-info .text-muted{font-size:12px;color:#999;margin-bottom:8px}.ai-score-badge{display:inline-block;background:var(--primary);color:var(--text-dark);padding:4px 10px;border-radius:12px;font-size:12px;font-weight:700}.video-analysis{padding:16px;background:#fff;border-top:1px solid #e0e0e0;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.video-analysis h4{font-size:16px;font-weight:700;margin-bottom:12px;color:var(--text-dark)}.analysis-content{font-size:14px;color:#666}.analysis-score{display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);padding:12px;border-radius:8px;margin-bottom:12px}.score-label{font-weight:600;color:#666}.score-value{font-size:24px;font-weight:700;color:var(--primary)}.feedback-text{background:#f9f9f9;padding:12px;border-radius:8px;margin-bottom:12px;line-height:1.6;font-size:13px}.insight-section{margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.insight-section h5{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}.insight-section ul{list-style:none;padding:0;margin:0}.insight-section li{padding:6px 0 6px 20px;position:relative;font-size:13px;color:#666}.insight-section li:before{content:"•";position:absolute;left:8px;color:var(--primary);font-weight:700}@media(max-width:480px){.modal-content{max-height:100vh;border-radius:0}.modal-header h2{font-size:20px}.player-stats-grid{grid-template-columns:repeat(2,1fr)}.video-thumbnail{height:120px}.video-play-icon{font-size:36px}}.btn-secondary{background:#e0e0e0;color:var(--text-dark);border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#d0d0d0}.message-box{width:100%;display:flex;flex-direction:column;gap:12px}.message-input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:80px}.message-input:focus{outline:none;border-color:var(--primary)}.message-actions{display:flex;gap:12px;justify-content:flex-end}.swipe-container{display:flex;flex-direction:column;align-items:center;padding:20px 0}.player-card{background:var(--bg-white);border-radius:16px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px;overflow:hidden}.player-card-header{background:linear-gradient(135deg,var(--gradient-start),var(--gradient-mid),var(--gradient-end));padding:24px;display:flex;gap:16px;align-items:center}.player-avatar-large{width:80px;height:80px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:var(--text-dark);flex-shrink:0}.player-card-info{flex:1}.player-card-info h2{margin:0 0 4px;font-size:22px;color:var(--text-dark)}.player-card-body{padding:20px}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.stat-item{text-align:center;padding:12px;background:var(--bg-light);border-radius:8px}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{font-size:18px;font-weight:700;color:var(--primary-dark)}.swipe-actions{display:flex;justify-content:center;gap:20px;padding:20px;border-top:1px solid var(--border)}.swipe-btn{width:64px;height:64px;border-radius:50%;border:none;font-size:28px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.swipe-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.swipe-btn:active{transform:scale(.95)}.swipe-btn-pass{background:#ff4458;color:#fff}.swipe-btn-like{background:var(--primary);color:var(--text-dark)}.swipe-btn-pass:hover{background:#e6323f}.swipe-btn-like:hover{background:var(--primary-dark)}@media(max-width:480px){.player-card{max-width:100%}.player-avatar-large{width:64px;height:64px;font-size:28px}.player-card-info h2{font-size:18px}.stat-row{gap:8px}.stat-item{padding:8px}.stat-value{font-size:16px}.swipe-btn{width:56px;height:56px;font-size:24px}}
