.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-content{justify-content:space-between;margin:0 auto;max-width:1400px;padding:15px 20px}.navbar-brand,.navbar-content{align-items:center;display:flex}.navbar-brand{gap:12px;text-decoration:none;transition:transform .2s ease}.navbar-brand:hover{text-decoration:none;transform:scale(1.02)}.navbar-logo{height:40px;object-fit:contain;width:auto}.navbar-brand-text{color:#667eea;font-size:24px;font-weight:700}.navbar-links{align-items:center;display:flex;gap:20px}.nav-link{color:#333;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:#667eea}.discord-help-link{align-items:center;background:linear-gradient(135deg,#5865f2,#7289da);border:none;border-radius:6px;box-shadow:0 2px 8px #5865f24d;color:#fff!important;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:8px 16px;text-decoration:none;transition:all .3s ease}.discord-help-link:hover{background:linear-gradient(135deg,#4752c4,#5b6eae);box-shadow:0 4px 12px #5865f266;color:#fff!important;transform:translateY(-2px)}.discord-help-link:before{content:"💬";font-size:16px}.profile-menu{display:inline-block;position:relative}.profile-button{align-items:center;background:#f5f5f5;border:1px solid #ddd;border-radius:5px;color:#666;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 12px;transition:all .2s}.profile-button:hover{background:#e9ecef;border-color:#667eea}.dropdown-arrow{font-size:10px;transition:transform .2s}.profile-button:hover .dropdown-arrow{transform:rotate(180deg)}.profile-dropdown{background:#fff;border:1px solid #ddd;border-radius:5px;box-shadow:0 4px 12px #00000026;margin-top:5px;min-width:180px;position:absolute;right:0;top:100%;z-index:1000}.dropdown-item{background:none;border:none;color:#333;cursor:pointer;display:block;font-size:14px;padding:10px 15px;text-align:left;transition:background .2s;width:100%}.dropdown-item:hover{background:#f8f9fa}.dropdown-item.logout-item{color:#dc3545}.dropdown-item.logout-item:hover{background:#f8d7da}.dropdown-divider{border:none;border-top:1px solid #eee;margin:5px 0}.user-info{color:#666;font-size:14px}.btn-logout{background:#dc3545;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:8px 20px;transition:background .2s}.btn-logout:hover{background:#c82333}@media (max-width:768px){.navbar-content{flex-direction:column;gap:15px;padding:10px 15px}.navbar-brand{gap:8px;justify-content:center}.navbar-logo{height:35px}.navbar-brand-text{font-size:18px}.navbar-links{flex-wrap:wrap;gap:15px;justify-content:center}.nav-link{padding:8px 12px}.discord-help-link,.nav-link{font-size:14px;touch-action:manipulation}.discord-help-link{padding:10px 20px}.profile-button{font-size:14px;padding:8px 12px;touch-action:manipulation}.profile-dropdown{left:50%;position:absolute;top:100%;transform:translateX(-50%);width:200px}}@media (max-width:414px){.navbar-content{padding:8px 10px}.navbar-brand-text{font-size:16px}.navbar-logo{height:30px}.navbar-links{gap:10px}.discord-help-link,.nav-link,.profile-button{font-size:13px;padding:6px 10px}}.home{min-height:100vh}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:100px 20px;text-align:center}.hero-logo{display:flex;justify-content:center;margin-bottom:30px}.hero-logo-img{filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));height:80px;object-fit:contain;transition:transform .3s ease;width:auto}.hero-logo-img:hover{transform:scale(1.05)}.hero h1{font-size:48px;font-weight:700;margin-bottom:20px}.hero-subtitle{font-size:24px;font-weight:600;margin-bottom:15px;opacity:.9}.hero-description{font-size:18px;line-height:1.6;margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:800px;opacity:.8}.cta-buttons{display:flex;gap:20px;justify-content:center}.btn-primary,.btn-secondary{border-radius:5px;font-size:18px;font-weight:600;padding:15px 40px;text-decoration:none;transition:transform .2s}.btn-primary{background:#fff;color:#667eea}.btn-primary:hover{transform:scale(1.05)}.btn-secondary{background:#0000;border:2px solid #fff}.btn-secondary:hover{background:#fff;color:#667eea;transform:scale(1.05)}.features{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1200px;padding:60px 20px}.feature-card{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;padding:30px;text-align:center;transition:transform .2s}.feature-card:hover{box-shadow:0 8px 12px #00000026;transform:translateY(-5px)}.feature-card h3{color:#333;font-size:24px;margin-bottom:15px}.feature-card p{color:#666;line-height:1.6}.features-section{background:#f8f9fa;padding:60px 20px;text-align:center}.features-section h2{color:#333;font-size:36px;margin-bottom:20px}.features-section p{color:#666;font-size:18px;margin-bottom:30px}.features-section ul{list-style:none;margin:0 auto;max-width:600px;padding:0;text-align:left}.features-section li{color:#555;font-size:16px;padding:10px 0}.features-section li:before{color:#667eea;content:"✓ ";font-weight:700;margin-right:10px}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section-header{margin-bottom:50px;text-align:center}.section-icon{display:inline-block;font-size:48px;margin-bottom:20px}.section-divider{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;height:4px;margin:20px auto;width:80px}.challenge-icon{animation:pulse 2s ease-in-out infinite}.solution-icon{animation:float 3s ease-in-out infinite}.mission-icon{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.challenge-section{background:linear-gradient(135deg,#fff5f5,#ffe5e5);overflow:hidden;padding:80px 0;position:relative}.challenge-section:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='2' fill='%23ff6b6b' opacity='.1'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.challenge-section .container{position:relative;z-index:1}.challenge-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:15px}.challenge-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:40px}.challenge-card{border-left:5px solid #ff6b6b;border-radius:16px;box-shadow:0 8px 24px #ff6b6b26;padding:40px;position:relative;transition:transform .3s ease,box-shadow .3s ease}.challenge-card:before{background:linear-gradient(90deg,#ff6b6b,#ff8787);content:"";height:4px;left:0;position:absolute;top:0;width:100%}.challenge-card:hover{box-shadow:0 12px 32px #ff6b6b40;transform:translateY(-8px)}.challenge-icon-small{display:inline-block;font-size:48px;margin-bottom:20px}.challenge-text{color:#555;font-size:18px;line-height:1.8;margin:0}.solution-section{background:#fff;padding:80px 0;position:relative}.solution-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:15px}.solution-intro{background:linear-gradient(135deg,#f0f4ff,#e6edff);border-left:5px solid #667eea;border-radius:16px;color:#555;font-size:20px;line-height:1.8;margin:0 auto 60px;max-width:900px;padding:30px;text-align:center}.solution-features{grid-gap:40px;display:grid;gap:40px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-top:50px}.solution-feature{background:#fff;border:1px solid #e8edff;border-radius:16px;box-shadow:0 8px 24px #667eea26;overflow:hidden;padding:40px;position:relative;transition:transform .3s ease,box-shadow .3s ease}.solution-feature:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;top:0;width:100%}.solution-feature:hover{box-shadow:0 12px 32px #667eea40;transform:translateY(-8px)}.feature-icon-wrapper{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 8px 20px #667eea4d;display:flex;height:80px;justify-content:center;margin:0 auto 25px;transition:transform .3s ease;width:80px}.solution-feature:hover .feature-icon-wrapper{transform:scale(1.1) rotate(5deg)}.feature-icon{filter:grayscale(0);font-size:40px}.solution-feature h3{color:#333;font-size:24px;font-weight:700;margin-bottom:15px;text-align:center}.solution-feature p{color:#666;font-size:16px;line-height:1.8;margin:0;text-align:center}.mission-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow:hidden;padding:80px 0;position:relative}.mission-section:before{background:radial-gradient(circle,#ffffff1a 1px,#0000 0);background-size:50px 50px;content:"";height:200%;opacity:.5;position:absolute;right:-50%;top:-50%;width:200%}.mission-section .container{position:relative;z-index:1}.mission-section h2{color:#fff;font-size:36px;font-weight:700;margin-bottom:15px}.mission-content{margin:0 auto;max-width:800px;position:relative;text-align:center}.mission-icon-large{animation:float 3s ease-in-out infinite;display:inline-block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));font-size:80px;margin-bottom:30px}.mission-text{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;font-size:22px;font-weight:500;line-height:1.8;margin:0;opacity:.95;padding:40px}.vision-section{background:#f8f9fa;padding:80px 0;text-align:center}.vision-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:30px}.vision-text{color:#666;font-size:18px;line-height:1.8;margin:0 auto;max-width:900px}.proficiency-section{background:#fff;padding:80px 0}.proficiency-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:15px;text-align:center}.section-subtitle{color:#666;font-size:18px;margin-bottom:50px;text-align:center}.proficiency-levels{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:50px}.proficiency-card{box-shadow:0 4px 15px #0000001a;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.proficiency-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.proficiency-header{background:linear-gradient(135deg,#f8f9fa,#fff);border-left:4px solid;padding:25px}.proficiency-icon{flex-shrink:0;font-size:2.5rem;margin-right:20px}.proficiency-title h3{color:#333;font-size:24px;font-weight:700;margin:0}.proficiency-number{color:#666;font-size:14px;font-weight:600;margin-top:5px}.proficiency-description{color:#555;line-height:1.6;padding:0 25px 25px}.characteristics-section{background:#f8f9fa;padding:80px 0}.characteristics-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:15px;text-align:center}.characteristics-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:50px}.characteristic-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:30px;transition:transform .3s ease,box-shadow .3s ease}.characteristic-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.characteristic-card h3{color:#333;font-size:20px;font-weight:700;margin-bottom:15px}.characteristic-card p{color:#555;line-height:1.6;margin:0}.internships-section{background:#fff;padding:80px 0;text-align:center}.internships-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:30px}.internships-text{color:#666;font-size:18px;line-height:1.8;margin:0 auto;max-width:800px}.resources-section{background:#f8f9fa;padding:80px 0}.resources-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:50px;text-align:center}.resources-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.resource-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 15px #0000001a;color:inherit;display:block;padding:30px;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}.resource-card:hover{box-shadow:0 8px 25px #00000026;color:inherit;text-decoration:none;transform:translateY(-5px)}.resource-icon{font-size:3rem;margin-bottom:20px;text-align:center}.resource-card h3{color:#333;font-size:20px;font-weight:700;margin-bottom:15px;text-align:center}.resource-card p{color:#555;line-height:1.6;margin:0;text-align:center}.discord-card{background:linear-gradient(135deg,#5865f2,#7289da);border:2px solid #5865f2;color:#fff}.discord-card:hover{background:linear-gradient(135deg,#4752c4,#5b6eae);box-shadow:0 8px 25px #5865f24d;transform:translateY(-5px)}.discord-card h3{color:#fff}.discord-card p{color:#ffffffe6}.discord-community-section{background:linear-gradient(135deg,#5865f2,#7289da);color:#fff;padding:80px 0}.discord-content{grid-gap:60px;align-items:center;display:grid;gap:60px;grid-template-columns:1fr 1fr}.discord-text h2{font-size:36px;font-weight:700;margin-bottom:20px}.discord-description{font-size:18px;line-height:1.8;margin-bottom:30px;opacity:.9}.discord-join-btn{align-items:center;background:#fff;border-radius:8px;box-shadow:0 4px 15px #0003;color:#5865f2;display:inline-flex;font-size:18px;font-weight:700;gap:12px;padding:15px 30px;text-decoration:none;transition:all .3s ease}.discord-join-btn:hover{background:#f8f9fa;box-shadow:0 6px 20px #0000004d;color:#5865f2;text-decoration:none;transform:translateY(-2px)}.discord-icon{font-size:20px}.discord-features{display:flex;flex-direction:column;gap:30px}.discord-feature{align-items:flex-start;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;display:flex;gap:20px;padding:25px}.feature-icon{flex-shrink:0;font-size:2rem;margin-top:5px}.discord-feature h3{font-size:20px;font-weight:700;margin-bottom:10px}.discord-feature p{line-height:1.6;margin:0;opacity:.9}.arduino-section{background:#f8f9fa;padding:80px 0}.arduino-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:15px;text-align:center}.arduino-projects{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:50px}.arduino-project-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:30px;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.arduino-project-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.project-icon{display:block;font-size:3rem;margin-bottom:20px}.arduino-project-card h3{color:#333;font-size:20px;font-weight:700;margin-bottom:15px}.arduino-project-card p{color:#555;line-height:1.6;margin-bottom:20px}.project-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.tag{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.mobile-features-section{background:#fff;padding:80px 0}.mobile-features-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:15px;text-align:center}.mobile-features{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:50px}.mobile-feature{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:30px;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.mobile-feature:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.mobile-feature .feature-icon{display:block;font-size:2.5rem;margin-bottom:20px}.mobile-feature h3{color:#333;font-size:18px;font-weight:700;margin-bottom:15px}.mobile-feature p{color:#555;font-size:14px;line-height:1.6;margin:0}.about-section{background:#f8f9fa;padding:80px 0}.about-section .container{margin:0 auto;max-width:900px;padding:0 20px}.about-section h2{color:#333;font-size:36px;font-weight:700;margin-bottom:40px;text-align:center}.about-content{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:50px}.about-intro{color:#333;font-size:20px;font-weight:600;line-height:1.8;margin-bottom:25px}.about-text{color:#555;font-size:18px;line-height:1.8;margin-bottom:20px}.about-text:last-child{margin-bottom:0}.cta-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:80px 0;text-align:center}.cta-section h2{font-size:36px;font-weight:700;margin-bottom:20px}.cta-section p{font-size:18px;margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:600px;opacity:.9}@media (max-width:768px){.hero-logo-img{height:60px}.hero h1{font-size:32px;line-height:1.2}.hero-subtitle{font-size:20px}.hero-description{font-size:16px;padding:0 10px}.cta-buttons{align-items:center;flex-direction:column;gap:15px}.btn-primary,.btn-secondary{font-size:16px;padding:15px 30px;touch-action:manipulation;width:280px}.arduino-projects,.characteristics-grid,.mobile-features,.proficiency-levels,.resources-grid{gap:20px;grid-template-columns:1fr}.about-section,.challenge-section,.characteristics-section h2,.internships-section h2,.mission-section,.proficiency-section h2,.resources-section h2,.solution-section,.vision-section h2{padding:60px 0}.about-section h2,.challenge-section h2,.mission-section h2,.solution-section h2{font-size:28px;margin-bottom:30px}.section-icon{font-size:36px;margin-bottom:15px}.challenge-content{gap:20px;grid-template-columns:1fr}.challenge-card{padding:30px 20px}.solution-intro{font-size:18px;margin-bottom:40px;padding:20px}.solution-features{gap:30px;grid-template-columns:1fr}.solution-feature{padding:30px 20px}.feature-icon-wrapper{height:60px;margin-bottom:20px;width:60px}.feature-icon{font-size:30px}.solution-feature h3{font-size:20px}.mission-icon-large{font-size:60px;margin-bottom:20px}.mission-text{font-size:18px}.about-content,.mission-text{padding:30px 20px}.about-intro{font-size:18px}.about-text{font-size:16px}.arduino-section h2,.cta-section h2,.mobile-features-section h2{font-size:28px;line-height:1.2}.proficiency-header{flex-direction:column;text-align:center}.proficiency-icon{margin-bottom:15px;margin-right:0}.discord-content{gap:40px;grid-template-columns:1fr;text-align:center}.discord-text h2{font-size:28px}.discord-description{font-size:16px}.discord-join-btn{font-size:16px;padding:12px 25px;touch-action:manipulation}.discord-features{gap:20px}.discord-feature{flex-direction:column;gap:15px;text-align:center}.feature-icon{margin-top:0}.arduino-project-card,.mobile-feature{padding:20px}.mobile-feature .feature-icon,.project-icon{font-size:2.5rem}.tag{font-size:11px;padding:3px 10px}}@media (max-width:414px){.hero{padding:60px 15px}.hero h1{font-size:28px}.hero-subtitle{font-size:18px}.hero-description{font-size:15px}.btn-primary,.btn-secondary{max-width:300px;width:100%}.container{padding:0 15px}.arduino-section,.characteristics-section,.cta-section,.internships-section,.mobile-features-section,.proficiency-section,.resources-section,.vision-section{padding:60px 0}.arduino-project-card,.characteristic-card,.discord-feature,.mobile-feature,.proficiency-card,.proficiency-header,.resource-card{padding:20px 15px}}@media (hover:none) and (pointer:coarse){.arduino-project-card:hover,.characteristic-card:hover,.mobile-feature:hover,.proficiency-card:hover,.resource-card:hover{box-shadow:0 4px 15px #0000001a;transform:none}.btn-primary:hover,.btn-secondary:hover,.discord-join-btn:hover,.hero-logo-img:hover{transform:none}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:12px;box-shadow:0 15px 35px #00000026;max-width:450px;padding:40px;transition:all .3s ease;width:100%}.registration-card{max-width:800px}.auth-logo{display:flex;justify-content:center;margin-bottom:20px}.auth-logo-img{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));height:60px;object-fit:contain;width:auto}.auth-card h2{color:#333;margin-bottom:10px;margin-top:0}.required-indicator{color:#e74c3c;margin-left:4px}.count-display{color:#666;font-size:12px;margin-top:5px;text-align:right}.count-display.warning{color:#e74c3c;font-weight:700}.form-group input,.form-group select,.form-group textarea,.form-select{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.form-select:focus{border-color:#667eea;outline:none}.btn-primary{border-radius:5px;padding:12px;transition:background .3s;width:100%}.btn-primary:hover{background:#5568d3}.error-message{border-radius:5px;padding:10px}.auth-link{color:#666;margin-top:20px;text-align:center}.auth-link a{color:#667eea;font-weight:600;text-decoration:none}.auth-link a:hover{text-decoration:underline}.auth-header{margin-bottom:30px;text-align:center}.auth-header h2{color:#333;font-size:28px;margin-bottom:8px}.auth-header p{color:#666;font-size:16px;margin:0}.oauth-section{margin-bottom:25px}.oauth-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px;justify-content:center;margin-bottom:10px;padding:12px 16px;transition:all .3s ease;width:100%}.oauth-btn:hover{background-color:#f8f9fa;border-color:#ccc;transform:translateY(-2px)}.google-btn:hover{background-color:#ffeaea;border-color:#db4437}.github-btn:hover{background-color:#f0f0f0;border-color:#333}.discord-btn:hover{background-color:#f0f2ff;border-color:#7289da}.email-btn{background:#f8f9fa;border-color:#4caf50;color:#4caf50}.email-btn:hover{background-color:#4caf50;border-color:#4caf50;color:#fff}.auth-method-section{margin-bottom:25px}.oauth-icon{font-size:18px}.divider{align-items:center;color:#666;display:flex;margin:25px 0}.divider:after,.divider:before{background:#e0e0e0;content:"";flex:1 1;height:1px}.divider span{font-size:14px;padding:0 15px}.form-group input,.form-select{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:14px;transition:all .3s ease}.form-group input:focus,.form-select:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.form-options{display:flex;justify-content:flex-end;margin-bottom:20px}.forgot-password-link{color:#4caf50;font-size:14px;font-weight:500;text-decoration:none;transition:color .3s ease}.forgot-password-link:hover{color:#45a049;text-decoration:underline}.login-btn{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:8px;font-size:16px;padding:16px;transition:all .3s ease}.login-btn:hover{box-shadow:0 8px 20px #4caf504d;transform:translateY(-2px)}.login-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.auth-footer{border-top:1px solid #e0e0e0;margin-top:30px;padding-top:20px;text-align:center}.auth-footer p{color:#666;font-size:14px;margin:10px 0}.back-to-login,.signup-link{color:#4caf50;font-weight:600;text-decoration:none;transition:color .3s ease}.back-to-login:hover,.signup-link:hover{color:#45a049;text-decoration:underline}.user-type-links{border-top:1px solid #f0f0f0;margin-top:20px;padding-top:15px}.role-links{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-top:10px}.role-link{background-color:#f8f9fa;border-radius:6px;color:#4caf50;display:block;font-size:13px;font-weight:500;padding:8px 12px;text-align:center;text-decoration:none;transition:all .3s ease}.role-link:hover{background-color:#4caf50;color:#fff;transform:translateY(-2px)}.forgot-password-form,.reset-btn{margin-top:20px}.reset-btn{background:linear-gradient(135deg,#4caf50,#45a049)}.success-message{padding:20px;text-align:center}.success-icon{background:#4caf50;border-radius:50%;color:#fff;display:inline-block;font-size:24px;font-weight:700;height:60px;line-height:60px;margin-bottom:20px;width:60px}.reset-instructions{background:#f8f9fa;border-radius:8px;margin-top:20px;padding:20px;text-align:left}.reset-instructions h4{color:#333;margin:0 0 15px}.reset-instructions ol{margin:0;padding-left:20px}.reset-instructions li{color:#666;margin-bottom:8px}.reset-password-form{margin-top:20px}.password-requirements{background:#f8f9fa;border-radius:6px;font-size:13px;margin-top:10px;padding:15px}.password-requirements p{color:#333;font-weight:600;margin:0 0 10px}.password-requirements ul{margin:0;padding-left:20px}.password-requirements li{color:#666;margin-bottom:5px;transition:color .3s ease}.password-requirements li.valid{color:#4caf50;font-weight:500}.field-error{color:#e74c3c;font-size:12px;font-weight:500;margin-top:5px}.progress-bar{gap:20px;margin-bottom:30px}.progress-bar,.progress-step{align-items:center;display:flex;justify-content:center}.progress-step{background:#e0e0e0;border-radius:50%;color:#999;font-weight:600;height:40px;transition:all .3s ease;width:40px}.progress-step.active{background:#4caf50;color:#fff}.registration-step{margin-bottom:20px}.step-header{margin-bottom:25px;text-align:center}.step-header h3{color:#333;font-size:22px;margin:0 0 8px}.step-header p{color:#666;margin:0}.form-row{margin-bottom:20px}.step-navigation{display:flex;gap:15px;justify-content:space-between;margin-top:30px}.btn-secondary:hover{transform:translateY(-2px)}.child-form{background:#fafafa;border:2px solid #e0e0e0;border-radius:12px;margin-bottom:20px;padding:20px}.child-header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.child-header h4{color:#333;font-size:18px;margin:0}.btn-danger-small{background:#e74c3c;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .3s ease}.btn-danger-small:hover{background:#c0392b}.preferred-timings{margin-top:20px}.section-header{margin-bottom:15px}.section-header h5{color:#333;font-size:16px;margin:0}.btn-secondary-small{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .3s ease}.timing-slot{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:10px;padding:15px;position:relative}.add-child-btn{background:#f8f9fa;border:2px dashed #4caf50;border-radius:8px;color:#4caf50;cursor:pointer;font-weight:600;padding:15px;transition:all .3s ease;width:100%}.add-child-btn:hover:not(:disabled){background:#4caf50;color:#fff}.add-child-btn:disabled{background:#f8f9fa;border-color:#dee2e6;color:#6c757d;cursor:not-allowed;opacity:.6}@media (max-width:768px){.auth-container{min-height:100vh;min-height:-webkit-fill-available;padding:10px}.auth-card{margin:10px;max-width:100%;padding:25px}.registration-card{max-width:95vw}.auth-logo-img{height:50px}.form-group input,.form-group select,.form-group textarea,.form-select{font-size:16px;padding:12px;touch-action:manipulation}.form-row{gap:15px}.form-row,.role-links{grid-template-columns:1fr}.step-navigation{flex-direction:column;gap:10px}.step-navigation button{touch-action:manipulation;width:100%}.progress-bar{gap:10px}.progress-step{font-size:14px;height:35px;width:35px}.btn-primary,.btn-secondary,.oauth-btn{touch-action:manipulation;width:100%}.oauth-btn{margin-bottom:10px}}@media (max-width:414px){.auth-container{padding:5px}.auth-card{margin:5px;padding:20px 15px}.registration-card{padding:15px 10px}.auth-logo-img{height:45px}.auth-card h2{font-size:24px}.form-group input,.form-group select,.form-group textarea,.form-select{padding:10px}}.admin-login-link{border-top:1px solid #e9ecef;margin-top:20px;padding-top:20px;text-align:center}.admin-link{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 4px 15px #667eea4d;display:inline-block;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:all .3s ease}.admin-link,.admin-link:hover{color:#fff;text-decoration:none}.admin-link:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.admin-link:active{transform:translateY(0)}@media (max-width:480px){.admin-link{font-size:12px;padding:10px 20px}}.registration-code-field{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:20px;padding:15px}.registration-code-field label{color:#495057;font-weight:600;margin-bottom:8px}.registration-code-field input{background:#fff;border:2px solid #dee2e6;border-radius:6px;box-sizing:border-box;font-family:Courier New,monospace;font-size:16px;letter-spacing:2px;padding:12px;text-align:center;text-transform:uppercase;width:100%}.registration-code-field input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.star-rating{flex-direction:column;gap:.5rem}.star-rating-label{color:#333;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.star-rating-container{align-items:center;display:flex;gap:.25rem}.star-rating .star{color:#ddd;display:inline-block;font-size:1.5rem;overflow:hidden;position:relative;transition:color .2s ease,transform .1s ease;-webkit-user-select:none;user-select:none}.star-rating .star .star-base{color:inherit;display:inline-block;width:100%}.star-rating .star .star-half{-webkit-clip-path:inset(0 50% 0 0);clip-path:inset(0 50% 0 0);color:#ffc107;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:50%}.star-rating .star.half,.star-rating .star.half .star-base{color:#ddd}.star-rating.small .star{font-size:1rem}.star-rating.large .star{font-size:2rem}.star-rating .star.filled{color:#ffc107}.star-rating .star.empty{color:#ddd}.star-rating:not(.readonly) .star:hover{color:#ffc107;transform:scale(1.1)}.star-rating:not(.readonly) .star.filled:hover~.star{color:#ddd}.star-rating-value{color:#666;font-size:.875rem;font-weight:500;margin-left:.5rem}.star-rating.readonly .star{cursor:default!important}.form-group .star-rating{margin-top:.5rem}.form-group .star-rating-label{display:block;font-weight:500;margin-bottom:.5rem}.proficiency-item .star-rating{align-items:center;flex-direction:row;justify-content:space-between}.proficiency-item .star-rating-container{flex:1 1;justify-content:flex-end}.student-portal{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px}.portal-layout{grid-gap:20px;display:grid;gap:20px;grid-template-columns:300px 1fr;margin:0 auto;max-width:1600px;width:100%}.portal-container{max-width:100%;width:100%}.portal-header{color:#333;margin-bottom:40px}.portal-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-weight:700;margin-bottom:10px}.portal-header p{color:#666;margin:0 0 25px}.student-profile-card{background:#fff;border-radius:10px;box-shadow:0 10px 35px #0f172a14;margin-bottom:30px;padding:24px}.student-profile-card-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:12px}.student-profile-card-header h2{color:#1f2937;font-size:1.6rem;margin:0}.student-profile-subtitle{color:#6b7280;font-size:.95rem;margin:6px 0 0}.btn-student-edit{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 18px;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.btn-student-edit:disabled{box-shadow:none;cursor:not-allowed;opacity:.6}.btn-student-edit:not(:disabled):hover{box-shadow:0 8px 20px #667eea40;transform:translateY(-1px)}.student-profile-close-btn{background:#0000;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;font-size:1.5rem;line-height:1;padding:4px 8px;transition:background .15s ease,color .15s ease}.student-profile-close-btn:hover{background:#94a3b826;color:#4b5563}.student-profile-message{border-radius:6px;font-size:.95rem;font-weight:500;margin:12px 0;padding:12px 16px}.student-profile-message-success{background:#ecfdf3;border:1px solid #027a4833;color:#027a48}.student-profile-message-error{background:#fef3f2;border:1px solid #b4231833;color:#b42318}.student-profile-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:20px}.student-profile-field{display:flex;flex-direction:column;gap:6px}.student-profile-field .label,.student-profile-field label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.student-profile-field .value{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;color:#1f2937;display:block;font-size:.95rem;padding:10px 12px}.student-profile-grid.editable .student-profile-field input{border:1px solid #d0d5dd;border-radius:8px;font-size:.95rem;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease}.student-profile-grid.editable .student-profile-field input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.student-profile-field.full-width{grid-column:1/-1}.student-profile-note{color:#6b7280;font-size:.85rem;margin-top:14px}.student-profile-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.student-profile-actions button{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:10px 18px;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.student-profile-save-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.student-profile-save-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.6}.student-profile-save-btn:not(:disabled):hover{box-shadow:0 8px 20px #667eea40;transform:translateY(-1px)}.student-profile-cancel-btn{background:#f3f4f6;color:#374151}.student-profile-cancel-btn:hover{background:#e5e7eb}.cohort-tabs-section{margin-bottom:40px;margin-top:20px}.cohorts-list{align-self:start;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-height:calc(100vh - 80px);overflow-y:auto;padding:20px;position:-webkit-sticky;position:sticky;top:20px}.cohorts-list h2{border-bottom:2px solid #e0e0e0;color:#333;font-size:1.3rem;font-weight:600;margin:0 0 20px;padding-bottom:15px}.cohort-item{background:#fff;border:1px solid #e0e0e0;border-radius:5px;cursor:pointer;margin-bottom:10px;padding:15px;transition:all .2s}.cohort-item:hover{background:#f5f5f5;border-color:#667eea;transform:translateX(3px)}.cohort-item.active{background:#667eea;border-color:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.cohort-item h3{font-size:16px;font-weight:600;margin:0 0 8px}.cohort-item.active h3{color:#fff}.cohort-description-small{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:13px;line-height:1.4;margin:8px 0 0;overflow:hidden}.cohort-item.active .cohort-description-small{color:#ffffffe6}.cohort-meta{align-items:center;color:#888;font-size:12px;gap:4px;margin:6px 0 0}.cohort-item.active .cohort-meta{color:#fffc}.cohort-content-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:100%;min-height:400px;padding:40px;width:100%}.cohort-tab-content{animation:fadeIn .3s ease;display:flex;flex-direction:column;gap:35px}@media (max-width:768px){.portal-layout{gap:15px;grid-template-columns:1fr}.cohorts-list{max-height:none;order:1;position:relative;top:0}.portal-container{order:2}.cohort-content-panel{padding:20px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cohort-header{border-bottom:2px solid #e8eaed;margin-bottom:40px;padding-bottom:25px;text-align:center;width:100%}.cohort-header h2{color:#333;font-size:2.2rem;font-weight:700;margin-bottom:12px;text-align:center}.cohort-description{color:#666;font-size:1.05rem;line-height:1.6;margin:0 auto;max-width:800px}.proficiency-ratings-section{background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.proficiency-ratings-section h3{border-bottom:1px solid #dee2e6;color:#333;font-size:1.6rem;font-weight:600;margin-bottom:25px;padding-bottom:15px}.rating-overall{color:#667eea;font-size:1.2rem;text-align:center}.cohort-section{display:flex;justify-content:center;margin-top:20px}.cohort-badge{align-items:center;border-radius:25px;box-shadow:0 4px 15px #667eea4d;display:flex;gap:12px;padding:12px 24px;transition:transform .3s ease,box-shadow .3s ease}.cohort-badge:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.cohort-icon{font-size:1.2rem;opacity:.9}.cohort-content{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.cohort-label{font-size:.8rem;font-weight:500;letter-spacing:.5px;opacity:.8;text-transform:uppercase}.cohort-name{font-size:1.1rem;font-weight:600;line-height:1.2}.cohort-card{border-radius:15px;box-shadow:0 4px 15px #0000001a;margin-bottom:20px;width:100%}.tutors-section{background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.tutors-section h3{border-bottom:1px solid #dee2e6;color:#333;font-size:1.6rem;font-weight:600;margin-bottom:25px;padding-bottom:15px}.tutors-grid{grid-gap:20px;gap:20px;justify-items:center;margin-top:15px}.tutor-card{box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:500px;transition:transform .3s ease,box-shadow .3s ease;width:100%}.tutor-card:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-3px)}.tutor-header{align-items:center;flex-direction:column;gap:15px;justify-content:center;text-align:center}.tutor-avatar{border:3px solid #667eea;border-radius:50%;height:60px;object-fit:cover;width:60px}.tutor-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid #764ba2;border-radius:50%;color:#fff;display:flex;font-size:1.2rem;font-weight:600;height:60px;justify-content:center;width:60px}.tutor-info{align-items:center;display:flex;flex:1 1;flex-direction:column;text-align:center}.tutor-info h4{color:#333;font-size:1.1rem;font-weight:600;margin:10px 0 5px}.tutor-email{margin:0 0 8px}.tutor-bio{color:#555;font-size:.85rem;font-style:italic;line-height:1.4;margin:0}.btn-view-details{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;margin-top:8px;padding:6px 12px;transition:all .3s ease}.btn-view-details:hover{box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}.tutor-details-modal{max-width:600px!important}.tutor-details-content{display:flex;flex-direction:column;gap:20px}.tutor-details-header{align-items:flex-start;border-bottom:1px solid #e0e0e0;display:flex;gap:20px;padding-bottom:20px}.tutor-details-avatar{border:3px solid #667eea;border-radius:50%;height:80px;object-fit:cover;width:80px}.tutor-details-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid #764ba2;border-radius:50%;color:#fff;display:flex;font-size:1.8rem;font-weight:600;height:80px;justify-content:center;width:80px}.tutor-details-info{flex:1 1}.tutor-details-info h3{color:#333;font-size:1.5rem;font-weight:600;margin:0 0 8px}.tutor-details-email{color:#666;font-size:1rem;margin:0 0 5px}.tutor-details-cohort{color:#667eea;font-size:.9rem;font-weight:500;margin:0}.tutor-details-bio{padding-top:20px}.tutor-details-bio h4{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 12px}.tutor-details-bio p{color:#555;font-size:.95rem;line-height:1.6;margin:0}.tutor-details-bio p.no-bio{color:#999;font-style:italic}.tutor-rating-section{background:#f8f9fa;border-radius:10px;margin-top:15px;padding:20px;text-align:center}.rating-label{color:#666;font-size:.9rem;margin:0 0 15px}.star-rating{display:flex;gap:8px;justify-content:center;margin-bottom:15px}.star{background:none;border:none;color:#ddd;cursor:pointer;font-size:2rem;line-height:1;padding:0;transition:all .2s ease}.star:hover{transform:scale(1.2)}.star.filled,.star:hover{color:#ffc107}.your-rating{color:#667eea;font-size:.9rem;font-weight:600;margin:8px 0 5px;text-align:center}.average-rating{color:#888;font-size:.85rem;font-style:italic;margin:5px 0 0;text-align:center}.btn-rate-tutor{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:12px;padding:8px 16px;transition:all .3s ease;width:100%}.btn-rate-tutor:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.tutor-rating-form{padding:20px}.tutor-rating-form .form-group{margin-bottom:20px}.tutor-rating-form label{color:#333;display:block;font-weight:500;margin-bottom:8px}.star-rating-form{display:flex;gap:10px;justify-content:center;margin:15px 0}.star-form{background:none;border:none;color:#ddd;cursor:pointer;font-size:2.5rem;line-height:1;padding:0;transition:all .2s ease}.star-form:hover{color:#ffc107;transform:scale(1.2)}.star-form.filled{color:#ffc107}.selected-rating-text{color:#667eea;font-size:.95rem;font-weight:600;margin-top:10px;text-align:center}.feedback-textarea{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:.95rem;min-height:100px;padding:12px;resize:vertical;width:100%}.feedback-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.character-count{color:#999;font-size:.8rem}.sticker-section{display:flex;justify-content:center;margin:35px 0}.sticker-badge{align-items:center;background:linear-gradient(135deg,#667eea20,#764ba240);border:2px solid #667eea;border-radius:15px;box-shadow:0 6px 20px #667eea26;display:flex;flex-direction:column;gap:15px;margin:0 auto;max-width:600px;overflow:hidden;padding:25px 30px;position:relative;text-align:center;transition:transform .3s ease,box-shadow .3s ease;width:100%}.sticker-badge:before{background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:translateX(-100%);transition:transform .6s ease}.sticker-badge:hover{box-shadow:0 8px 25px #667eea40;transform:translateY(-3px)}.sticker-badge:hover:before{transform:translateX(100%)}.sticker-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;font-size:3.5rem}.sticker-content{flex:1 1;min-width:0;width:100%}.sticker-title{font-size:1.8rem;font-weight:700;line-height:1.2;margin-bottom:8px;text-align:center;text-shadow:0 1px 2px #0000001a}.sticker-description{font-size:1rem;font-weight:500;line-height:1.5;opacity:.9;text-align:center}.help-suggestion{display:flex;justify-content:center;margin:35px 0}.help-card{align-items:flex-start;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border-radius:12px;box-shadow:0 4px 15px #0000000d;display:flex;gap:15px;max-width:600px;padding:20px;transition:transform .3s ease,box-shadow .3s ease;width:100%}.help-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.help-icon{flex-shrink:0;font-size:1.5rem;margin-top:2px}.help-content{flex:1 1}.help-content h3{color:#495057;font-size:1.2rem;font-weight:600;margin:0 0 10px}.help-content p{color:#6c757d;font-size:1rem;line-height:1.5;margin:0 0 15px}.help-content strong{color:#495057;font-weight:600}.help-tips{display:flex;flex-wrap:wrap;gap:10px}.tip{background:#fff;border:1px solid #dee2e6;border-radius:20px;box-shadow:0 2px 4px #0000000d;color:#495057;font-size:.85rem;font-weight:500;padding:6px 12px}.dashboard-stats{background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-card{align-items:center;border-radius:12px;box-shadow:0 4px 20px #667eea4d;display:flex;gap:20px;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{box-shadow:0 8px 30px #667eea66;transform:translateY(-5px)}.stat-icon{font-size:2.5rem;opacity:.9}.stat-content h3{font-size:1.1rem;font-weight:600;margin:0 0 10px;opacity:.9}.stat-number{font-size:2.5rem;line-height:1;margin:0 0 5px}.stat-content p{font-size:.9rem;margin:0;opacity:.8}.proficiency-section{border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.proficiency-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:30px;text-align:center}.proficiency-header{gap:15px;justify-content:center;margin-bottom:25px}.proficiency-header h3{color:#333;font-size:1.5rem;font-weight:600;margin:0}.proficiency-icon{font-size:1.8rem;opacity:.8}.proficiency-content{align-items:center;display:flex;flex-direction:column;gap:20px}.proficiency-rating{align-items:baseline;display:flex;gap:5px}.rating-number{color:#667eea;font-size:3rem;font-weight:700;line-height:1}.rating-percent{color:#667eea;font-size:2rem;font-weight:600}.proficiency-bar{max-width:300px}.progress-bar{background-color:#e0e0e0;height:12px;overflow:hidden;width:100%}.progress-bar,.progress-fill{border-radius:6px;position:relative}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .8s ease-in-out}.progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d 50%,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.proficiency-description{color:#666;font-size:1rem;margin:0;max-width:300px}.loading-text{color:#999;font-style:italic}.last-projects-section{align-items:center;background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;padding:30px}.last-projects-section h3{border-bottom:1px solid #dee2e6;color:#333;font-size:1.6rem;font-weight:600;margin-bottom:25px;padding-bottom:15px;text-align:left;width:100%}.last-projects-header{align-items:center;display:flex;gap:15px;margin-bottom:25px}.last-projects-header h3{color:#333;font-size:1.6rem;font-weight:600;margin:0}.project-icon{font-size:1.8rem;opacity:.8}.last-projects-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));max-width:1200px;width:100%}.last-project-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;box-shadow:0 8px 25px #667eea4d;color:#fff;padding:20px;position:relative;transition:transform .3s ease,box-shadow .3s ease}.last-project-card:hover{box-shadow:0 12px 35px #667eea66;transform:translateY(-5px)}.project-rank{background:linear-gradient(135deg,#4caf50,#8bc34a);border-radius:15px;box-shadow:0 3px 10px #4caf504d;color:#fff;font-size:.8rem;font-weight:600;left:20px;padding:5px 12px;position:absolute;top:-10px}.last-project-content{display:flex;flex-direction:column;gap:15px}.project-details{flex:1 1}.project-name{color:#fff;font-size:1.1rem;font-weight:600;line-height:1.3;margin:0 0 8px}.project-date{color:#ffffffe6;font-size:.85rem;margin:0 0 5px;opacity:.8}.project-grader{color:#ffffffe6;font-size:.8rem;font-style:italic;margin:0 0 8px;opacity:.7}.project-feedback{background:#ffffff1a;border-radius:8px;margin-top:10px;padding:10px}.feedback-text{color:#fffffff2;font-size:.8rem;font-style:italic;line-height:1.4;margin:0}.project-rating{align-items:center;border-top:1px solid #fff3;display:flex;flex-direction:column;gap:8px;padding-top:10px}.project-rating-number{color:#fff;font-size:1.8rem;font-weight:700;line-height:1}.project-rating-bar{background:#fff3;border-radius:10px;height:6px;overflow:hidden;width:100%}.project-progress-fill{background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:10px;height:100%;transition:width .3s ease}.project-actions{display:flex;justify-content:center;margin-top:15px}.review-button{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;box-shadow:0 3px 10px #28a7454d;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.review-button:hover{background:linear-gradient(135deg,#218838,#1e7e34);box-shadow:0 6px 20px #28a74566;transform:translateY(-2px)}.review-button .button-icon{font-size:1rem}.modal-overlay{align-items:center!important;background:#000c!important;bottom:0!important;display:flex!important;height:100vh!important;justify-content:center!important;left:0!important;overflow-y:auto!important;padding:20px!important;position:fixed!important;right:0!important;top:0!important;width:100vw!important;z-index:99999!important}.review-modal{background:#fff!important;border:3px solid red!important;border-radius:15px;box-shadow:0 20px 60px #0000004d;margin:auto;max-height:90vh;max-width:900px;overflow-y:auto;position:relative;width:100%}.review-sections{display:flex;flex-direction:column;gap:25px}.review-section{background:#f8f9fa;border-left:4px solid #667eea;border-radius:12px;padding:20px}.review-section h3{align-items:center;color:#333;display:flex;font-size:1.3rem;font-weight:600;gap:10px;margin:0 0 15px}.review-section h3:before{content:"📋";font-size:1.2rem}.overview-info{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{background:#fff;border:1px solid #e0e0e0;font-size:.9rem;padding:12px 15px}.info-item strong{color:#667eea;margin-right:8px}.responses-grid{grid-gap:15px;display:grid;gap:15px}.response-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:15px}.response-item h4{color:#333;font-size:1rem;font-weight:600;margin:0 0 10px}.response-item p{color:#555;font-size:.9rem;line-height:1.5;margin:0}.work-links{display:flex;flex-direction:column;gap:8px}.work-link{background:#f0f4ff;border-radius:5px;color:#667eea;font-size:.9rem;padding:5px 10px;text-decoration:none;transition:all .3s ease}.work-link:hover{background:#e0e8ff;text-decoration:underline}.feedback-content{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;position:relative}.feedback-content p{color:#555;font-size:1rem;font-style:italic;line-height:1.6;margin:0 0 15px}.feedback-author{color:#667eea;font-size:.9rem;font-weight:600;text-align:right}.solution-content{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.solution-content p{color:#555;font-size:1rem;line-height:1.6;margin:0 0 15px}.solution-note{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;color:#856404;font-size:.9rem;padding:12px}.modal-footer{background:#f8f9fa;border-radius:0 0 15px 15px;border-top:1px solid #e0e0e0;padding:20px 25px}.btn-secondary{border-radius:8px;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.leaderboard-section{background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.leaderboard-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:25px}.leaderboard-header{margin-bottom:25px;text-align:center}.leaderboard-header h3{color:#333;font-size:1.8rem;font-weight:700;margin:0 0 8px}.leaderboard-subtitle{color:#666;font-size:1rem;font-weight:500}.leaderboard-loading{padding:40px 20px;text-align:center}.leaderboard-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.leaderboard-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;display:flex;gap:15px;padding:15px 20px;transition:all .3s ease}.leaderboard-item:hover{background:#e9ecef;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.leaderboard-item.top-three{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-color:#ffc107;box-shadow:0 4px 15px #ffc10733}.rank-position{align-items:center;display:flex;font-weight:700;justify-content:center;min-width:50px}.rank-icon{font-size:1.5rem}.rank-number{color:#6c757d;font-size:1.1rem}.student-info{flex:1 1;min-width:0}.student-name{color:#333;font-size:1.1rem;margin-bottom:4px}.student-cohort,.student-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-cohort{color:#666;font-size:.9rem}.student-stats{min-width:120px;text-align:right}.proficiency-score{align-items:center;color:#28a745;display:flex;font-size:1.2rem;font-weight:700;justify-content:center;margin-bottom:4px}.challenges-count{color:#6c757d;font-size:.85rem}.leaderboard-actions{border-top:1px solid #e9ecef;padding-top:15px;text-align:center}.view-full-leaderboard-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 20px;transition:all .3s ease}.view-full-leaderboard-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.full-leaderboard-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:absolute}.modal-content{animation:modalSlideIn .3s ease-out;box-shadow:0 20px 40px #0003;overflow:hidden;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.modal-header h2{font-weight:700}.close-modal-btn{align-items:center;background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:35px;justify-content:center;padding:5px;transition:all .2s ease;width:35px}.close-modal-btn:hover{background:#e9ecef;color:#333}.modal-body{max-height:60vh;overflow-y:auto;padding:20px 25px}.full-leaderboard-list{display:flex;flex-direction:column;gap:10px}.full-leaderboard-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;gap:12px;padding:12px 15px;transition:all .2s ease}.full-leaderboard-item:hover{background:#e9ecef}.full-leaderboard-item.top-three{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-color:#ffc107}.full-leaderboard-item .rank-position{min-width:40px}.full-leaderboard-item .student-info{flex:1 1}.full-leaderboard-item .student-name{font-size:1rem;margin-bottom:2px}.full-leaderboard-item .student-cohort{font-size:.85rem}.full-leaderboard-item .student-stats{min-width:100px}.full-leaderboard-item .proficiency-score{align-items:center;display:flex;font-size:1.1rem;justify-content:center}.full-leaderboard-item .challenges-count{font-size:.8rem}.current-challenge{background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.challenge-card{box-shadow:0 4px 20px #0000001a;overflow:hidden}.challenge-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px}.challenge-header h2{font-size:1.5rem;font-weight:600;margin:0}.status-badge{background:#fff3;font-size:.9rem;padding:6px 12px}.status-badge.active{background:#28a745;color:#fff}.challenge-content{padding:30px}.challenge-title{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:15px}.challenge-description{color:#666;font-size:1.1rem;margin-bottom:25px}.challenge-requirements h4{color:#333;font-size:1.2rem;font-weight:600;margin-bottom:15px}.challenge-requirements ul{list-style:none;margin:0;padding:0}.challenge-requirements li{color:#555;padding:8px 0 8px 25px;position:relative}.challenge-requirements li:before{color:#28a745;content:"✓";font-size:1.1rem;font-weight:700;left:0;position:absolute}.challenge-response{background:#f8f9fa;border:1px solid #e8eaed;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:30px}.response-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:30px}.response-header{justify-content:space-between;margin-bottom:25px}.response-header,.response-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.save-status{font-size:.9rem;font-weight:500}.save-status,.saving-indicator{align-items:center;display:flex}.saving-indicator{color:#ffc107;gap:5px}.saving-spinner{animation:spin 1s linear infinite}.unsaved-indicator{color:#dc3545}.saved-indicator{color:#28a745}.response-header h2{color:#333;flex:1 1;font-size:1.5rem;font-weight:600;margin:0}.response-help-tooltip{align-items:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #90caf9;border-radius:20px;box-shadow:0 2px 8px #1976d21a;color:#1976d2;cursor:help;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:8px 12px;transition:all .3s ease}.response-help-tooltip:hover{background:linear-gradient(135deg,#bbdefb,#90caf9);box-shadow:0 4px 12px #1976d233;transform:translateY(-1px)}.tooltip-icon{font-size:1rem}.tooltip-text{font-weight:600}.response-form{display:flex;flex-direction:column;gap:25px}.loading-template{color:#666;font-size:1.1rem;padding:40px;text-align:center}.template-info{background:#e3f2fd;border-left:4px solid #1976d2;border-radius:6px;margin-bottom:25px;padding:15px}.template-description-text{color:#1976d2;font-size:14px;line-height:1.5;margin:0}.question-help-text{align-items:flex-start;background:#f0f7ff;border-radius:6px;color:#1976d2;display:flex;font-size:13px;gap:8px;line-height:1.5;margin-bottom:10px;padding:10px}.question-help-text .help-icon{flex-shrink:0;font-size:16px;margin-top:2px}.required-indicator{color:#c62828;font-weight:700;margin-left:2px}.response-input{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 15px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.response-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.response-input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.7}.character-count{color:#666;font-size:.85rem;font-weight:500;margin-top:5px;text-align:right}.character-count:has(+*){color:#999}.form-group{gap:10px}.form-group label{font-size:1.1rem}.response-textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;line-height:1.5;min-height:120px;padding:15px;resize:vertical;transition:border-color .3s ease;width:100%}.response-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.response-textarea:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-help-text{background:linear-gradient(135deg,#e8f5e8,#f0f8f0);border:1px solid #c3e6c3;border-left:4px solid #28a745;border-radius:8px;margin-top:10px;padding:12px 15px}.form-help-text p{color:#155724;font-size:.9rem;line-height:1.4;margin:0}.form-help-text strong{color:#0d4f1c;font-weight:600}.response-textarea::placeholder{color:#999;font-style:italic}.btn-clear,.btn-save{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-save{background:#17a2b8}.btn-save:hover:not(:disabled){background:#138496;transform:translateY(-2px)}.btn-clear:hover:not(:disabled){background:#5a6268;transform:translateY(-2px)}.btn-clear:disabled,.btn-save:disabled{background:#adb5bd;cursor:not-allowed;transform:none}.btn-submit{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:6px;box-shadow:0 2px 8px #28a7454d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-submit:hover:not(:disabled){box-shadow:0 4px 12px #28a74566;transform:translateY(-2px)}.btn-submit:disabled{background:#adb5bd;box-shadow:none;cursor:not-allowed;transform:none}.message{font-size:1rem}.message-success{border-left:4px solid #28a745}.submission-success{margin-top:30px}.success-card{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #28a745;border-radius:12px;padding:30px;text-align:center}.success-card h3{color:#155724;font-size:1.8rem;font-weight:700;margin-bottom:15px}.success-card p{color:#155724;font-size:1.1rem;line-height:1.6;margin-bottom:25px}.next-steps{background:#ffffffb3;border-radius:8px;margin-top:20px;padding:20px;text-align:left}.next-steps h4{color:#155724;font-size:1.2rem;font-weight:600;margin-bottom:15px}.next-steps ul{list-style:none;margin:0;padding:0}.next-steps li{color:#155724;padding:8px 0 8px 25px;position:relative}.next-steps li:before{color:#28a745;content:"→";font-size:1.1rem;font-weight:700;left:0;position:absolute}@media (max-width:768px){.student-portal{padding:10px}.portal-header h1{font-size:2rem}.cohort-badge{flex-direction:column;gap:8px;padding:10px 20px;text-align:center}.cohort-content{align-items:center}.cohort-name{font-size:1rem}.sticker-badge{flex-direction:column;gap:15px;padding:15px 20px;text-align:center}.sticker-icon{font-size:2.5rem}.sticker-title{font-size:1.5rem}.sticker-description{font-size:.9rem}.help-card{flex-direction:column;gap:12px;padding:15px;text-align:center}.help-content h3{font-size:1.1rem}.help-content p{font-size:.9rem}.help-tips{justify-content:center}.tip{font-size:.8rem;padding:5px 10px}.stats-grid{gap:15px;grid-template-columns:1fr}.stat-card{flex-direction:column;gap:15px;padding:20px;text-align:center}.stat-icon,.stat-number{font-size:2rem}.proficiency-card{padding:20px}.proficiency-header{flex-direction:column;gap:10px}.proficiency-header h3{font-size:1.3rem}.rating-number{font-size:2.5rem}.rating-percent{font-size:1.5rem}.proficiency-bar{max-width:250px}.progress-bar{height:10px}.last-project-card{padding:20px}.last-project-content{align-items:flex-start;flex-direction:column;gap:15px}.project-rating{align-items:flex-start;width:100%}.project-rating-bar{width:100%}.challenge-content,.response-card{padding:20px}.response-header,.response-header-actions{align-items:flex-start;flex-direction:column;gap:10px}.save-status{font-size:.8rem}.response-help-tooltip{align-self:center;font-size:.8rem;padding:6px 10px}.challenge-header{gap:10px;padding:15px 20px;text-align:center}.challenge-header,.form-actions{flex-direction:column}.btn-clear,.btn-save,.btn-submit{width:100%}.response-textarea{min-height:100px}.form-help-text{padding:10px 12px}.form-help-text p{font-size:.8rem}.leaderboard-card{padding:20px}.leaderboard-header h3{font-size:1.5rem}.leaderboard-item{align-items:flex-start;flex-direction:column;gap:10px;padding:12px 15px}.rank-position{align-self:flex-start;min-width:auto}.student-info{width:100%}.student-stats{display:flex;justify-content:space-between;min-width:auto;text-align:left;width:100%}.modal-content{margin:10px;max-width:95vw}.modal-body{padding:15px 20px}.full-leaderboard-item{align-items:flex-start;flex-direction:column;gap:8px}.full-leaderboard-item .student-stats{display:flex;justify-content:space-between;width:100%}.tutors-grid{grid-template-columns:1fr}.tutor-card{padding:15px}.tutor-header{align-items:center;flex-direction:column;text-align:center}.tutor-avatar,.tutor-avatar-placeholder{height:80px;width:80px}.tutor-info{text-align:center}.star-rating{justify-content:center}.star{font-size:1.5rem}.last-projects-grid{gap:15px;grid-template-columns:1fr}.last-project-card{padding:15px}.project-rank{font-size:.7rem;left:15px;padding:4px 8px;top:-8px}.project-name{font-size:1rem}.project-date,.project-grader{font-size:.8rem}.feedback-text{font-size:.75rem}.project-rating-number{font-size:1.5rem}.modal-overlay{padding:10px}.review-modal{max-height:95vh}.modal-header{padding:15px 20px}.modal-header h2{font-size:1.3rem}.modal-body{padding:20px}.review-section{padding:15px}.review-section h3{font-size:1.1rem}.overview-info{grid-template-columns:1fr}.response-item{padding:12px}.response-item h4{font-size:.9rem}.response-item p{font-size:.85rem}.work-link{font-size:.8rem;padding:4px 8px}.feedback-content,.solution-content{padding:15px}.modal-footer{padding:15px 20px}}.dashboard{margin:0 auto;max-width:1400px;padding:20px}.dashboard h1{color:#333;margin-bottom:10px}.dashboard>p{color:#666;margin-bottom:30px}.dashboard-navigation{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:30px}.nav-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;gap:12px;min-width:200px;padding:15px 20px;transition:all .3s ease}.nav-button:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.nav-icon{font-size:20px}.nav-button span:not(.nav-icon){align-items:flex-start;display:flex;flex-direction:column}.nav-button span:first-of-type{font-size:16px;font-weight:600}.nav-description{font-size:12px;margin-top:2px;opacity:.9}.no-children-message{background:#f8f9fa;border-radius:6px;color:#666;margin:10px 0;padding:20px;text-align:center}.no-children-message p{margin:8px 0}.dashboard-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:300px 1fr}.challenges-list,.students-list,.submissions-list{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-height:calc(100vh - 200px);overflow-y:auto;padding:20px}.challenge-item,.student-item,.submission-item{border:1px solid #e0e0e0;border-radius:5px;cursor:pointer;margin-bottom:10px;padding:15px;transition:all .2s}.challenge-item:hover,.student-item:hover,.submission-item:hover{background:#f5f5f5;border-color:#667eea}.challenge-item.active,.student-item.active,.submission-item.active{background:#667eea;border-color:#667eea;color:#fff}.challenge-item h3,.student-item h3,.submission-item h3{font-size:16px;margin:0 0 5px}.status{border-radius:3px;display:inline-block;font-size:12px;font-weight:600;margin-top:5px;padding:3px 8px}.status-assigned{background:#e3f2fd;color:#1976d2}.status-in_progress{background:#fff3e0;color:#f57c00}.status-submitted{background:#f3e5f5;color:#7b1fa2}.status-graded{background:#e8f5e9;color:#388e3c}.challenge-details,.grading-panel,.student-progress{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px}.progress-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:30px}.progress-header h2{flex:1 1;margin:0;min-width:200px}.cohort-name-in-title{color:#495057;font-size:.9em;font-weight:600}.selected-cohort-badge{align-items:center;border:2px solid;border-radius:20px;display:inline-flex;font-size:14px;font-weight:600;gap:10px;padding:8px 16px;transition:all .2s ease}.selected-cohort-badge:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.clear-cohort-btn{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:20px;height:20px;justify-content:center;line-height:1;margin-left:4px;padding:0;transition:background-color .2s ease;width:20px}.clear-cohort-btn:hover{background-color:#0000001a}.no-cohort-progress{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:60px 40px;text-align:center}.no-cohort-progress h3{color:#495057;font-size:1.5rem;margin-bottom:15px}.no-cohort-progress p{color:#6c757d;line-height:1.6;margin:10px auto;max-width:600px}.no-cohort-progress strong{color:#495057}.challenge-description{background:#f5f5f5;border-radius:5px;line-height:1.6;margin:15px 0;padding:15px}.grade-form,.submission-form{margin-top:20px}.grade-form textarea,.submission-form textarea{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-family:monospace;margin-bottom:15px;padding:10px;width:100%}.ai-feedback{background:#e8f5e9;border-left:4px solid #4caf50;border-radius:5px;margin-top:20px;padding:15px}.ai-feedback h4{color:#2e7d32;margin-top:0}.dashboard-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d;color:#fff;padding:25px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-3px)}.stat-card h3{font-size:16px;opacity:.9}.stat-card .stat-value{font-size:42px;font-weight:700;line-height:1;margin:10px 0}.stat-card .stat-subtitle{font-size:14px;margin:0;opacity:.8}.stats-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;margin-bottom:20px;padding:20px;text-align:center}.stat-value{font-size:48px;font-weight:700;margin-top:10px}.grades-list{margin-top:20px}.grade-item{background:#f9f9f9;border-left:4px solid #667eea;border-radius:5px;margin-bottom:15px;padding:15px}.grade-item h4{color:#333;margin:0 0 10px}.grade-score{color:#667eea;font-size:20px;font-weight:700;margin-bottom:10px}.grade-feedback{color:#555;line-height:1.6;margin:10px 0}.grade-date,.submission-date{color:#999;font-size:12px;margin-top:5px}.submission-content{background:#f5f5f5;border-radius:5px;margin:15px 0}.graded-info{background:#e8f5e9;border-radius:5px;color:#2e7d32;margin-top:20px;padding:15px}@media (max-width:768px){.dashboard-content{grid-template-columns:1fr}.challenges-list,.students-list,.submissions-list{max-height:300px}}.mentor-content{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px}.challenges-overview{margin-bottom:30px}.challenges-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.challenge-card{background:#f9f9f9;border-radius:8px;padding:20px;transition:all .2s}.challenge-card:hover{box-shadow:0 4px 8px #0000001a}.challenge-card h3{color:#333;font-size:18px;margin:0 0 10px}.challenge-desc{color:#666;font-size:14px;line-height:1.5;margin-bottom:15px}.challenge-meta{align-items:center;justify-content:space-between}.student-info{background:#f5f5f5;border-radius:8px;margin-top:20px;padding:20px}.student-info h2{margin-top:0}.student-info p{color:#555;margin:10px 0}.proficiency-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;margin-bottom:30px;padding:25px}.proficiency-section h3{color:#333;font-size:22px;font-weight:600;margin:0 0 10px}.proficiency-categories{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.proficiency-item{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:15px;transition:all .2s ease}.proficiency-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.proficiency-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.category-name{color:#495057;font-size:14px;font-weight:600}.category-score{font-size:16px;font-weight:700}.category-rating,.stat-rating-container{align-items:center;display:flex}.stat-rating-container{justify-content:center}.star-rating-display{align-items:center;display:flex;flex-direction:column;gap:.5rem}.rating-text{color:#666;font-size:.875rem;font-weight:500}.no-rating-text{color:#999;font-style:italic}.proficiency-bar{background-color:#e9ecef;border-radius:4px;height:8px;overflow:hidden;width:100%}.proficiency-fill{border-radius:4px;height:100%;transition:width .3s ease}.completed-challenges-section{background:#fff;border:1px solid #e9ecef;border-radius:10px;margin-bottom:30px;padding:25px}.completed-challenges-section h3{color:#333;font-size:22px;font-weight:600;margin:0 0 10px}.challenges-grid{grid-gap:20px;gap:20px;margin-top:20px}.completed-challenge-card{background:#f8f9fa;border:1px solid #dee2e6;border-radius:10px;padding:20px;transition:all .2s ease}.completed-challenge-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-3px)}.challenge-header h4{color:#333;flex:1 1;font-size:18px;font-weight:600;margin:0 10px 0 0}.category-badge{background:#e3f2fd;border-radius:20px;color:#1976d2;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.challenge-grade{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:15px;padding:15px}.grade-score{color:#495057;font-size:16px;font-weight:600}.grade-percentage{font-size:18px;font-weight:700}.challenge-meta{color:#6c757d;font-size:13px;margin-bottom:10px}.challenge-meta p{margin:3px 0}.challenge-feedback{background:#e7f3ff;border:1px solid #b8daff;border-radius:6px;margin-top:10px;padding:12px}.challenge-feedback p{color:#004085;font-size:14px;line-height:1.5;margin:0}.weekly-progress-section{background:#fff;border:1px solid #e9ecef;border-radius:10px;padding:25px}.weekly-progress-section h3{color:#333;font-size:22px;font-weight:600;margin:0 0 10px}.histogram-container{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-top:20px;padding:20px}.histogram{align-items:end;display:flex;gap:8px;height:300px;justify-content:space-between;overflow-x:auto;padding:20px 0}.histogram-bar-container{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:60px}.histogram-bar{border-radius:4px 4px 0 0;cursor:pointer;margin-bottom:10px;max-width:50px;min-height:20px;transition:all .3s ease;width:100%}.histogram-bar:hover{opacity:.8;transform:scaleY(1.05)}.histogram-label{color:#6c757d;font-size:11px;height:40px;margin-bottom:5px;text-orientation:mixed;writing-mode:vertical-rl}.histogram-label,.histogram-value{align-items:center;display:flex;justify-content:center;text-align:center}.histogram-value{color:#495057;font-size:12px;font-weight:600}.no-data{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#6c757d;font-style:italic;padding:40px;text-align:center}@media (max-width:1200px){.proficiency-categories{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.challenges-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (max-width:768px){.dashboard-content{gap:15px;grid-template-columns:1fr}.students-list{margin-bottom:20px;max-height:200px}.challenges-grid,.proficiency-categories{grid-template-columns:1fr}.histogram{height:200px;padding:10px 0}.histogram-label{font-size:10px;height:30px}.challenge-header{align-items:flex-start;flex-direction:column;gap:10px}.challenge-grade{flex-direction:column;gap:10px;text-align:center}}.opportunities-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;margin-top:30px;padding:25px}.opportunities-section h3{color:#333;font-size:22px;font-weight:600;margin:0 0 10px}.section-subtitle{color:#6c757d;font-size:14px;font-style:italic;margin-bottom:20px}.opportunities-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:20px}.opportunity-card{background:#fff;border:1px solid #dee2e6;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:25px;transition:all .3s ease}.opportunity-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.opportunity-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.opportunity-header h4{color:#333;flex:1 1;font-size:18px;font-weight:600;line-height:1.3;margin:0 15px 0 0}.opportunity-type-badge{background:#e3f2fd;border-radius:20px;color:#1976d2;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:capitalize;white-space:nowrap}.opportunity-type-badge.type-competition{background:#fff3e0;color:#f57c00}.opportunity-type-badge.type-scholarship{background:#f3e5f5;color:#7b1fa2}.opportunity-type-badge.type-workshop{background:#e8f5e8;color:#388e3c}.opportunity-type-badge.type-internship{background:#fce4ec;color:#c2185b}.opportunity-description{color:#555;font-size:14px;line-height:1.6;margin-bottom:20px}.opportunity-details{border-top:1px solid #e9ecef;padding-top:20px}.opportunity-meta{margin-bottom:15px}.opportunity-meta p{align-items:center;color:#6c757d;display:flex;font-size:13px;margin:8px 0}.opportunity-meta strong{color:#495057;font-weight:600;min-width:140px}.opportunity-requirements{margin-bottom:15px}.opportunity-requirements p{color:#6c757d;font-size:13px;font-weight:600;margin:8px 0}.opportunity-requirements ul{margin:8px 0 0 20px;padding:0}.opportunity-requirements li{color:#6c757d;font-size:13px;line-height:1.4;margin:5px 0}.opportunity-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.opportunity-tag{background:#f8f9fa;border:1px solid #dee2e6;border-radius:15px;color:#6c757d;font-size:11px;font-weight:500;padding:4px 10px}.opportunity-actions{margin-top:20px;text-align:center}.register-button{background:linear-gradient(135deg,#28a745,#20c997);border-radius:8px;box-shadow:0 3px 10px #28a7454d;color:#fff;display:inline-block;font-size:14px;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .3s ease}.register-button:hover{background:linear-gradient(135deg,#218838,#1ea085);box-shadow:0 5px 15px #28a74566;color:#fff;text-decoration:none;transform:translateY(-2px)}@media (max-width:768px){.opportunities-grid{grid-template-columns:1fr}.opportunity-header{align-items:flex-start;flex-direction:column;gap:10px}.opportunity-header h4{margin-right:0}.opportunity-meta strong{min-width:120px}}.subscription-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:20px;padding:25px}.subscription-section h2{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:15px}.subscription-info{gap:15px}.subscription-info p{color:#666;line-height:1.5;margin:0}.upgrade-button{align-self:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.upgrade-button:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.upgrade-button:active{transform:translateY(0)}.student-sticker-small{align-items:center;border:1px solid;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;font-size:.85rem;font-weight:600;gap:8px;margin:10px 0;padding:8px 12px}.sticker-icon-small{flex-shrink:0;font-size:1.2rem}.sticker-title-small{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-sticker-large{display:flex;justify-content:center;margin:20px 0}.sticker-badge-large{align-items:center;background:linear-gradient(135deg,#667eea20,#764ba240);border:2px solid #667eea;border-radius:12px;box-shadow:0 4px 15px #667eea26;display:flex;gap:20px;max-width:600px;overflow:hidden;padding:20px 25px;position:relative;transition:transform .3s ease,box-shadow .3s ease;width:100%}.sticker-badge-large:before{background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:translateX(-100%);transition:transform .6s ease}.sticker-badge-large:hover{box-shadow:0 6px 20px #667eea33;transform:translateY(-2px)}.sticker-badge-large:hover:before{transform:translateX(100%)}.sticker-icon-large{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;font-size:2.5rem}.sticker-content-large{flex:1 1;min-width:0}.sticker-title-large{font-size:1.6rem;font-weight:700;line-height:1.2;margin-bottom:6px;text-shadow:0 1px 2px #0000001a}.sticker-description-large{font-size:.95rem;font-weight:500;line-height:1.4;opacity:.9}.survey-section{background:#f8f9fa;border-radius:12px;box-shadow:0 4px 15px #0000001a;margin:40px auto;max-width:1200px;padding:40px 20px;width:100%}.survey-section h2{color:#333;font-size:2rem;font-weight:700;margin-bottom:20px;text-align:center}.survey-content{grid-gap:40px;align-items:center;display:grid;gap:40px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1000px}.survey-info p{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:30px}.survey-benefits{display:flex;flex-direction:column;gap:15px}.benefit-item{align-items:center;display:flex;gap:12px;padding:12px 0}.benefit-icon{flex-shrink:0;font-size:1.5rem}.benefit-item span:last-child{color:#555;font-weight:500}.survey-actions{align-items:center;display:flex;flex-direction:column;gap:20px}.survey-button.single-survey{font-size:1.1rem;max-width:400px;padding:18px 32px;width:100%}.survey-button{align-items:center;border:none;border-radius:10px;box-shadow:0 4px 12px #0000001a;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:12px;justify-content:center;padding:18px 25px;text-decoration:none;transition:all .3s ease;width:100%}.survey-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.survey-button.primary:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 6px 20px #667eea4d;transform:translateY(-2px)}.survey-button.secondary{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.survey-button.secondary:hover{background:linear-gradient(135deg,#218838,#1e7e34);box-shadow:0 6px 20px #28a7454d;transform:translateY(-2px)}.button-icon{font-size:1.2rem}@media (max-width:768px){.subscription-section{margin-top:15px;padding:20px}.upgrade-button{text-align:center;width:100%}.sticker-badge-large{flex-direction:column;gap:15px;padding:15px 20px;text-align:center}.sticker-icon-large{font-size:2rem}.sticker-title-large{font-size:1.4rem}.sticker-description-large{font-size:.9rem}.survey-content{gap:30px;grid-template-columns:1fr;text-align:center}.survey-section h2{font-size:1.6rem}.survey-info p{font-size:1rem}.survey-button{font-size:.95rem;padding:15px 20px}.benefit-item{justify-content:center}}@media (max-width:414px){.survey-section{margin:20px 0;padding:30px 15px}.survey-section h2{font-size:1.4rem}.survey-info p{font-size:.95rem}.survey-button{font-size:.9rem;padding:12px 15px}.benefit-item{padding:8px 0}.benefit-icon{font-size:1.2rem}}.approval-status{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin:0 auto;max-width:600px;padding:40px;text-align:center}.approval-status h2{color:#e67e22;font-size:24px;margin-bottom:20px}.approval-status p{color:#555;font-size:16px;line-height:1.6;margin-bottom:15px}.rejection-reason{border:1px solid #fecaca;border-radius:8px;margin:20px 0;padding:20px;text-align:left}.rejection-reason h3{color:#dc2626;font-size:18px;margin-bottom:10px}.rejection-reason p{color:#7f1d1d;font-style:italic;margin:0}.cohort-info-small{background:#f8f9fa;border-radius:4px;font-size:12px;margin-top:8px;padding:8px}.student-item.active .cohort-info-small{background:#fff3}.cohort-info-small p{color:#495057;font-weight:600;margin:0 0 4px}.student-item.active .cohort-info-small p{color:#ffffffe6}.cohort-item-clickable,.cohort-item-small{align-items:center;border-left:3px solid #dee2e6;border-radius:4px;cursor:default;display:flex;font-size:11px;justify-content:space-between;margin:4px 0;padding:6px 8px;transition:all .2s ease}.cohort-item-clickable{cursor:pointer}.cohort-item-clickable:hover{background-color:#ffffff26;transform:translateX(2px)}.student-item.active .cohort-item-clickable:hover{background-color:#ffffff40}.cohort-item-clickable.cohort-selected{box-shadow:0 1px 3px #0000001a;font-weight:600}.cohort-name{color:#495057;font-weight:500}.student-item.active .cohort-name{color:#fffffff2!important}.cohort-item-clickable.cohort-selected .cohort-name{font-weight:600}.cohort-count{color:#6c757d;font-size:10px}.student-item.active .cohort-count{color:#fffc}.cohorts-section{margin-bottom:30px}.cohort-card{border:1px solid #dee2e6;transition:all .2s ease}.cohort-card:hover{box-shadow:0 4px 12px #0000001a}.cohort-header{border-bottom:1px solid #dee2e6}.cohort-header h4{color:#495057;font-size:18px;font-weight:600;margin:0}.cohort-stats .stat{color:#6c757d;font-size:14px}.cohort-description{color:#6c757d;line-height:1.4;margin:0 0 15px}.cohort-members{margin-bottom:15px}.cohort-members h5{color:#495057;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.members-list{display:flex;flex-direction:column;gap:10px}.member-item{background:#f8f9fa;border-left:3px solid #007bff;border-radius:6px;padding:12px}.member-info{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}.member-name{color:#495057;font-size:14px;font-weight:600}.member-username{color:#6c757d;font-size:12px}.member-bio{color:#6c757d;font-size:13px;line-height:1.4}.member-bio p{margin:0}.cohort-discord{border-top:1px solid #dee2e6;margin-top:15px;padding-top:15px}.cohort-discord a{background:#5865f2;border-radius:6px;color:#fff;display:inline-block;font-size:14px;padding:8px 16px;transition:background-color .2s ease}.cohort-discord a:hover{background:#4752c4}.cohort-leaderboard-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;margin-top:30px;padding:20px}.cohort-leaderboard-header h3{color:#333;margin:0}.cohort-leaderboard-loading{color:#666;font-style:italic;padding:16px 0}.cohort-leaderboard-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:20px 0 0;padding:0}.cohort-leaderboard-item{align-items:center;background:#fafafa;border:1px solid #e4e6eb;border-radius:6px;display:flex;justify-content:space-between;padding:12px 16px;transition:background .2s ease}.cohort-leaderboard-item.top{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea40}.cohort-leaderboard-item:hover{background:#f1f3ff;border-color:#667eea55}.cohort-leaderboard-item .rank{color:#667eea;font-weight:600;margin-right:16px;min-width:32px}.cohort-leaderboard-item .entry-details{flex:1 1}.cohort-leaderboard-item .entry-name{color:#333;font-weight:600}.cohort-leaderboard-item .entry-cohorts{color:#777;font-size:13px;margin-top:2px}.cohort-leaderboard-item .entry-stats{align-items:flex-end;display:flex;flex-direction:column;gap:4px;min-width:140px}.cohort-leaderboard-item .stat-rating{color:#222;font-weight:600}.cohort-leaderboard-item .stat-challenges{color:#777;font-size:12px}.cohort-leaderboard-footnote{color:#777;font-size:12px;margin-top:12px;text-align:right}.attendance-section{background:#fff;border:1px solid #e4e7ec;border-radius:8px;box-shadow:0 2px 8px #0000000f;margin-top:30px;padding:20px}.attendance-section-header{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.attendance-section-header h3{color:#333;margin:0}.attendance-list{gap:12px;list-style:none;margin:0;padding:0}.attendance-item,.attendance-list{display:flex;flex-direction:column}.attendance-item{background:#f9fbff;border:1px solid #eef1ff;border-radius:8px;gap:8px;padding:16px;transition:transform .2s ease,box-shadow .2s ease}.attendance-item:hover{box-shadow:0 6px 16px #667eea26;transform:translateY(-2px)}.attendance-item-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.attendance-datetime{align-items:center;color:#333;display:flex;font-weight:600;gap:8px}.attendance-date{font-size:.95rem}.attendance-separator{color:#9ca3af}.attendance-time{color:#4b5563;font-size:.95rem}.attendance-duration{color:#4f46e5;font-size:.9rem;font-weight:600}.attendance-topic{color:#1f2937;font-weight:600}.attendance-notes{color:#4b5563;line-height:1.5}.attendance-meta{color:#6b7280;font-size:.85rem}.attendance-empty,.attendance-error,.attendance-loading{border:1px dashed #d1d5db;color:#4b5563;padding:14px;text-align:center}@media (max-width:1100px){.dashboard-content{grid-template-columns:1fr}.students-list,.submissions-list{max-height:300px}}.schedule-section{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px}.schedule-section .section-header{margin-bottom:20px}.schedule-section .section-header h3{color:#333;margin:0 0 5px}.schedule-section .section-header p{color:#666;font-size:.9rem;margin:0}.week-header h4{color:#333;font-size:1.3rem;font-weight:600;margin:0}.ratings-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.rating-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.rating-header{border-bottom:1px solid #e0e0e0;margin-bottom:15px;padding-bottom:10px}.rating-header h4{color:#333;font-size:1.1rem;margin:0}.rating-week{color:#666;font-size:.9rem}.rating-overall{background:#fff;border-radius:6px;margin-bottom:15px;padding:10px}.rating-categories{grid-gap:8px;display:grid;gap:8px;margin-bottom:15px}.rating-comments{border-top:1px solid #e0e0e0;padding-top:15px}.rating-comments strong{color:#333;display:block;margin-bottom:8px}.rating-comments p{color:#666;font-style:italic;line-height:1.5;margin:0}.category-item{align-items:center;background:#fff;border-radius:4px;display:flex;font-size:.9rem;gap:12px;justify-content:space-between;padding:8px}.category-item .category-label{color:#666;flex-shrink:0}.category-item .star-rating{flex-shrink:0}.manager-portal{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.tutor-schedules-container{display:flex;flex-direction:column;gap:30px;margin-top:20px}.tutor-schedule-group{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.tutor-header{border-bottom:2px solid #667eea;margin-bottom:20px;padding-bottom:15px}.tutor-header h3{font-size:1.5rem;margin:0 0 5px}.tutor-email{font-size:.95rem;margin:0}.profile-section{margin-top:20px}.profile-display{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:25px}.profile-info{flex-direction:column;gap:15px}.info-row{border-bottom:1px solid #f0f0f0;padding:10px 0}.info-row:last-child{border-bottom:none}.info-row strong{color:#667eea;display:inline-block;margin-right:10px;min-width:120px}.notifications-section{padding:20px}.notifications-container{display:flex;flex-direction:column;gap:30px;margin-top:20px}.notification-section{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.notification-section-header{align-items:center;border-bottom:2px solid #667eea;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.notification-section-header h3{color:#333;font-size:1.3rem;font-weight:600;margin:0}.notification-count{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;min-width:30px;padding:6px 14px;text-align:center}.notifications-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.notification-item{background:#f8f9fa;border:1px solid #e0e0e0;border-left:4px solid #667eea;border-radius:8px;padding:20px;transition:all .3s ease}.notification-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.notification-tutor{border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column;gap:5px;margin-bottom:15px;padding-bottom:15px}.notification-tutor strong{color:#333;font-size:1.1rem;font-weight:600}.tutor-email{color:#666;font-size:.9rem}.tutor-contact{display:flex;flex-direction:column;gap:4px;margin-top:8px}.tutor-phone{color:#666;font-size:.9rem}.notification-cohort{border-bottom:1px solid #e0e0e0;color:#555;font-size:.95rem;margin-bottom:15px;padding-bottom:15px}.notification-cohort strong{color:#667eea;margin-right:8px}.notification-schedule{display:flex;flex-direction:column;gap:10px}.schedule-date,.schedule-day,.schedule-duration,.schedule-time{color:#555;font-size:.9rem;line-height:1.5}.schedule-date strong,.schedule-day strong,.schedule-duration strong,.schedule-time strong{color:#333;font-weight:600;margin-right:8px}.timezone-date,.timezone-time{color:#888;font-size:.85rem;margin-left:4px}.dues-section{padding:20px}.dues-container{margin-top:20px}.dues-summary{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:15px 20px}.dues-summary p{color:#333;font-size:1.1rem;margin:0}.dues-table-container{border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.dues-table{background:#fff;border-collapse:collapse;width:100%}.dues-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.dues-table th{border-bottom:2px solid #5a6fd8;font-size:.95rem;font-weight:600;padding:12px 15px;text-align:left}.dues-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s ease}.dues-table tbody tr:hover{background-color:#f8f9fa}.dues-table tbody tr.negative-balance{background-color:#fff5f5}.dues-table tbody tr.negative-balance:hover{background-color:#ffe5e5}.dues-table tbody tr.zero-balance{background-color:#fffbf0}.dues-table tbody tr.zero-balance:hover{background-color:#fff8e5}.dues-table td{color:#333;font-size:.9rem;padding:12px 15px}.dues-table td.balance-negative{color:#dc3545;font-weight:600}.dues-table td.balance-zero{color:#f59e0b;font-weight:600}.dues-table td.amount-due{color:#dc3545;font-weight:600}@media (max-width:768px){.dues-table-container{overflow-x:scroll}.dues-table{min-width:800px}.dues-table td,.dues-table th{font-size:.85rem;padding:8px 10px}}.user-management{margin:0 auto;max-width:1400px;padding:20px}.user-management-header{margin-bottom:30px}.user-management-header h1{color:#2c3e50;font-size:28px;margin-bottom:10px}.user-management-header p{color:#7f8c8d;font-size:16px}.filters-section{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.filters-row{align-items:end;display:flex;flex-wrap:wrap;gap:20px}.filter-group{display:flex;flex-direction:column;min-width:200px}.filter-group label{color:#2c3e50;font-size:14px;font-weight:600;margin-bottom:5px}.filter-group input,.filter-group select{border:1px solid #ddd;border-radius:5px;font-size:14px;padding:10px;transition:border-color .3s ease}.filter-group input:focus,.filter-group select:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.users-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:#f8f9fa}.users-table th{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:14px;font-weight:600;padding:15px;text-align:left}.users-table td{border-bottom:1px solid #e9ecef;padding:15px;vertical-align:top}.user-row:hover{background:#f8f9fa}.user-info{min-width:200px}.user-name{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:5px}.user-details{display:flex;flex-direction:column;gap:2px}.username{color:#7f8c8d;font-size:12px}.email{color:#3498db;font-size:12px}.status-approved{background:#d4edda;color:#155724}.status-pending{background:#fff3cd;color:#856404}.status-rejected{background:#f8d7da;color:#721c24}.status-no-record{background:#e2e3e5;color:#6c757d}.status-not-required{background:#d1ecf1;color:#0c5460}.status-active{background:#d4edda;color:#155724}.status-inactive{background:#e2e3e5;color:#6c757d}.status-expired{background:#f8d7da;color:#721c24}.status-cancelled{background:#f5c6cb;color:#721c24}.type-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.type-student{background:#e3f2fd;color:#1976d2}.type-tutor{background:#f3e5f5;color:#7b1fa2}.type-mentor{background:#e8f5e8;color:#388e3c}.type-parent{background:#fff3e0;color:#f57c00}.type-admin{background:#ffebee;color:#d32f2f}.plan-badge{border-radius:8px;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;margin-left:5px;padding:2px 6px;text-transform:uppercase}.plan-basic{background:#e3f2fd;color:#1976d2}.plan-premium{background:#f3e5f5;color:#7b1fa2}.plan-enterprise{background:#e8f5e8;color:#388e3c}.subscription-info{display:flex;flex-direction:column;gap:5px}.days-remaining{color:#6c757d;font-size:11px;font-style:italic}.cohort-info{display:flex;flex-wrap:wrap;gap:4px}.cohort-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block}.no-cohort{color:#6c757d;font-size:13px;font-style:italic}.subscription-details{margin-top:15px}.child-subscription{align-items:center;display:flex;gap:5px;margin-top:5px}.detail-item .warning{color:#e74c3c;font-weight:600}.view-details-btn{background:#3498db;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;transition:background-color .3s ease}.view-details-btn:hover{background:#2980b9}.pagination-container{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-top:20px;padding:20px}.pagination-info{color:#6c757d;font-size:14px}.pagination-controls{align-items:center;display:flex;gap:10px}.pagination-btn{background:#fff;border:1px solid #ddd;border-radius:5px;color:#2c3e50;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f8f9fa;border-color:#3498db;color:#3498db}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.page-numbers{display:flex;gap:5px}.page-number-btn{background:#fff;border:1px solid #ddd;border-radius:5px;color:#2c3e50;cursor:pointer;font-size:14px;font-weight:500;min-width:40px;padding:8px 12px;transition:all .2s}.page-number-btn:hover{background:#f8f9fa;border-color:#3498db}.page-number-btn.active{background:#3498db;border-color:#3498db;color:#fff}.modal{max-width:600px}.close-btn:hover{color:#2c3e50}.modal-content{padding:20px}.user-details-section{margin-bottom:30px}.user-details-section h3{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:18px;margin-bottom:15px;padding-bottom:5px}.detail-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item.full-width{grid-column:1/-1}.detail-item label{color:#7f8c8d;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-item span{color:#2c3e50;font-size:14px}.detail-item .active{color:#27ae60;font-weight:600}.detail-item .inactive{color:#e74c3c;font-weight:600}.rejection-reason{background:#fdf2f2;border-left:4px solid #e74c3c;border-radius:5px;font-style:italic;padding:10px}.no-children{color:#7f8c8d;font-style:italic;padding:20px;text-align:center}.children-list{gap:15px;margin-top:15px}.child-card{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:15px;transition:box-shadow .3s ease}.child-card:hover{box-shadow:0 2px 8px #0000001a}.child-info{flex:1 1}.child-name{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:5px}.child-details{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}.child-username{color:#7f8c8d;font-size:12px}.child-email{color:#3498db;font-size:12px}.child-status{align-items:center;display:flex;gap:10px}.status-indicator{border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.status-indicator.active{background:#d4edda;color:#155724}.status-indicator.inactive{background:#f8d7da;color:#721c24}.child-meta{color:#7f8c8d;font-size:11px;text-align:right}.child-date,.child-login{margin-bottom:2px}.subscription-details{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:15px}.no-subscription{color:#7f8c8d;font-style:italic;padding:20px;text-align:center}.subscription-plan{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.subscription-plan.basic{background:#e3f2fd;color:#1976d2}.subscription-plan.premium{background:#f3e5f5;color:#7b1fa2}.subscription-plan.enterprise{background:#e8f5e8;color:#388e3c}.subscription-status{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.subscription-status.active{background:#d4edda;color:#155724}.subscription-status.inactive{background:#e2e3e5;color:#6c757d}.subscription-status.expired{background:#f8d7da;color:#721c24}.subscription-status.cancelled{background:#fff3cd;color:#856404}.subscription-status.pending{background:#d1ecf1;color:#0c5460}.days-remaining{color:#27ae60;font-weight:600}.days-warning{color:#e74c3c;font-weight:600}.subscription-badge{border-radius:8px;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;margin-left:5px;padding:2px 6px;text-transform:uppercase}@media (max-width:768px){.filters-row{align-items:stretch;flex-direction:column}.filter-group{min-width:auto}.users-table-container{overflow-x:auto}.users-table{min-width:600px}.detail-grid{grid-template-columns:1fr}.modal{margin:10px;width:95%}}@media (max-width:480px){.user-management{padding:10px}.users-table td,.users-table th{padding:10px 8px}.user-name{font-size:14px}.email,.username{font-size:11px}}.status-badge.status-disabled{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.status-badge.status-enabled{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.action-buttons{align-items:flex-start;flex-direction:column}.disable-enable-buttons{display:flex;gap:5px}.disable-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:4px 8px;transition:background-color .2s}.disable-btn:hover{background:#c82333}.enable-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:4px 8px;transition:background-color .2s}.enable-btn:hover{background:#218838}@media (max-width:768px){.action-buttons{flex-direction:row;flex-wrap:wrap}.disable-enable-buttons{flex-direction:column;gap:3px}}.registration-code-management{margin:0 auto;max-width:1200px;padding:20px}.header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.header h2{color:#2c3e50;margin:0}.actions{display:flex;gap:10px}.btn{border-radius:5px;transition:all .3s ease}.btn-primary{background:#3498db}.btn-primary:hover{background:#2980b9}.btn-secondary{background:#95a5a6}.btn-secondary:hover{background:#7f8c8d}.btn-danger{background:#e74c3c}.btn-danger:hover{background:#c0392b}.btn-sm{font-size:12px;padding:5px 10px}.current-codes-section{margin-bottom:40px}.current-codes-section h3{color:#2c3e50;margin-bottom:20px}.codes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.code-card{background:#fff;border-left:4px solid #3498db;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.code-card.current{border-left-color:#27ae60}.code-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.code-header h4{color:#2c3e50;margin:0}.status-badge.current{background:#d5f4e6;color:#27ae60}.status-badge.expired{background:#fadbd8;color:#e74c3c}.status-badge.future{background:#d6eaf8;color:#3498db}.code-content{text-align:center}.code-value{color:#2c3e50;font-family:Courier New,monospace;font-size:24px;font-weight:700;letter-spacing:2px;margin-bottom:10px}.code-dates{color:#7f8c8d;font-size:14px;margin-bottom:15px}.code-actions{display:flex;gap:10px;justify-content:center}.all-codes-section h3{color:#2c3e50;margin-bottom:20px}.codes-table{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.codes-table table{border-collapse:collapse;width:100%}.codes-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:15px;text-align:left}.codes-table td{border-bottom:1px solid #e9ecef;padding:15px}.codes-table tr:hover{background:#f8f9fa}.code-cell{font-family:Courier New,monospace;font-weight:700;letter-spacing:1px}.modal{box-shadow:0 10px 30px #0000004d}.modal-header h3{color:#2c3e50}.close-btn{color:#7f8c8d}.close-btn:hover{color:#e74c3c}.form-group input,.form-group select{padding:10px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:10px;justify-content:flex-end}@media (max-width:768px){.header{align-items:stretch;flex-direction:column;gap:15px}.actions{justify-content:center}.codes-grid{grid-template-columns:1fr}.codes-table{overflow-x:auto}.codes-table table{min-width:600px}}.referral-code-management{margin:0 auto;max-width:1200px;padding:20px}.stat-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.stat-card h3{color:#666;font-weight:500}.stat-number{color:#333;font-size:24px;margin:0}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.referral-codes-table{border-collapse:collapse;width:100%}.referral-codes-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#333;font-weight:600;padding:15px;text-align:left}.referral-codes-table td{border-bottom:1px solid #e9ecef;padding:15px;vertical-align:middle}.referral-codes-table tr:hover{background:#f8f9fa}.code-text{background:#e3f2fd;border-radius:4px;color:#007bff;font-family:Courier New,monospace;font-size:14px;font-weight:700;padding:4px 8px}.unavailable-badge{background:#dc3545;border-radius:3px;color:#fff;font-size:10px;margin-left:8px;padding:2px 6px}.status-badge{border-radius:4px;padding:4px 8px}.btn-danger-small,.btn-secondary-small,.btn-warning-small{border:none;border-radius:4px;cursor:pointer;font-size:12px;padding:4px 8px;transition:all .2s}.btn-secondary-small{background:#6c757d;color:#fff}.btn-secondary-small:hover{background:#5a6268}.btn-warning-small{background:#ffc107;color:#212529}.btn-warning-small:hover{background:#e0a800}.btn-danger-small{background:#dc3545;color:#fff}.btn-danger-small:hover{background:#c82333}.modal{border-radius:8px;max-height:90vh}.close-btn{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.close-btn:hover{color:#333}.modal-form{padding:20px}.form-group input,.form-group textarea{border-radius:4px;padding:8px 12px;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.checkbox-label{align-items:center;cursor:pointer;display:flex!important}.checkbox-label input{margin-right:8px;width:auto!important}.modal-actions button{border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 16px}.modal-actions button[type=button]{background:#fff;color:#666}.modal-actions button[type=button]:hover{background:#f8f9fa}.modal-actions .btn-primary{background:#007bff;border-color:#007bff;color:#fff}.modal-actions .btn-primary:hover{background:#0056b3}.error-message{border:1px solid #f5c6cb;padding:12px}.btn-primary{background:#007bff;border-radius:4px;font-size:14px}.btn-primary:hover{background:#0056b3}@media (max-width:768px){.management-header{align-items:stretch;flex-direction:column;gap:15px}.stats-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.referral-codes-table{font-size:14px}.referral-codes-table td,.referral-codes-table th{padding:10px 8px}}.cohort-management{margin:0 auto;max-width:1200px;padding:20px}.cohort-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.cohort-management-header h1{color:#2c3e50;font-size:28px;margin-bottom:10px}.cohort-management-header p{color:#7f8c8d;font-size:16px;margin:0}.create-cohort-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:transform .2s,box-shadow .2s}.create-cohort-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.results-summary{color:#7f8c8d;font-size:14px;margin-bottom:15px}.cohorts-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.cohorts-table{border-collapse:collapse;width:100%}.cohorts-table thead{background:#f8f9fa}.cohorts-table th{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:14px;font-weight:600;padding:15px;text-align:left}.cohorts-table td{border-bottom:1px solid #e9ecef;padding:15px;vertical-align:top}.cohort-row:hover{background-color:#f8f9fa}.cohort-name{min-width:200px}.cohort-title{color:#2c3e50;font-size:16px;font-weight:600}.cohort-description{max-width:300px}.description-text{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#6c757d;display:-webkit-box;font-size:14px;line-height:1.4;max-height:60px;overflow:hidden;text-overflow:ellipsis}.cohort-count{min-width:120px;text-align:center}.count-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;margin-right:8px;padding:4px 8px}.tutors-count{background-color:#e3f2fd;color:#1976d2}.students-count{background-color:#f3e5f5;color:#7b1fa2}.assign-btn-small{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-left:5px;padding:4px 8px;transition:background .2s}.assign-btn-small:hover{background:#218838}.cohort-mentor{min-width:150px;text-align:center}.mentor-info{align-items:center;display:flex;gap:8px;justify-content:center}.mentor-name{color:#2c3e50;font-size:14px;font-weight:500}.remove-btn-small{background:#dc3545;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;line-height:1;padding:2px 6px;transition:background .2s}.remove-btn-small:hover{background:#c82333}.cohort-discord{text-align:center}.discord-link{color:#667eea;font-size:14px}.discord-link:hover{text-decoration:underline}.no-discord{color:#6c757d;font-size:14px;font-style:italic}.cohort-template{min-width:150px}.template-info{align-items:center;display:flex;gap:8px}.template-name-badge{background-color:#e3f2fd;border-radius:12px;color:#1976d2;font-size:12px;font-weight:600;padding:4px 12px}.template-assignment-modal{padding:10px 0}.template-assignment-modal p{color:#2c3e50;margin-bottom:20px}.template-select{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;width:100%}.template-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.no-templates-message{color:#868e96;font-size:13px;font-style:italic;margin-top:15px}.cohort-date{color:#6c757d;font-size:14px;white-space:nowrap}.action-buttons{align-items:center}.delete-btn,.edit-btn{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s}.edit-btn{background:#17a2b8}.edit-btn:hover{background:#138496}.delete-btn{background:#dc3545;color:#fff}.delete-btn:hover{background:#c82333}.cohort-leaderboard{min-width:140px;text-align:center}.leaderboard-badge{background:#eef2ff;border-radius:999px;color:#4338ca;display:inline-block;font-size:12px;font-weight:600;padding:4px 10px}.no-leaderboard{color:#9ca3af;font-size:12px}.leaderboard-select-wrapper{display:flex;flex-direction:column;gap:8px;margin-top:12px}.leaderboard-select-wrapper select{border:1px solid #d1d5db;border-radius:6px;padding:10px}.leaderboard-select-hint{color:#6b7280;font-size:12px;margin:0}.modal{border-radius:12px}.modal h3{color:#333;font-size:24px;margin:0 0 20px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;font-size:16px}.form-group select[multiple]{height:120px}.modal-actions{gap:15px}.cancel-btn{background:#f8f9fa;border:2px solid #e0e0e0;color:#666;transition:all .2s}.cancel-btn:hover{background:#e9ecef;border-color:#d0d0d0}.confirm-btn{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;font-size:16px;padding:12px 24px;transition:transform .2s,box-shadow .2s}.confirm-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.confirm-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.retry-btn{background:#667eea;border-radius:6px;margin-top:15px}.retry-btn:hover{background:#5a6fd8}@media (max-width:768px){.cohort-management-header{align-items:flex-start;flex-direction:column;gap:15px}.cohorts-grid{grid-template-columns:1fr}.cohort-header{align-items:flex-start;flex-direction:column;gap:15px}.cohort-actions{justify-content:flex-end;width:100%}.modal{margin:20px;padding:20px}.modal-actions{flex-direction:column}}.admin-profile{margin:0 auto;max-width:800px;padding:20px}.profile-header h2{color:#333;margin-bottom:10px}.profile-header p{color:#666;font-size:16px}.profile-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;justify-content:space-between;padding:30px}.profile-card,.profile-info{align-items:center;display:flex}.profile-info{gap:20px}.profile-avatar{flex-shrink:0}.avatar-circle{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:28px;font-weight:700;height:80px;justify-content:center;text-transform:uppercase;width:80px}.profile-details h3{color:#333;font-size:24px;margin:0 0 5px}.profile-details .username{color:#666;font-size:16px;margin:0 0 5px}.profile-details .user-type{color:#007bff;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0;text-transform:uppercase}.profile-actions{flex-shrink:0}.edit-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:background-color .2s}.edit-btn:hover{background:#0056b3}.save-btn{background:#28a745;font-weight:500;padding:12px 24px;transition:background-color .2s}.save-btn:hover:not(:disabled){background:#218838}.cancel-btn,.save-btn:disabled{background:#6c757d}.cancel-btn{border-radius:8px;font-size:16px;font-weight:500;padding:12px 24px;transition:background-color .2s}.cancel-btn:hover:not(:disabled){background:#5a6268}.cancel-btn:disabled{background:#adb5bd;cursor:not-allowed}.profile-form{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:30px}.form-section{margin-bottom:40px}.form-section:last-child{margin-bottom:0}.form-section h4{border-bottom:2px solid #e9ecef;color:#333;font-size:18px;margin:0 0 20px;padding-bottom:10px}.form-group input{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input.editable{border-color:#007bff}.form-group input.editable:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input.readonly{background:#f8f9fa;border-color:#e9ecef;color:#6c757d;cursor:not-allowed}.form-help{color:#666;display:block;font-size:12px;font-style:italic;margin-top:5px}.info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;padding:15px}.info-item label{color:#666;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.info-value{color:#333;font-size:16px;font-weight:500;margin-bottom:5px}.info-item small{color:#666;font-size:12px;font-style:italic}.admin-badge{background:#007bff;color:#fff;display:inline-block;padding:4px 12px}.admin-badge,.status-badge{border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.status-badge.active{border:1px solid #c3e6cb}.status-badge.inactive{border:1px solid #f5c6cb}.error,.loading{font-size:16px}@media (max-width:768px){.admin-profile{padding:15px}.profile-card{align-items:stretch;flex-direction:column;gap:20px}.profile-info{flex-direction:column;text-align:center}.profile-actions{align-self:center}.form-row,.info-grid{grid-template-columns:1fr}.edit-actions{flex-direction:column;width:100%}.edit-actions button{width:100%}}@media (max-width:480px){.profile-card,.profile-form{padding:20px}.avatar-circle{font-size:20px;height:60px;width:60px}.profile-details h3{font-size:20px}}.notification-settings{background:#f8f9fa;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin:0 auto;max-width:800px;padding:20px}.settings-header{border-bottom:2px solid #e9ecef;margin-bottom:30px;padding-bottom:20px;text-align:center}.settings-header h2{color:#2c3e50;font-size:28px;font-weight:700;margin-bottom:10px}.settings-header p{color:#6c757d;font-size:16px;margin:0}.settings-content{display:flex;flex-direction:column;gap:30px}.settings-section{background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 4px #0000000d;padding:25px}.settings-section h3{align-items:center;color:#2c3e50;display:flex;font-size:20px;font-weight:600;gap:10px;margin-bottom:20px}.frequency-options{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.frequency-option{align-items:flex-start;background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;padding:15px;transition:all .3s ease}.frequency-option:hover{background:#f0f4ff;border-color:#667eea}.frequency-option input[type=radio]{accent-color:#667eea;margin-right:12px;margin-top:2px}.frequency-option input[type=radio]:checked+.option-content{color:#667eea}.option-content{flex:1 1}.option-label{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:5px}.option-description{color:#6c757d;font-size:14px;line-height:1.4}.notification-group{display:flex;flex-direction:column;gap:15px}.notification-toggle{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;padding:15px;transition:all .3s ease}.notification-toggle:hover{background:#f0f4ff;border-color:#667eea}.notification-toggle input[type=checkbox]{accent-color:#667eea;margin-right:12px;transform:scale(1.2)}.toggle-label{color:#2c3e50;font-size:16px;font-weight:600}.notification-types{grid-gap:12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-left:30px;padding:15px}.notification-type{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;display:flex;padding:10px;transition:all .2s ease}.notification-type:hover{background:#f0f4ff;border-color:#667eea}.notification-type input[type=checkbox]{accent-color:#667eea;margin-right:10px}.notification-type span{color:#495057;font-size:14px;font-weight:500}.contact-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px}.contact-item{color:#495057;font-size:16px;margin-bottom:10px}.contact-item strong{color:#2c3e50;margin-right:10px}.contact-note{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:6px;color:#1976d2;font-size:14px;margin-top:15px;padding:12px}.settings-actions{border-top:2px solid #e9ecef;padding-top:20px;text-align:center}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 40px;transition:all .3s ease}.save-btn:hover:not(:disabled){box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.alert{border-left:4px solid;border-radius:8px;font-weight:500;margin-bottom:20px;padding:15px 20px}.alert-error{background:#f8d7da;border-left-color:#dc3545;color:#721c24}.alert-success{background:#d4edda;border-left-color:#28a745;color:#155724}.loading{color:#6c757d;font-size:18px}.error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#dc3545;font-size:18px;padding:40px;text-align:center}@media (max-width:768px){.notification-settings{margin:10px;padding:15px}.frequency-options,.notification-types{grid-template-columns:1fr}.notification-types{margin-left:0}.settings-section{padding:20px}.settings-header h2{font-size:24px}}@media (max-width:480px){.notification-settings{margin:5px;padding:10px}.settings-section{padding:15px}.frequency-option,.notification-toggle{padding:12px}}.template-management{margin:0 auto;max-width:1400px;padding:20px}.template-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px}.template-header h2{color:#2c3e50;font-size:28px;margin:0}.message{border-radius:6px;justify-content:space-between}.message.success{background-color:#d4edda}.message.error{background-color:#f8d7da}.message button{background:none;border:none;color:inherit;cursor:pointer;font-size:24px;margin-left:15px;padding:0}.error-message{background-color:#f8d7da;border-radius:6px}.templates-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.templates-table{border-collapse:collapse;width:100%}.templates-table thead{background:#f8f9fa}.templates-table th{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:14px;font-weight:600;padding:15px;text-align:left}.templates-table td{border-bottom:1px solid #e9ecef;padding:15px;vertical-align:middle}.templates-table tbody tr:hover{background-color:#f8f9fa}.template-name{color:#2c3e50;font-weight:600;min-width:200px}.template-description{color:#7f8c8d;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-block;font-size:12px;font-weight:600}.badge.active{background-color:#d4edda;color:#155724}.badge.inactive{background-color:#f8d7da;color:#721c24}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.btn-small{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s}.btn-preview{background-color:#e3f2fd;color:#1976d2}.btn-preview:hover{background-color:#bbdefb}.btn-edit{background-color:#fff3e0;color:#f57c00}.btn-edit:hover{background-color:#ffe0b2}.btn-assign{background-color:#f3e5f5;color:#7b1fa2}.btn-assign:hover{background-color:#e1bee7}.btn-danger{background-color:#ffebee;color:#c62828}.btn-danger:hover{background-color:#ffcdd2}.btn-primary{border-radius:8px;font-size:16px;padding:12px 24px;transition:transform .2s,box-shadow .2s}.btn-primary:hover{box-shadow:0 4px 12px #667eea66}.btn-secondary{background-color:#6c757d;font-size:14px;padding:10px 20px;transition:background-color .2s}.btn-secondary:hover{background-color:#5a6268}.modal-content{border-radius:10px;box-shadow:0 10px 40px #0003}.large-modal{max-width:900px}.modal-header{border-bottom:1px solid #e9ecef}.modal-header h2{color:#2c3e50;font-size:24px}.modal-close{border-radius:4px;color:#7f8c8d;font-size:28px;height:32px;transition:background-color .2s;width:32px}.modal-close:hover{background-color:#f8f9fa;color:#2c3e50}.modal-actions{border-top:1px solid #e9ecef;margin-top:25px;padding-top:20px}.template-form{display:flex;flex-direction:column;gap:25px}.form-group{gap:8px}.form-group input,.form-group select,.form-group textarea{font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .3s,box-shadow .3s}.form-row{grid-gap:15px;gap:15px}.checkbox-group label{display:flex}.checkbox-group input[type=checkbox]{cursor:pointer}.form-section{border-top:2px solid #e9ecef;margin-top:10px;padding-top:25px}.form-section h3{color:#2c3e50;font-size:20px;margin:0 0 10px}.section-help{color:#7f8c8d;font-size:13px;font-style:italic;margin:0 0 15px}.attribute-item,.question-item{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:15px;padding:20px}.attribute-header,.question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.attribute-number,.question-number{color:#667eea;font-size:14px;font-weight:600}.attribute-actions,.question-actions{display:flex;gap:5px}.btn-icon{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:12px;padding:4px 8px;transition:all .2s}.btn-icon:hover:not(:disabled){background-color:#f8f9fa;border-color:#667eea}.btn-icon:disabled{cursor:not-allowed;opacity:.5}.btn-icon.btn-danger:hover:not(:disabled){background-color:#ffebee;border-color:#c62828}.preview-container{display:flex;flex-direction:column;gap:20px}.preview-message{background-color:#e3f2fd;border-radius:6px;color:#1976d2;font-size:14px;margin:0;padding:12px 16px}.preview-container h3{color:#2c3e50;margin:10px 0}.preview-description{color:#7f8c8d;font-size:14px;margin:0 0 20px}.preview-attributes,.preview-questions{display:flex;flex-direction:column;gap:20px}.preview-attributes h4,.preview-questions h4{color:#2c3e50;font-size:18px;margin:0 0 15px}.preview-attribute-item,.preview-question-item{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:15px}.preview-attribute-header,.preview-question-header{margin-bottom:10px}.preview-attribute-header label,.preview-question-header label{color:#2c3e50;font-size:15px;font-weight:600}.required{color:#c62828;margin-left:4px}.preview-help-text{color:#1976d2;font-size:13px;font-style:italic;margin:8px 0}.preview-rating-scale{background-color:#fff3e0;border-radius:6px;color:#f57c00;font-size:14px;margin-bottom:20px;padding:12px 16px}.preview-rating-selector{display:flex;gap:10px;margin-top:10px}.rating-btn{background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;font-size:16px;font-weight:600;height:40px;opacity:.6;width:40px}.rating-btn,.rating-btn:disabled{cursor:not-allowed}.assign-form{display:flex;flex-direction:column;gap:20px}.assign-form p{color:#2c3e50;font-size:15px;margin:0}.warning{background-color:#ffebee;border-radius:6px;color:#c62828;font-size:13px;margin-top:10px;padding:10px}.leaderboard-management{background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000014;padding:24px}.leaderboard-management-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px}.leaderboard-management-header h1{color:#1f2937;font-size:24px;margin:0}.leaderboard-management-header p{color:#6b7280;margin:4px 0 0}.leaderboard-error{align-items:center;background:#fee2e2;border-radius:6px;color:#b91c1c;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.leaderboard-error button{background:#0000;border:none;color:inherit;cursor:pointer;font-weight:600}.leaderboard-empty,.leaderboard-loading{color:#6b7280;padding:24px;text-align:center}.leaderboard-empty h3{color:#1f2937;margin-bottom:8px}.leaderboard-table{border-collapse:collapse;width:100%}.leaderboard-table td,.leaderboard-table th{border-bottom:1px solid #e5e7eb;padding:14px 16px;text-align:left}.leaderboard-table th{background:#f9fafb;color:#374151;font-weight:600}.leaderboard-name{color:#111827;font-weight:600}.leaderboard-slug{color:#6b7280;font-size:12px;margin-top:4px}.status-pill{display:inline-block;font-size:12px;padding:4px 10px}.status-pill.active{background:#dcfce7;color:#166534}.status-pill.inactive{background:#fee2e2;color:#b91c1c}.leaderboard-actions{display:flex;flex-wrap:wrap;gap:8px}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);font-weight:600;padding:10px 16px;transition:transform .2s ease,box-shadow .2s ease}.btn-primary:hover{box-shadow:0 10px 20px #6366f133;transform:translateY(-1px)}.btn-outline{border:1px solid #d1d5db;color:#374151;padding:8px 12px}.btn-outline:hover{border-color:#6366f1;color:#6366f1}.btn-danger{background:#ef4444;padding:8px 12px}.btn-danger:hover{background:#dc2626}.leaderboard-type-modal{max-width:500px;width:100%}.leaderboard-type-modal .modal-body{display:flex;flex-direction:column;gap:16px}.checkbox-group{gap:8px;margin-top:8px}.checkbox-group label{align-items:center;display:inline-flex;gap:8px}.modal-close{background:#0000;color:#6b7280;font-size:18px}.modal-close:hover{color:#111827}@media (max-width:768px){.leaderboard-actions,.leaderboard-management-header{align-items:flex-start;flex-direction:column}}.admin-billing{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;margin-top:30px}.billing-header{align-items:center;display:flex;justify-content:space-between}.billing-header h2{color:#333;font-size:1.8rem;margin:0}.billing-header p{color:#667085;margin:4px 0 0}.billing-error,.billing-loading{background:#f9fafb;border:1px dashed #d0d5dd;border-radius:8px;color:#475467;padding:16px;text-align:center}.billing-error{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.billing-table-wrapper{border:1px solid #e4e7ec;border-radius:10px;box-shadow:0 2px 10px #0f172a14;overflow:auto}.billing-table{border-collapse:collapse;min-width:720px;width:100%}.billing-table thead{background:#f4f6fb}.billing-table td,.billing-table th{border-bottom:1px solid #eef1f6;font-size:.95rem;padding:16px 20px;text-align:left}.billing-table tbody tr{cursor:pointer;transition:background .2s ease}.billing-table tbody tr:hover{background:#f8fafc}.billing-table tbody tr.selected{background:#eef2ff}.billing-student{display:flex;flex-direction:column;gap:4px}.student-name{color:#1f2937;font-weight:600}.student-meta{color:#667085;font-size:.85rem}.credit-balance{color:#0f172a;font-weight:600}.credit-balance.negative{color:#dc2626}.status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.8rem;font-weight:600;letter-spacing:.02em;padding:6px 12px;text-transform:uppercase}.status-pill.paid{background:#ecfdf3;color:#027a48}.status-pill.pending{background:#fef3c7;color:#b45309}.status-pill.inline{margin-right:12px}.attendance-panel{background:#fff;border:1px solid #dde1ea;border-radius:10px;box-shadow:0 2px 12px #0f172a1a;padding:20px}.attendance-panel-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.attendance-panel-header h3{font-size:1.4rem;margin:0}.attendance-panel-header p{color:#667085;margin:4px 0 0}.attendance-summary{align-items:center;color:#475467;display:flex;gap:12px}.credit-summary{font-weight:600}.attendance-empty,.attendance-error,.attendance-loading{background:#f9fafb;border:1px dashed #d0d5dd;border-radius:8px;color:#475467;padding:16px}.attendance-error{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.attendance-log{grid-gap:14px;display:grid;gap:14px;list-style:none;margin:0;padding:0}.attendance-log li{background:#f8fafc;border:1px solid #eef1f6;border-radius:8px;box-shadow:inset 0 1px 0 #fff3;padding:14px}.log-header{align-items:center;color:#1f2937;display:flex;font-weight:600;gap:12px;justify-content:space-between}.log-topic{color:#0f172a;font-weight:600;margin-top:8px}.log-notes{color:#475467;line-height:1.45;margin-top:6px}.log-meta{color:#667085;font-size:.85rem;margin-top:8px}.modal-overlay{background:#0f172a8c;z-index:999}.modal{box-shadow:0 12px 40px #0f172a40;max-width:90%;padding:24px;width:360px}.modal h3{color:#1f2937;margin-bottom:16px;margin-top:0}.modal .form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.modal input[type=number]{border:1px solid #d0d5dd;border-radius:6px;font-size:1rem;padding:10px}.modal-actions{gap:12px}.btn-outline,.btn-primary,.btn-secondary{border-radius:999px;padding:8px 16px;transition:background .2s ease,color .2s ease,border-color .2s ease}.btn-primary{background:#4f46e5}.btn-primary:hover{background:#4338ca}.btn-secondary{background:#e4e7ec;color:#1f2937}.btn-secondary:hover{background:#d2d6dd}.btn-outline{background:#fff;border:1px solid #4f46e5;border-radius:999px;color:#4f46e5;font-weight:600;padding:6px 14px}.btn-outline:hover{background:#4f46e5}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:1024px){.attendance-panel{padding:16px}}.challenge-category-management{margin:0 auto;max-width:1400px;padding:20px}.management-header h2{color:#333;margin:0}.categories-container{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-top:20px}.main-categories-section,.sub-categories-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.main-categories-section h3,.sub-categories-section h3{align-items:center;color:#333;display:flex;gap:10px;margin-bottom:20px;margin-top:0}.main-category-name{color:#666;font-size:.9em;font-weight:400}.sub-categories-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.sub-categories-header h3{margin:0}.categories-list{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.category-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;padding:15px;transition:all .2s}.category-card:hover{border-color:#4caf50;box-shadow:0 4px 8px #0000001a}.category-card.selected{background:#f1f8f4;border-color:#4caf50}.category-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.category-header h4{color:#333;flex:1 1;margin:0}.category-actions{display:flex;gap:5px}.btn-icon{background:none;border:none;cursor:pointer;font-size:16px;opacity:.7;padding:5px;transition:opacity .2s}.btn-icon:hover{opacity:1}.category-description{color:#666;font-size:.9em;margin:10px 0;min-height:40px}.category-stats{color:#888;display:flex;font-size:.85em;gap:15px;margin:10px 0}.category-status{margin-top:10px}.status-badge{border-radius:12px;display:inline-block;font-size:.8em;font-weight:500;padding:4px 12px}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.empty-state{color:#999;font-style:italic}.error-message,.message{border-radius:4px;padding:12px 20px}.error-message{background:#f8d7da;color:#721c24}.btn{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-primary{background:#4caf50}.btn-primary:hover{background:#45a049}.btn-danger:disabled{background:#ccc;cursor:not-allowed}.modal-content{max-width:500px;padding:30px}.modal-content h3{color:#333;margin-bottom:20px;margin-top:0}.form-group input[type=text],.form-group textarea{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:8px 12px;width:100%}.form-group input[type=text]:disabled{background:#f5f5f5;color:#999}.form-group input[type=checkbox]{margin-right:5px}.modal-actions{margin-top:30px}.warning-text{color:#dc3545;display:block;font-weight:500;margin-top:10px}.loading{color:#666;padding:40px;text-align:center}@media (max-width:1024px){.categories-container{grid-template-columns:1fr}}.admin-dashboard{margin:0 auto;max-width:1200px;padding:20px}.admin-dashboard h1{color:#2c3e50;margin-bottom:30px;text-align:center}.retry-btn{background:#3498db;border:none;border-radius:5px;color:#fff;cursor:pointer;margin-top:10px;padding:10px 20px}.retry-btn:hover{background:#2980b9}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:#fff;border-left:4px solid;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px;text-align:center}.stat-card.pending{border-left-color:#f39c12}.stat-card.approved{border-left-color:#27ae60}.stat-card.subscribed{border-left-color:#9b59b6}.stat-card.rejected{border-left-color:#e74c3c}.stat-card.total{border-left-color:#3498db}.stat-card h3{color:#7f8c8d;font-size:14px;letter-spacing:1px;margin:0 0 10px;text-transform:uppercase}.stat-number{color:#2c3e50;font-size:36px;font-weight:700}.tabs{border-bottom:2px solid #ecf0f1;display:flex;margin-bottom:20px}.tab{color:#7f8c8d;font-size:16px;padding:15px 25px}.tab:hover{background:#f8f9fa;color:#3498db}.tab.active{border-bottom-color:#3498db;color:#3498db;font-weight:600}.tab-content{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.tab-content h2{color:#2c3e50;margin-bottom:20px}.empty-state{color:#7f8c8d;font-size:18px;padding:40px}.approvals-list,.tutors-list{grid-gap:20px;display:grid;gap:20px}.approval-card,.tutor-card{align-items:flex-start;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:20px;transition:all .3s ease}.approval-card:hover,.tutor-card:hover{box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.approval-info,.tutor-info{flex:1 1}.approval-info h3,.tutor-info h3{color:#2c3e50;font-size:20px;margin:0 0 5px}.approval-info .email,.tutor-info .email{color:#7f8c8d;margin:5px 0}.approval-info .username,.tutor-info .username{color:#95a5a6;font-size:14px;margin:5px 0}.approval-info .bio,.tutor-info .bio{color:#34495e;line-height:1.5;margin:10px 0}.approval-info .date,.tutor-info .date{color:#95a5a6;font-size:12px;margin:10px 0 0}.approval-actions,.tutor-actions{display:flex;flex-direction:column;gap:10px;margin-left:20px}.approve-btn,.create-approval-btn{background:#27ae60;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:background .3s ease}.approve-btn:hover,.create-approval-btn:hover{background:#229954}.reject-btn{background:#e74c3c;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:background .3s ease}.reject-btn:hover{background:#c0392b}.modal{background:#fff;border-radius:10px;max-height:80vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.modal h3{color:#2c3e50;margin-bottom:15px}.modal p{color:#7f8c8d;line-height:1.5;margin-bottom:20px}.modal textarea{border:1px solid #ddd;border-radius:5px;font-family:inherit;font-size:14px;margin-bottom:15px;min-height:80px;padding:10px;resize:vertical;width:100%}.modal textarea:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.cancel-btn{background:#95a5a6;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.cancel-btn:hover{background:#7f8c8d}.confirm-btn{background:#27ae60;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.confirm-btn:hover{background:#229954}.reject-confirm-btn{background:#e74c3c;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.reject-confirm-btn:hover:not(:disabled){background:#c0392b}.reject-confirm-btn:disabled{background:#bdc3c7;cursor:not-allowed}@media (max-width:768px){.admin-dashboard{padding:10px}.stats-grid{grid-template-columns:repeat(2,1fr)}.approval-card,.tutor-card{flex-direction:column}.approval-actions,.tutor-actions{flex-direction:row;margin-left:0;margin-top:15px}.modal{margin:20px;padding:20px}}.stats-section{margin-bottom:40px}.stats-section h2{color:#2c3e50;font-size:24px;padding-bottom:10px}.main-tabs,.stats-section h2{border-bottom:2px solid #ecf0f1;margin-bottom:20px}.main-tabs{display:flex}.main-tab{background:none;border:none;border-bottom:3px solid #0000;color:#7f8c8d;cursor:pointer;font-size:16px;font-weight:600;padding:15px 30px;transition:all .3s ease}.main-tab:hover{background:#f8f9fa;color:#2c3e50}.main-tab.active{background:#f8f9fa;border-bottom-color:#3498db;color:#3498db}.mentor-card{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:15px;padding:20px;transition:box-shadow .3s ease}.mentor-card:hover{box-shadow:0 4px 8px #00000026}.mentor-info h3{color:#2c3e50;font-size:18px;margin:0 0 5px}.mentor-info .username{color:#7f8c8d;font-size:14px;margin:0 0 5px}.mentor-info .email{color:#3498db;font-size:14px;margin:0 0 5px}.mentor-info .bio{color:#555;font-size:14px;font-style:italic;margin:0 0 5px}.mentor-info .date{color:#95a5a6;font-size:12px;margin:0}.mentor-actions{display:flex;gap:10px}.mentors-list{display:flex;flex-direction:column;gap:15px}.student-card{align-items:center;border-radius:10px;display:flex;justify-content:space-between;margin-bottom:15px;transition:box-shadow .3s ease}.student-info h3{color:#2c3e50;font-size:18px;margin:0 0 5px}.student-info .username{color:#7f8c8d;font-size:14px;margin:0 0 5px}.student-info .email{color:#3498db;font-size:14px;margin:0 0 5px}.student-info .bio{color:#555;font-size:14px;font-style:italic;margin:0 0 5px}.student-info .date{color:#95a5a6;font-size:12px;margin:0}.students-list{display:flex;flex-direction:column;gap:15px}@media (max-width:768px){.main-tabs{flex-direction:column}.main-tab{font-size:14px;padding:12px 20px}.mentor-card{align-items:flex-start;flex-direction:column;gap:15px}.mentor-actions{justify-content:center;width:100%}.stats-section h2{font-size:20px}}.parent-profile{margin:0 auto;max-width:800px;padding:20px}.profile-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.profile-header h1{color:#333;margin:0}.profile-actions{display:flex;gap:10px}.btn-cancel,.btn-edit,.btn-save{border:none;border-radius:5px;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.btn-save:hover:not(:disabled){background:#218838}.btn-save:disabled{background:#6c757d;cursor:not-allowed}.btn-cancel:hover:not(:disabled){background:#5a6268}.edit-actions{display:flex;gap:10px}.profile-content{display:flex;flex-direction:column;gap:30px}.profile-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px}.profile-section h2{border-bottom:1px solid #e9ecef;color:#333;font-size:1.3em;margin:0 0 20px;padding-bottom:10px}.form-group input,.form-group textarea{border-radius:5px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{box-shadow:0 0 0 2px #667eea33}.form-group input.readonly,.form-group textarea.readonly{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-group input.editable,.form-group textarea.editable{background:#fff;color:#333}.password-hint{color:#6c757d;font-size:13px;margin-top:10px}@media (max-width:768px){.parent-profile{padding:15px}.profile-header{align-items:flex-start;flex-direction:column;gap:15px}.form-grid{gap:15px;grid-template-columns:1fr}.edit-actions{flex-direction:column;width:100%}.btn-cancel,.btn-edit,.btn-save{width:100%}}.parent-cohorts{margin:0 auto;max-width:1200px;padding:20px}.page-header{margin-bottom:30px;text-align:center}.page-header h1{color:#333;margin-bottom:10px}.page-header p{color:#666;font-size:16px}.error,.loading{font-size:18px;padding:40px;text-align:center}.error{color:#e74c3c}.no-cohorts{background:#f8f9fa;border-radius:8px;margin:20px 0;padding:60px 20px;text-align:center}.no-cohorts h3{color:#333;margin-bottom:10px}.no-cohorts p{color:#666}.cohorts-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.cohort-card{border:1px solid #e1e5e9;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:box-shadow .3s ease}.cohort-card:hover{box-shadow:0 4px 8px #00000026}.cohort-header{border-bottom:1px solid #e1e5e9;padding-bottom:15px}.cohort-header h3{font-size:20px}.cohort-stats{display:flex;gap:15px}.stat{color:#666;font-size:14px}.stat strong{color:#007bff;font-weight:600}.cohort-description{background:#f8f9fa;border-radius:6px;margin-bottom:20px;padding:15px}.cohort-description p{color:#555}.cohort-section{margin-bottom:20px}.cohort-section:last-child{margin-bottom:0}.cohort-section h4{color:#333;font-size:16px;font-weight:600;margin-bottom:10px}.children-list{display:flex;flex-direction:column;gap:8px}.child-item{align-items:center;background:#e3f2fd;border-left:3px solid #2196f3;border-radius:6px;display:flex;gap:10px;padding:8px 12px}.child-name{color:#333;font-weight:500}.child-username{color:#666;font-size:14px}.person-list{display:flex;flex-direction:column;gap:10px}.person-item{align-items:center;background:#f8f9fa;border:1px solid #e1e5e9;border-radius:6px;display:flex;justify-content:space-between;padding:12px 15px}.person-info{display:flex;flex-direction:column;gap:2px}.person-name{color:#333;font-weight:500}.person-email{color:#666;font-size:14px}.btn-primary-small{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px;transition:background-color .3s ease}.btn-primary-small:hover{background:#0056b3}.discord-link{background:#7289da;border-radius:6px;color:#fff;display:inline-block;font-weight:500;padding:10px 15px;text-decoration:none;transition:background-color .3s ease}.discord-link:hover{background:#5a6fc7}.modal-content{border-radius:8px;box-shadow:0 10px 25px #0000004d;max-height:80vh}.modal-header{border-bottom:1px solid #e1e5e9;padding:20px}.modal-header h3{color:#333;margin:0}.modal-close{font-size:24px;line-height:1}.modal-body{padding:20px}.person-info p{color:#555;margin:8px 0}.bio-section{margin-top:20px}.bio-section h4{color:#333;font-size:16px;margin-bottom:10px}.bio-content{background:#f8f9fa;border-left:3px solid #007bff;border-radius:6px;padding:15px}.bio-content p{color:#555;line-height:1.6;margin:0}.no-bio{color:#999!important;font-style:italic}.modal-footer{border-top:1px solid #e1e5e9;padding:20px;text-align:right}.btn-secondary{border-radius:4px;transition:background-color .3s ease}.btn-secondary:hover{background:#545b62}@media (max-width:768px){.parent-cohorts{padding:15px}.cohorts-grid{grid-template-columns:1fr}.cohort-header{align-items:flex-start;flex-direction:column;gap:10px}.cohort-stats{align-self:flex-start}.person-item{align-items:flex-start;flex-direction:column;gap:10px}.modal-content{margin:10px;width:95%}}.student-management{margin:0 auto;max-width:1200px;padding:20px}.management-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.management-header h1{color:#333;margin:0}.btn-add{background:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:background .2s}.btn-add:hover{background:#218838}.limit-reached-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;font-weight:500;padding:12px 24px}.limit-reached-message,.message{border-radius:5px;font-size:14px}.message{word-wrap:break-word;line-height:1.4;margin-bottom:20px;max-width:100%}.message-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message-error{background:#f8d7da;border:1px solid #f5c6cb;border-left:4px solid #dc3545;color:#721c24}.add-student-form{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:25px}.add-student-form h2{border-bottom:1px solid #e9ecef;color:#333;font-size:1.3em;margin:0 0 20px;padding-bottom:10px}.form-grid{grid-template-columns:1fr 1fr;margin-bottom:20px}.form-group label{margin-bottom:5px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:5px;font-size:14px;padding:10px 12px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.form-actions{gap:10px}.btn-cancel,.btn-save{border:none;border-radius:5px;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.btn-save{background:#28a745;color:#fff}.btn-save:hover{background:#218838}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.students-list h2{color:#333;font-size:1.3em;margin:0 0 20px}.no-students{background:#f8f9fa;border-radius:8px;color:#6c757d;padding:40px;text-align:center}.students-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.student-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;transition:box-shadow .2s}.student-card:hover{box-shadow:0 4px 8px #00000026}.student-info h3{color:#333;font-size:1.2em;margin:0 0 15px}.student-info p{color:#666;font-size:14px;margin:5px 0}.student-info p strong{color:#333}.student-actions{border-top:1px solid #e9ecef;display:flex;gap:10px;margin-top:15px;padding-top:15px}.btn-delete,.btn-edit{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-edit{background:#667eea;color:#fff}.btn-edit:hover{background:#5a6fd8}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}@media (max-width:768px){.student-management{padding:15px}.management-header{align-items:flex-start;flex-direction:column;gap:15px}.form-grid{gap:15px;grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-save{width:100%}.students-grid{grid-template-columns:1fr}.student-actions{flex-direction:column}.btn-delete,.btn-edit{width:100%}}.subscriptions-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px}.subscriptions-container{margin:0 auto;max-width:1200px}.subscriptions-header{margin-bottom:40px;position:relative;text-align:center}.back-button{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;left:0;padding:10px 20px;position:absolute;top:0;transition:background .3s ease}.back-button:hover{background:#5a6268}.subscriptions-header h1{color:#333;font-size:2.5rem;font-weight:700;margin-bottom:10px}.subscriptions-header p{color:#666;font-size:1.1rem;margin:0}.subscription-plans{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:40px}.subscription-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;flex-direction:column;padding:30px;position:relative;transition:all .3s ease}.subscription-card:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.subscription-card.popular{border-color:#007bff;transform:scale(1.05)}.subscription-card.current{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-color:#28a745}.popular-badge{background:linear-gradient(135deg,#007bff,#0056b3);left:50%;padding:8px 20px;transform:translateX(-50%)}.current-badge,.popular-badge{border-radius:20px;color:#fff;font-size:12px;font-weight:600;letter-spacing:.5px;position:absolute;text-transform:uppercase;top:-10px}.current-badge{background:linear-gradient(135deg,#28a745,#1e7e34);padding:8px 16px;right:20px}.plan-header{margin-bottom:30px;text-align:center}.plan-header h3{color:#333;font-size:1.8rem;font-weight:600}.plan-header h3,.plan-price{margin-bottom:15px}.price{color:#007bff;font-size:3rem;font-weight:700}.period{color:#666;font-size:1rem;margin-left:5px}.plan-description{color:#666;font-size:1rem;line-height:1.5;margin:0}.plan-features{flex-grow:1;margin-bottom:30px}.plan-features ul{list-style:none;margin:0;padding:0}.plan-features li{align-items:center;color:#555;display:flex;font-size:.95rem;padding:8px 0}.checkmark{color:#28a745;font-size:1.1rem;font-weight:700;margin-right:12px}.plan-actions{margin-top:auto}.select-plan-button{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:15px 20px;transition:all .3s ease;width:100%}.select-plan-button:hover{background:#0056b3;transform:translateY(-2px)}.select-plan-button.selected{background:#28a745}.select-plan-button.selected:hover{background:#1e7e34}.current-plan-button{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:not-allowed;font-size:1rem;font-weight:600;opacity:.7;padding:15px 20px;width:100%}.subscription-summary{background:#fff;border:2px solid #007bff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin-bottom:30px;padding:30px;text-align:center}.summary-content h3{color:#333;font-size:1.5rem;margin-bottom:15px}.summary-content p{color:#666;font-size:1.1rem;margin-bottom:25px}.summary-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.subscribe-button{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;box-shadow:0 4px 15px #28a7454d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .3s ease}.subscribe-button:hover{box-shadow:0 6px 20px #28a74566;transform:translateY(-2px)}.change-plan-button{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .3s ease}.change-plan-button:hover{background:#5a6268;transform:translateY(-2px)}.subscription-footer{color:#666;line-height:1.6;text-align:center}.subscription-footer p{margin:10px 0}.subscription-footer .terms{color:#999;font-size:.9rem}@media (max-width:768px){.subscriptions-page{padding:10px}.subscriptions-header h1{font-size:2rem}.subscription-plans{gap:20px;grid-template-columns:1fr}.subscription-card.popular{transform:none}.summary-actions{align-items:center;flex-direction:column}.change-plan-button,.subscribe-button{max-width:300px;width:100%}}.tutor-portal{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.header-content>div{flex:1 1;min-width:300px}.btn-profile{background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.btn-profile:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.tutor-skill-pill-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.tutor-skill-pill{background:#fff3;border:1px solid #ffffff4d;border-radius:999px;color:#fff;font-size:.85rem;font-weight:500;padding:6px 12px}.tutor-skill-pill-empty{background:#ffffff1a;border:1px dashed #ffffff4d;color:#ffffffd9}.loading-container{color:#666;padding:60px 20px}.message-close{top:50%;transform:translateY(-50%)}.portal-tabs{flex-wrap:wrap;overflow-x:auto}.tab{min-width:120px;transition:all .3s ease;white-space:nowrap}.tab.active{border-bottom:3px solid #667eea}.section-header{margin-bottom:30px}.empty-state p{margin:0 0 30px}.challenge-card{border:1px solid #e9ecef;transition:all .3s ease}.challenge-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.challenge-header h3{margin:0 0 10px}.badge{border-radius:20px;font-size:.8rem;letter-spacing:.5px;padding:4px 12px}.challenge-meta{grid-gap:15px;background:#f8f9fa;border-radius:8px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);padding:15px}.meta-item{text-align:center}.meta-label{color:#6c757d;display:block;font-weight:500;margin-bottom:5px}.meta-value{display:block;font-size:1.2rem}.challenge-description p{font-size:.9rem}.submissions-section{max-width:1200px}.submissions-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.submission-card{border:1px solid #e9ecef;transition:all .3s ease}.submission-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.submission-header h3{font-size:1.3rem;margin:0 0 10px}.badge.status{border-radius:20px;font-size:.8rem;font-weight:500;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.badge.status.submitted{background:#fff3cd;color:#856404}.badge.status.under_review{background:#cce5ff;color:#06c}.badge.status.graded{background:#d4edda;color:#155724}.badge.status.returned{background:#f8d7da;color:#721c24}.badge.student{background:#e3f2fd;border-radius:20px;color:#1976d2;font-size:.8rem;font-weight:500;padding:4px 12px}.submission-meta{background:#f8f9fa;border-radius:8px;padding:10px}.submission-description p{font-size:.9rem}.large-modal{max-height:90vh;max-width:800px}.submission-details{border-bottom:2px solid #e9ecef;margin-bottom:30px;padding-bottom:20px}.submission-details h3{color:#333;font-size:1.4rem;margin:0 0 20px}.submission-content{background:#f8f9fa;border-radius:8px;max-height:300px;overflow-y:auto;padding:15px}.content-section{margin-bottom:20px}.content-section:last-child{margin-bottom:0}.content-section h4{color:#495057;font-size:1rem;font-weight:600;margin:0 0 8px}.content-section p{color:#666;font-size:.9rem;line-height:1.5;margin:0}.review-form{margin-top:20px}.review-form h3{color:#333;font-size:1.3rem;margin:0 0 20px}.review-form h4{color:#495057;font-size:1.1rem;font-weight:600;margin:20px 0 15px}.btn-outline,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:8px;padding:10px 20px;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary:hover{transform:translateY(-1px)}.btn-outline{border:2px solid #667eea}.add-challenge-section{margin:0 auto;max-width:800px}.challenge-form-container{background:#f8f9fa;border-radius:12px;padding:30px}.challenge-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:.9rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e9ecef;border-radius:8px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #667eea1a}.form-group textarea{min-height:80px}.checkbox-group{flex-direction:row}.checkbox-group input[type=checkbox]{margin:0;width:auto}.form-actions{border-top:1px solid #dee2e6;margin-top:20px;padding-top:20px}.modal-overlay{background:#000000b3;padding:20px}.modal-content{border-radius:15px;box-shadow:0 20px 60px #0000004d;width:100%}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px 15px 0 0;color:#fff}.modal-header h2{font-size:1.3rem;font-weight:600}.modal-close{border-radius:50%;color:#fff;font-size:2rem;transition:background .3s ease}.modal-close:hover{background:#fff3}.badge.cohort{border-radius:12px;font-weight:500;padding:4px 8px}.badge.cohort,.meta-label{font-size:12px}.meta-value{font-size:16px}@media (max-width:768px){.tutor-portal{padding:10px}.portal-header{padding:20px}.portal-header h1{font-size:2rem}.portal-content{padding:20px}.challenges-grid,.submissions-grid{gap:20px;grid-template-columns:1fr}.challenge-meta{gap:10px;grid-template-columns:1fr}.form-row{gap:15px;grid-template-columns:1fr}.challenge-form-container{padding:20px}.section-header{align-items:stretch;gap:15px}.challenge-actions,.form-actions,.section-header,.submission-actions{flex-direction:column}.modal-content{margin:10px;max-height:95vh}.modal-header{padding:15px 20px}.modal-body{padding:20px}}@media (max-width:480px){.portal-header h1{font-size:1.8rem}.challenge-card{padding:20px}.challenge-form-container{padding:15px}.modal-header h2{font-size:1.1rem}}.feedback-combined-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-top:20px}.mentor-feedback-card{border-left:4px solid #667eea}.feedback-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;gap:20px;padding:25px;position:relative;transition:all .3s ease}.feedback-type-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:6px 12px;position:absolute;right:15px;text-transform:uppercase;top:15px;z-index:1}.feedback-type-badge.mentor-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.feedback-type-badge.student-badge{background:linear-gradient(135deg,#ffc107,#ff9800);color:#fff}.feedback-card:hover{border-color:#667eea;box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.feedback-card-header{align-items:flex-start;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding-bottom:15px}.feedback-mentor-info{flex:1 1}.feedback-mentor-info h3{color:#333;font-size:1.4rem;font-weight:600;margin:0 0 8px}.feedback-cohort{background:#e3f2fd;border-radius:20px;color:#1976d2;display:inline-block;font-size:.85rem;font-weight:500;padding:4px 12px}.feedback-overall-rating{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;min-width:80px;padding:15px 20px;text-align:center}.rating-value{font-size:2rem;font-weight:700;line-height:1;margin-bottom:5px}.rating-label{font-size:.85rem;font-weight:500;opacity:.9}.feedback-ratings-grid{grid-gap:15px;background:#f8f9fa;border-radius:8px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);padding:15px}.rating-item{align-items:center;display:flex;flex-direction:column;text-align:center}.rating-label-small{color:#6c757d;font-size:.75rem;font-weight:500;margin-bottom:8px;text-align:center}.rating-value-small{color:#333;font-size:1.3rem;font-weight:600}.feedback-section{background:#fafafa;border-left:4px solid #667eea;border-radius:8px;padding:15px}.feedback-section h4{align-items:center;color:#333;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0 0 10px}.feedback-section p{color:#555;font-size:.95rem;line-height:1.6;margin:0}.feedback-strengths{background:#f0fff4;border-left-color:#28a745}.feedback-improvements{background:#fffbf0;border-left-color:#ffc107}.feedback-footer{align-items:center;border-top:1px solid #e9ecef;display:flex;gap:15px;justify-content:space-between;margin-top:auto;padding-top:15px}.feedback-date{color:#6c757d;font-size:.85rem;font-style:italic}.feedback-preview{background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:15px}.preview-text{color:#555;font-size:.9rem;line-height:1.5}.preview-text strong{color:#333}.feedback-details-container{display:flex;flex-direction:column;gap:25px}.feedback-details-header{align-items:flex-start;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;padding-bottom:20px}.feedback-details-mentor h3{color:#333;font-size:1.6rem;font-weight:600;margin:0 0 8px}.feedback-overall-rating-large{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;min-width:120px;padding:20px 30px;text-align:center}.rating-value-large{font-size:3rem;font-weight:700;line-height:1;margin-bottom:8px}.rating-label-large{font-size:1rem;font-weight:500;opacity:.9}.feedback-details-ratings{background:#f8f9fa;border-radius:8px;padding:20px}.feedback-details-ratings h4{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 20px}.details-ratings-grid{display:flex;flex-direction:column;gap:20px}.details-rating-item{background:#fff;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:15px}.details-rating-label{color:#333;font-size:1rem;font-weight:600}.details-rating-value{color:#667eea;font-size:1.5rem;font-weight:700}.details-rating-bar{background:#e9ecef;border-radius:6px;height:12px;overflow:hidden;width:100%}.details-rating-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:6px;height:100%;transition:width .3s ease}.feedback-section-details{background:#fafafa;border-left:4px solid #667eea;border-radius:8px;padding:20px}.feedback-section-details h4{align-items:center;color:#333;display:flex;font-size:1.2rem;font-weight:600;gap:10px;margin:0 0 15px}.feedback-section-details p{color:#555;font-size:1rem;line-height:1.8;margin:0;white-space:pre-wrap}.feedback-section-details p.no-content{color:#868e96;font-style:italic;opacity:.8}.feedback-strengths-details{background:#f0fff4;border-left-color:#28a745}.feedback-improvements-details{background:#fffbf0;border-left-color:#ffc107}.feedback-details-footer{border-top:1px solid #e9ecef;padding-top:15px}.feedback-details-date{color:#6c757d;font-size:.9rem}.feedback-details-date strong{color:#495057}.updated-indicator{color:#868e96;font-size:.85rem;font-style:italic}.student-rating-display{background:linear-gradient(135deg,#ffc107,#ff9800);border-radius:12px;color:#fff;min-width:100px;padding:15px 20px;text-align:center}.star-rating-value{font-size:1.5rem;letter-spacing:2px;line-height:1;margin-bottom:8px}.student-rating-display .rating-label{font-size:.9rem;font-weight:500;opacity:.9}.student-rating-display-large{background:linear-gradient(135deg,#ffc107,#ff9800);border-radius:12px;color:#fff;min-width:150px;padding:20px 30px;text-align:center}.star-rating-value-large{font-size:2.5rem;letter-spacing:3px;line-height:1;margin-bottom:10px}.student-rating-display-large .rating-label-large{font-size:1.1rem;font-weight:500;opacity:.9}.profile-modal{max-width:800px!important}.profile-form{display:flex;flex-direction:column;gap:30px}.form-section{border-bottom:1px solid #e0e0e0;padding-bottom:25px}.form-section:last-child{border-bottom:none}.form-section h3{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 20px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1/-1}.form-group label{color:#555;font-size:.95rem}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:.95rem;padding:10px 12px;transition:border-color .3s ease,box-shadow .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{min-height:100px;resize:vertical}.form-hint{color:#6b7280;font-size:.85rem;margin-top:6px}.profile-modal .modal-actions{border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px}.attendance-manager{display:flex;flex-direction:column;gap:20px}.attendance-header{display:flex;flex-direction:column;gap:10px}.attendance-header h2{font-size:24px;font-weight:600;margin:0}.attendance-header p{color:#6b7280;margin:0}.attendance-alert{border-radius:6px;font-weight:500;max-width:420px;padding:10px 16px}.attendance-alert.success{background:#ecfdf5;border:1px solid #34d399;color:#047857}.attendance-alert.error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c}.attendance-card{background:#fff;border-radius:12px;box-shadow:0 8px 20px #0f172a14;display:flex;flex-direction:column;gap:24px;padding:24px}.attendance-form-header{align-items:center;display:flex;justify-content:space-between}.attendance-form,.attendance-form .form-row{display:flex;flex-direction:column;gap:16px}.attendance-form .form-row{flex-direction:row;flex-wrap:wrap;gap:20px}.attendance-form .form-row .form-group{flex:1 1;min-width:180px}.attendance-form .form-group{display:flex;flex-direction:column;gap:6px}.attendance-form label{color:#111827;font-weight:600}.attendance-form input,.attendance-form select,.attendance-form textarea{border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease}.attendance-form input:focus,.attendance-form select:focus,.attendance-form textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.attendance-form textarea{min-height:80px;resize:vertical}.attendance-form-actions{align-items:center;display:flex;gap:12px}.attendance-form .btn-primary{background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 16px;transition:background .2s ease}.attendance-form .btn-primary:disabled{background:#a5b4fc;cursor:not-allowed}.attendance-form .btn-link{background:none;border:none;color:#4f46e5;cursor:pointer;font-weight:600;padding:0}.student-checkbox-grid{grid-gap:8px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));max-height:220px;overflow-y:auto;padding:12px}.student-checkbox{align-items:center;color:#1f2937;display:flex;font-size:14px;gap:8px}.student-checkbox input{margin:0}.attendance-records{display:flex;flex-direction:column;gap:16px}.records-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between}.records-header h3{font-size:20px;font-weight:600;margin:0}.record-subtitle{color:#6b7280;font-size:14px}.attendance-table{background:#f8fafc;border-collapse:collapse;border-radius:8px;font-size:14px;overflow:hidden;width:100%}.attendance-table td,.attendance-table th{border-bottom:1px solid #e5e7eb;padding:12px 14px;text-align:left;vertical-align:top}.attendance-table th{background:#eef2ff;color:#312e81;font-weight:600}.attendee-list{display:flex;flex-wrap:wrap;gap:6px}.attendee-pill{align-items:center;background:#eef2ff;border-radius:999px;color:#3730a3;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px}.attendee-empty{color:#9ca3af;font-style:italic}.record-actions{display:flex;gap:8px}.record-actions .btn-danger,.record-actions .btn-outline{border:1px solid #0000;border-radius:6px;cursor:pointer;font-weight:600;padding:6px 12px;transition:background .2s ease,color .2s ease,border-color .2s ease}.record-actions .btn-outline{background:#fff;border-color:#d1d5db;color:#1f2937}.record-actions .btn-outline:hover{border-color:#4f46e5;color:#4f46e5}.record-actions .btn-danger{background:#fee2e2;color:#b91c1c}.record-actions .btn-danger:hover{background:#fca5a5;color:#7f1d1d}.attendance-blank-state,.attendance-loading{text-align:center}.attendance-blank-state,.attendance-empty,.attendance-loading{background:#f9fafb;border:1px dashed #d1d5db;border-radius:8px;color:#4b5563;padding:18px}@media (max-width:768px){.attendance-form .form-row,.record-actions{flex-direction:column}}.mentor-portal{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.portal-container{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0003;margin:0 auto;max-width:1200px;overflow:hidden}.portal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center}.portal-header h1{font-size:2.5rem;font-weight:600;margin:0 0 10px}.portal-header p{font-size:1.1rem;margin:0;opacity:.9}.message{align-items:center;border-radius:8px;display:flex;font-weight:500;margin:20px;padding:15px 20px;position:relative}.message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.message-icon{font-size:1.2rem;margin-right:10px}.message-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.5rem;opacity:.7;position:absolute;right:15px}.message-close:hover{opacity:1}.portal-tabs{background:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#6c757d;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:15px 20px;transition:all .2s}.tab:hover{background:#e9ecef;color:#495057}.tab.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.portal-content{padding:30px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px}.section-actions{display:flex;gap:12px}.section-actions .btn-primary{white-space:nowrap}.section-header h2{color:#333;font-size:1.8rem;font-weight:600;margin:0}.btn-primary{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:background .2s}.btn-primary:hover{background:#5a6fd8}.btn-secondary{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:background .2s}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:background .2s}.btn-danger:hover{background:#c82333}.btn-outline{background:#0000;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .2s}.btn-outline:hover{background:#667eea;color:#fff}.loading-container{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:400px;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:20px;width:40px}.empty-state{color:#6c757d;padding:60px 20px}.empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h3{color:#495057;font-size:1.5rem;margin:0 0 10px}.empty-state p{font-size:1.1rem;line-height:1.5;margin:0 0 25px}.challenges-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.challenge-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:25px;transition:transform .2s,box-shadow .2s}.challenge-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.challenge-card.big-challenge{border-left:4px solid #667eea}.challenge-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.challenge-header h3{color:#333;flex:1 1;font-size:1.3rem;font-weight:600;margin:0}.challenge-badges{display:flex;flex-wrap:wrap;gap:8px}.badge{border-radius:12px;font-size:.75rem;font-weight:500;padding:4px 8px;text-transform:uppercase}.badge.category{background:#e3f2fd;color:#1976d2}.badge.status{background:#fff3cd;color:#856404}.badge.student{background:#d1ecf1;color:#0c5460}.badge.cohort{background:#e3f2fd;color:#1976d2}.challenge-meta{border-bottom:1px solid #f0f0f0;display:flex;gap:20px;margin-bottom:15px;padding-bottom:15px}.meta-item{align-items:center;display:flex;flex-direction:column}.meta-label{color:#666;font-size:.8rem;margin-bottom:4px}.meta-value{color:#333;font-size:1.1rem;font-weight:600}.challenge-description{margin-bottom:20px}.challenge-description p{color:#666;line-height:1.5;margin:0}.challenge-actions{display:flex;flex-wrap:wrap;gap:10px}.submissions-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.submission-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:25px;transition:transform .2s,box-shadow .2s}.submission-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.submission-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.submission-header h3{color:#333;flex:1 1;font-size:1.2rem;font-weight:600;margin:0}.submission-badges{display:flex;flex-wrap:wrap;gap:8px}.submission-meta{border-bottom:1px solid #f0f0f0;display:flex;gap:20px;margin-bottom:15px;padding-bottom:15px}.submission-description{margin-bottom:20px}.submission-description p{color:#666;line-height:1.5;margin:0 0 10px}.submission-actions{display:flex;flex-wrap:wrap;gap:10px}.challenge-form-container{margin:0 auto;max-width:600px}.challenge-form{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group label{color:#333;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.checkbox-group{align-items:center;display:flex;gap:10px}.checkbox-group label{cursor:pointer;font-weight:400;margin:0}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.modal-content.large-modal{max-width:800px}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 25px}.modal-header h2{color:#333;font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;width:30px}.modal-close:hover{color:#333}.modal-body{padding:25px}.cohorts-section{padding:20px}.cohorts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.cohort-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px;transition:transform .2s,box-shadow .2s}.cohort-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.cohort-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.cohort-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.cohort-badges{display:flex;gap:8px}.cohort-meta{border-bottom:1px solid #f0f0f0;display:flex;gap:20px;padding-bottom:15px}.cohort-description,.cohort-meta{margin-bottom:15px}.cohort-description p{color:#666;line-height:1.5;margin:0}.cohort-discord{background:#f8f9fa;border-radius:6px;margin-bottom:15px;padding:10px}.cohort-discord strong{color:#333;margin-right:8px}.cohort-discord a{color:#1976d2;font-weight:500;text-decoration:none}.cohort-discord a:hover{text-decoration:underline}.cohort-mentors,.cohort-students{margin-bottom:15px}.cohort-mentors .section-header,.cohort-students .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.cohort-mentors .section-header strong,.cohort-students .section-header strong{color:#333;font-size:14px}.cohort-mentors ul,.cohort-students ul{list-style:none;margin:0;padding-left:0}.cohort-mentors li,.cohort-students li{border-bottom:1px solid #f0f0f0;color:#666;font-size:14px;padding:6px 0}.cohort-mentors li:last-child,.cohort-students li:last-child{border-bottom:none}.cohort-mentors p,.cohort-students p{color:#999;font-size:14px;font-style:italic;margin:0}.submission-controls{align-items:center;display:flex;gap:12px}.cohort-filter{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-size:14px;min-width:150px;padding:8px 12px}.cohort-filter:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.submission-cohorts{background:#f8f9fa;border-radius:6px;margin-bottom:15px;padding:10px}.submission-cohorts strong{color:#333;font-size:14px;margin-right:8px}.cohort-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.cohort-tag{background:#e3f2fd;color:#1976d2}.badge.category,.cohort-tag{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px}.badge.category{background:#f3e5f5;color:#7b1fa2}.tutors-section{padding:20px}.tutors-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-top:20px}.tutor-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:25px;transition:transform .2s,box-shadow .2s}.tutor-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.tutor-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.tutor-header h3{color:#333;flex:1 1;font-size:1.3rem;font-weight:600;margin:0}.tutor-badges{display:flex;flex-wrap:wrap;gap:8px}.badge.tutor{background:#e8f5e8;color:#2e7d32}.badge.rated{background:#fff3e0;color:#f57c00}.tutor-meta{border-bottom:1px solid #f0f0f0;display:flex;gap:20px;padding-bottom:15px}.tutor-bio,.tutor-meta{margin-bottom:15px}.tutor-bio p{color:#666;line-height:1.5;margin:0}.tutor-cohorts{margin-bottom:15px}.tutor-cohorts .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.tutor-cohorts .section-header strong{color:#333;font-size:14px}.tutor-cohorts ul{list-style:none;margin:0;padding-left:0}.cohort-item{border-bottom:1px solid #f0f0f0;color:#666;display:flex;flex-direction:column;font-size:14px;gap:4px;padding:8px 0}.cohort-item:last-child{border-bottom:none}.cohort-description{color:#999;font-size:12px;font-style:italic}.tutor-ratings{margin-bottom:20px}.tutor-ratings .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.tutor-ratings .section-header strong{color:#333;font-size:14px}.ratings-list{display:flex;flex-direction:column;gap:10px}.rating-item{background:#f8f9fa;border-left:3px solid #667eea;border-radius:8px;padding:12px}.rating-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.rating-cohort{color:#333;font-size:14px;font-weight:600}.rating-score{background:#667eea;border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 8px}.rating-aspects{color:#666;display:flex;flex-wrap:wrap;font-size:12px;gap:12px}.rating-aspects span{background:#e9ecef;border-radius:8px;padding:2px 6px}.tutor-actions{display:flex;flex-wrap:wrap;gap:10px}.tutor-rating-form{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.tutor-rating-form h3{border-bottom:2px solid #667eea;color:#333;font-size:1.2rem;margin-bottom:20px;padding-bottom:10px}@media (max-width:768px){.mentor-portal{padding:10px}.portal-header{padding:20px}.portal-header h1{font-size:2rem}.portal-content{padding:20px}.portal-tabs{flex-direction:column}.tab{border-bottom:1px solid #dee2e6;border-right:none}.tab.active{border-bottom-color:#dee2e6;border-left:3px solid #667eea}.challenges-grid,.cohorts-grid,.form-row,.submissions-grid,.tutors-grid{grid-template-columns:1fr}.section-header{align-items:stretch;flex-direction:column;gap:15px}.submission-controls{gap:10px}.challenge-actions,.submission-actions,.submission-controls{flex-direction:column}.modal-content{margin:20px;width:95%}}.students-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.students-table{border-collapse:collapse;width:100%}.students-table thead{background:#f8f9fa}.students-table th{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:14px;font-weight:600;padding:15px;text-align:left}.students-table td{border-bottom:1px solid #e9ecef;padding:15px;vertical-align:middle}.student-row:hover{background:#f8f9fa}.btn-small{font-size:13px;padding:6px 12px}.tutors-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.tutors-table{border-collapse:collapse;width:100%}.tutors-table thead{background:#f8f9fa}.tutors-table th{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:14px;font-weight:600;padding:15px;text-align:left}.tutors-table td{border-bottom:1px solid #e9ecef;padding:15px;vertical-align:middle}.tutor-row:hover{background:#f8f9fa}.badge.rated{background:#d4edda;color:#155724}.badge.not-rated,.badge.rated{border-radius:4px;font-size:12px;font-weight:500;padding:4px 8px}.badge.not-rated{background:#fff3cd;color:#856404}.cohort-names{display:flex;flex-wrap:wrap;gap:4px}.cohort-badge{background:#e3f2fd;border-radius:4px;color:#1976d2;font-size:12px;font-weight:500;padding:4px 8px;white-space:nowrap}.no-cohorts{color:#7f8c8d;font-size:13px;font-style:italic}.schedule-section{padding:20px}.weekly-schedules-container{display:flex;flex-direction:column;gap:30px;margin-top:20px}.week-section{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:20px}.week-header{align-items:center;border-bottom:2px solid #667eea;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.week-header h3{color:#333;font-size:1.3rem;font-weight:600;margin:0}.week-date-range{color:#666;font-size:.95rem;font-weight:500}.schedules-list-week{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.schedule-item-week{background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:15px;transition:box-shadow .2s ease}.schedule-item-week:hover{box-shadow:0 4px 8px #0000001a}.schedule-item-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between}.schedule-cohort-name{color:#667eea;font-size:1rem;font-weight:600}.schedule-date{color:#666;font-size:.9rem;text-align:right;white-space:nowrap}.schedule-time{align-items:center;display:flex;gap:8px;margin-top:5px}.schedule-time .time{color:#333;font-size:1.1rem;font-weight:600}.schedule-time .duration{color:#666;font-size:.85rem}.schedule-day-name{color:#888;font-size:.9rem;font-style:italic}.schedule-meeting-url{border-top:1px solid #e0e0e0;margin-top:10px;padding-top:10px}.meeting-link{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;box-shadow:0 2px 4px #667eea4d;color:#fff;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:all .3s ease}.meeting-link:hover{background:linear-gradient(135deg,#5568d3,#653a91);box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.meeting-link:active{transform:translateY(0)}.no-schedules-week{background:#fff;border:1px dashed #e0e0e0;border-radius:8px;color:#999;font-style:italic;padding:30px 20px;text-align:center}.empty-state{color:#666;padding:40px 20px;text-align:center}.empty-state .hint{color:#999;font-size:.9rem;margin-top:10px}.admin-login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.admin-login-container:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='10' height='10' patternUnits='userSpaceOnUse'%3E%3Cpath d='M10 0H0v10' fill='none' stroke='rgba(255,255,255,0.1)' stroke-width='.5'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.admin-login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:450px;padding:40px;position:relative;width:100%;z-index:1}.admin-login-header{margin-bottom:30px;text-align:center}.admin-logo{margin-bottom:20px}.admin-logo-img{height:60px;width:auto}.admin-login-header h1{color:#2c3e50;font-size:28px;font-weight:700;margin:0 0 10px;text-shadow:0 2px 4px #0000001a}.admin-login-header p{color:#7f8c8d;font-size:16px;font-weight:400;margin:0}.admin-login-form{margin-bottom:30px}.form-group{margin-bottom:20px}.form-group label{color:#2c3e50;display:block;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.form-input{background:#fffc;border:2px solid #e9ecef;border-radius:10px;box-sizing:border-box;font-size:16px;padding:15px 20px;transition:all .3s ease;width:100%}.form-input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input::placeholder{color:#adb5bd;font-style:italic}.admin-login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;letter-spacing:1px;padding:15px 20px;text-transform:uppercase;transition:all .3s ease;width:100%}.admin-login-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.admin-login-btn:active{transform:translateY(0)}.admin-login-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;margin-bottom:20px;padding:12px 16px;text-align:center}.admin-login-footer{border-top:1px solid #e9ecef;padding-top:20px;text-align:center}.back-to-login{color:#667eea;font-weight:500;text-decoration:none;transition:color .3s ease}.back-to-login:hover{color:#5a6fd8;text-decoration:underline}.security-notice{background:#667eea1a;border:1px solid #667eea33;border-radius:8px;margin-top:20px;padding:15px}.security-notice p{color:#5a6fd8;font-size:12px;font-weight:500;margin:5px 0}@media (max-width:480px){.admin-login-container{padding:10px}.admin-login-card{padding:30px 20px}.admin-login-header h1{font-size:24px}.admin-login-btn,.form-input{font-size:14px;padding:12px 16px}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.admin-login-card{animation:slideInUp .6s ease-out}.admin-login-btn:disabled{position:relative}.admin-login-btn:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;bottom:0;content:"";height:16px;left:0;margin:auto;position:absolute;right:0;top:0;width:16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}body,html{height:100%;width:100%}input::-ms-clear,input::-ms-reveal{display:none}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0);font-family:sans-serif;line-height:1.15}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:initial;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{font-weight:500;margin-bottom:.5em;margin-top:0}p{margin-bottom:1em;margin-top:0}abbr[data-original-title],abbr[title]{border-bottom:0;cursor:help;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}address{font-style:normal;line-height:inherit;margin-bottom:1em}input[type=number],input[type=password],input[type=text],textarea{-webkit-appearance:none}dl,ol,ul{margin-bottom:1em;margin-top:0}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}code,kbd,pre,samp{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;font-size:1em}pre{margin-bottom:1em;margin-top:0;overflow:auto}figure{margin:0 0 1em}img{border-style:none;vertical-align:middle}[role=button],a,area,button,input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{caption-side:bottom;padding-bottom:.3em;padding-top:.75em;text-align:left}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-size:inherit;line-height:inherit;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{border:0;margin:0;min-width:0;padding:0}legend{color:inherit;display:block;font-size:1.5em;line-height:inherit;margin-bottom:.5em;max-width:100%;padding:0;white-space:normal;width:100%}progress{vertical-align:initial}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:none;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{background-color:#feffe6;padding:.2em}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.d87cde3e.css.map*/