.plan-choice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}.plan-choice-modal{background:#fff;border:1px solid #e2e8f0;border-radius:20px;max-width:480px;width:100%;padding:2rem 2rem 1.75rem;text-align:center;box-shadow:0 8px 32px #0000001f;max-height:calc(100vh - 2rem);overflow-y:auto;margin:auto}.plan-choice-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:1.5rem}.plan-choice-logo-icon{width:36px;height:36px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #4299e14d;color:#fff;flex-shrink:0}.plan-choice-logo-text{font-size:1.25rem;font-weight:600;color:#2d3748;letter-spacing:-.3px}.plan-choice-title{font-size:1.45rem;font-weight:700;color:#1a202c;margin:0 0 .5rem;line-height:1.25}.plan-choice-subtitle{font-size:.9rem;color:#718096;margin:0 0 1.5rem;line-height:1.55}.plan-choice-highlight{color:#4299e1;font-weight:600}.trial-features{background:#f7faff;border:1px solid #bee3f8;border-radius:14px;padding:1rem 1.25rem;margin-bottom:1.5rem;text-align:left}.trial-features-title{font-size:.75rem;font-weight:700;color:#4299e1;text-transform:uppercase;letter-spacing:.07em;margin:0 0 .75rem}.trial-feature-item{display:flex;align-items:center;gap:.625rem;font-size:.875rem;color:#4a5568;margin-bottom:.45rem}.trial-feature-item:last-child{margin-bottom:0}.trial-feature-check{color:#4299e1;flex-shrink:0}.plan-choice-actions{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem}.btn-trial{width:100%;padding:.8rem 1.5rem;background:#4299e1;color:#fff;font-weight:700;font-size:.9375rem;border:none;border-radius:12px;cursor:pointer;transition:opacity .15s,transform .1s;box-shadow:0 4px 14px #4299e159}.btn-trial:hover{opacity:.92;transform:translateY(-1px)}.btn-pay-now{width:100%;padding:.8rem 1.5rem;background:transparent;color:#4299e1;font-weight:600;font-size:.9rem;border:1.5px solid #bee3f8;border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s}.btn-pay-now:hover{background:#ebf8ff;border-color:#4299e1}.plan-choice-note{font-size:.75rem;color:#a0aec0;line-height:1.45;margin:0}@media (max-width: 520px){.plan-choice-modal{padding:1.5rem 1.25rem 1.25rem;border-radius:16px}.plan-choice-title{font-size:1.25rem}}.paywall-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1001;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}.paywall-modal{background:#fff;border:1px solid #e2e8f0;border-radius:20px;max-width:900px;width:100%;max-height:calc(100vh - 2rem);overflow-y:auto;padding:2rem 2rem 1.75rem;box-shadow:0 8px 32px #0000001f;scrollbar-width:none;margin:auto}.paywall-modal::-webkit-scrollbar{display:none}.paywall-back{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:#4299e1;font-size:.875rem;font-weight:600;cursor:pointer;padding:.25rem 0;margin-bottom:.75rem;transition:opacity .15s}.paywall-back:hover{opacity:.75}.paywall-close{position:absolute;top:1rem;right:1rem;width:2rem;height:2rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:50%;color:#718096;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.paywall-close:hover{background:#edf2f7}.paywall-header{text-align:center;margin-bottom:1.75rem}.paywall-badge{display:inline-block;background:#ebf8ff;border:1px solid #bee3f8;color:#4299e1;padding:.3rem .9rem;border-radius:999px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;margin-bottom:.75rem}.paywall-title{font-size:1.55rem;font-weight:700;color:#1a202c;margin:0 0 .5rem;line-height:1.2}.paywall-subtitle{font-size:.9rem;color:#718096;max-width:500px;margin:0 auto;line-height:1.55}.paywall-plans{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem}@media (max-width: 720px){.paywall-plans{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.paywall-plans{grid-template-columns:1fr}}.plan-card{background:#f7fafc;border:1.5px solid #e2e8f0;border-radius:16px;padding:1.25rem 1rem;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;position:relative;display:flex;flex-direction:column}.plan-card:hover{border-color:#4299e1;background:#ebf8ff;transform:translateY(-2px)}.plan-card.selected{border-color:#4299e1;background:#ebf8ff;box-shadow:0 0 0 3px #4299e126}.plan-card.popular-plan{border-color:#4299e1;background:#fff}.plan-popular-badge{position:absolute;top:-.7rem;left:50%;transform:translate(-50%);background:#4299e1;color:#fff;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.2rem .75rem;border-radius:999px;white-space:nowrap;box-shadow:0 2px 8px #4299e159}.plan-name{font-size:.95rem;font-weight:700;color:#2d3748;margin-bottom:.25rem}.plan-price{font-size:1.7rem;font-weight:800;color:#4299e1;line-height:1;margin-bottom:.2rem}.plan-price-cents{font-size:1rem;font-weight:600;vertical-align:super}.plan-interval{font-size:.75rem;color:#a0aec0;margin-bottom:1rem}.plan-features-list{list-style:none;padding:0;margin:0 0 1.25rem;flex:1}.plan-feature{display:flex;align-items:flex-start;gap:.5rem;font-size:.78rem;color:#4a5568;margin-bottom:.4rem;line-height:1.35}.plan-feature-icon{color:#4299e1;flex-shrink:0;margin-top:1px}.btn-select-plan{width:100%;padding:.625rem .75rem;background:#4299e1;color:#fff;font-size:.82rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:opacity .15s,transform .1s;margin-top:auto;box-shadow:0 3px 10px #4299e14d}.btn-select-plan:hover{opacity:.9;transform:translateY(-1px)}.btn-select-plan:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 480px){.paywall-modal{padding:1.5rem 1rem;border-radius:16px}.paywall-title{font-size:1.25rem}}.landing-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1)}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:20px 60px;flex-wrap:wrap;gap:20px}.landing-header .logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#1a1a1a;letter-spacing:.5px}.landing-header .logo-icon{width:40px;height:40px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.landing-header nav{display:flex;gap:40px;align-items:center;flex-wrap:wrap}.landing-header nav a{text-decoration:none;color:#1a1a1a;font-size:16px;font-weight:600;transition:color .3s}.landing-header nav a:hover{color:#4299e1}.signup-btn{background:#fff;padding:10px 24px;border-radius:25px;border:1px solid #e0e0e0;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit}.signup-btn:hover{background:#4299e1;color:#fff;border-color:#4299e1}.hero{display:flex;justify-content:space-between;align-items:center;padding:80px 60px;max-width:1400px;margin:0 auto;gap:80px}.hero-content{flex:1;max-width:550px}.hero h1{font-size:72px;font-weight:700;line-height:1.1;margin-bottom:30px;color:#1a1a1a}.hero h1 .italic{font-style:italic;font-weight:400}.hero h1 .italic.bold{font-weight:700}.hero-text{font-size:16px;line-height:1.6;color:#4a4a4a;margin-bottom:40px}.cta-buttons{display:flex;gap:16px;margin-bottom:50px}.get-started-btn{background:#1a1a1a;color:#fff;padding:14px 32px;border-radius:25px;border:none;font-size:15px;cursor:pointer;transition:all .3s;font-weight:500;font-family:inherit}.get-started-btn:hover{background:#333;transform:translateY(-2px)}.get-started-btn.large{padding:18px 48px;font-size:18px}.prototype-btn{background:#fff;color:#1a1a1a;padding:14px 32px;border-radius:25px;border:1px solid #e0e0e0;font-size:15px;cursor:pointer;transition:all .3s;font-weight:500;font-family:inherit}.prototype-btn:hover{background:#f5f5f5;transform:translateY(-2px)}.app-badges{display:flex;flex-direction:column;gap:8px}.badges-text{display:flex;flex-direction:column;gap:2px}.available-on{font-size:15px;font-weight:600;color:#1a1a1a}.available-on span{color:#4a90e2}.coming-soon{font-size:13px;color:#888}.store-badges{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.badge{display:flex;align-items:center;gap:8px;background:#fff;border-radius:12px;padding:10px 16px;cursor:pointer;transition:transform .3s,box-shadow .3s;box-shadow:0 2px 8px #0000001a;font-size:14px;font-weight:600;color:#1a1a1a;border:1px solid #e8e8e8}.badge svg{width:22px;height:22px;flex-shrink:0}.badge:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.web-badge{border-color:#4a90e2;color:#4a90e2}.disabled-badge{opacity:.45;cursor:not-allowed;position:relative}.disabled-badge:hover{transform:none;box-shadow:0 2px 8px #0000001a}.disabled-badge span{color:#555}.hero-image{flex:1;display:flex;justify-content:center;align-items:center}.mockup-container{width:100%;max-width:600px;aspect-ratio:16/10;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #00000014;transition:transform .3s,box-shadow .3s;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.mockup-container:hover{transform:translateY(-10px);box-shadow:0 15px 40px #0000001f}.mockup-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-image-asset{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.features-section{padding:80px 60px;max-width:1200px;margin:0 auto;text-align:center}.features-section h2{font-size:48px;margin-bottom:60px;color:#1a1a1a}.what-section{background:#fff;padding:80px 40px;margin:40px 0}.what-section .container{max-width:1200px;margin:0 auto}.what-section h2{font-size:42px;font-weight:700;margin-bottom:30px;color:#1a1a1a;text-align:center}.what-description{font-size:18px;line-height:1.8;color:#444;max-width:900px;margin:0 auto 60px;text-align:center}.feature-icon-box{width:60px;height:60px;background:#4299e1;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;flex-shrink:0}.feature-icon-box svg{width:32px;height:32px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.feature-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:40px 30px;transition:all .3s ease;box-shadow:0 4px 16px #0000000a}.feature-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #00000014}.feature-icon{font-size:48px;margin-bottom:20px}.feature-card h3{font-size:22px;margin-bottom:15px;color:#2d3748}.feature-card p{font-size:15px;color:#718096;line-height:1.6}.cta-section{padding:80px 60px;text-align:center;background:#ffffff80}.cta-section h2{font-size:48px;margin-bottom:20px;color:#1a1a1a}.cta-section p{font-size:18px;color:#4a4a4a;margin-bottom:40px}.landing-footer{padding:40px 60px;border-top:1px solid rgba(0,0,0,.1)}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.footer-content p{color:#718096;font-size:14px}@media (max-width: 1024px){.hero{flex-direction:column;padding:60px 40px;gap:50px}.hero h1{font-size:56px}.landing-header{padding:20px 40px}}.hero-image-mobile{display:none}@media (max-width: 768px){.landing-header{padding:20px 30px}.landing-header nav{gap:20px;width:100%;justify-content:center}.hero{padding:40px 30px}.hero h1{font-size:42px}.cta-buttons{flex-direction:column;width:100%}.get-started-btn,.prototype-btn{width:100%}.features-section,.cta-section,.landing-footer{padding:60px 30px}.features-section h2,.cta-section h2{font-size:36px}.hero-image-mobile{display:block;width:100%;margin:20px 0}.hero-image-mobile .mockup-container{max-width:100%}.hero-image{display:none}}@media (max-width: 480px){.hero h1{font-size:36px}.features-grid{grid-template-columns:1fr}}.signup-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);display:flex;align-items:center;justify-content:center;padding:20px}.signup-container{width:100%;max-width:1200px}.signup-header{margin-bottom:40px;display:flex;justify-content:center}.signup-header .logo{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;color:#2d3748;cursor:pointer;transition:opacity .3s}.signup-header .logo:hover{opacity:.8}.signup-header .logo-icon{width:48px;height:48px;background:#4299e1;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #4299e14d}.signup-content{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.signup-info h1{font-size:48px;font-weight:700;color:#2d3748;margin-bottom:20px;line-height:1.2}.signup-info p{font-size:18px;color:#718096;margin-bottom:40px;line-height:1.6}.features-list{display:flex;flex-direction:column;gap:20px}.feature-item{display:flex;align-items:center;gap:12px;font-size:16px;color:#4a5568}.check-icon{width:28px;height:28px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.signup-form-container{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:24px;padding:48px;box-shadow:0 8px 32px #0000000f}.form-header{text-align:center;margin-bottom:32px}.form-header h2{font-size:32px;font-weight:700;color:#2d3748;margin-bottom:8px}.form-header p{font-size:16px;color:#718096}.signup-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:14px;font-weight:600;color:#4a5568}.input-wrapper{display:flex;align-items:center;gap:12px;background:#fffc;border:1px solid rgba(226,232,240,.6);border-radius:12px;padding:0 14px;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease}.input-wrapper:focus-within{border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a;background:#fff}.input-left-icon{display:flex;align-items:center;color:#718096;pointer-events:none;flex-shrink:0}.input-wrapper svg.input-icon,.input-wrapper>svg:first-child{color:#718096;pointer-events:none;flex-shrink:0}.input-wrapper input{flex:1;min-width:0;padding:14px 0;background:transparent!important;border:none!important;outline:none!important;box-shadow:none!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;font-size:15px;color:#2d3748;font-family:inherit}.input-wrapper input:focus,.input-wrapper input:active,.input-wrapper input:hover{outline:none!important;box-shadow:none!important;border:none!important;background:transparent!important}.input-wrapper input:-webkit-autofill,.input-wrapper input:-webkit-autofill:hover,.input-wrapper input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px rgba(255,255,255,0) inset!important;box-shadow:0 0 0 1000px #fff0 inset!important;-webkit-text-fill-color:#2d3748!important;background-color:transparent!important;border:none!important;transition:background-color 9999s ease-in-out 0s}.password-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#718096;cursor:pointer;padding:4px;border-radius:6px;transition:color .2s ease;flex-shrink:0}.password-toggle:hover{color:#4299e1}.submit-btn{width:100%;padding:16px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:0 4px 12px #4299e14d;transition:all .3s ease}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.alert{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:10px;font-size:14px;font-weight:500;margin-bottom:20px}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.resend-verification{background:#fef3c7;border:1px solid #fde68a;border-radius:12px;padding:16px;margin-bottom:20px;text-align:center}.resend-verification p{font-size:14px;color:#92400e;margin-bottom:12px;font-weight:500}.resend-btn{padding:10px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s ease;box-shadow:0 2px 8px #f59e0b4d}.resend-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b66}.resend-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.divider{position:relative;text-align:center;margin:24px 0}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:#e2e8f0cc}.divider:before{left:0}.divider:after{right:0}.divider span{background:#ffffffe6;padding:0 16px;color:#718096;font-size:14px;font-weight:500}.oauth-buttons{display:flex;flex-direction:column;gap:12px}.oauth-btn{width:100%;padding:14px;background:#fff;border:1px solid rgba(226,232,240,.8);border-radius:12px;font-size:15px;font-weight:600;color:#2d3748;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s ease}.oauth-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e0;transform:translateY(-1px)}.oauth-btn:disabled{opacity:.6;cursor:not-allowed}.apple-btn{background:#000;color:#fff;border-color:#000}.apple-btn:hover:not(:disabled){background:#1a1a1a;border-color:#1a1a1a}.form-footer{text-align:center;margin-top:24px}.form-footer p{color:#718096;font-size:14px}.toggle-btn{background:none;border:none;color:#4299e1;font-weight:600;cursor:pointer;font-family:inherit;font-size:14px;padding:0;text-decoration:underline}.toggle-btn:hover{color:#667eea}.terms-text{margin-top:10px;font-size:12px;color:#a0aec0}.terms-link{color:#4299e1;text-decoration:none;font-weight:500}.terms-link:hover{text-decoration:underline}@media (max-width: 1024px){.signup-content{grid-template-columns:1fr;gap:40px}.signup-info{text-align:center}.signup-info h1{font-size:40px}.features-list{align-items:center}}@media (max-width: 768px){.signup-form-container{padding:32px 24px}.signup-info h1{font-size:36px}.form-header h2{font-size:28px}}@media (max-width: 480px){.signup-page{padding:10px}.signup-info h1{font-size:32px}.signup-form-container{padding:24px 20px}}.sidebar{width:240px;background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.3);padding:32px 20px;display:flex;flex-direction:column;box-shadow:4px 0 24px #00000008;height:100vh;position:fixed;left:0;top:0;z-index:100}.sidebar-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:48px}.sidebar-close-btn{display:none;width:32px;height:32px;background:#0000000d;border:none;border-radius:8px;align-items:center;justify-content:center;cursor:pointer;color:#718096;transition:all .2s ease}.sidebar-close-btn:hover{background:#ef44441a;color:#ef4444}.logo{display:flex;align-items:center;gap:12px;padding:0 8px}.logo-icon{width:36px;height:36px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #4299e14d;color:#fff}.logo-text{font-size:20px;font-weight:600;color:#2d3748;letter-spacing:-.5px}.nav-menu{display:flex;flex-direction:column;gap:8px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;color:#718096;font-weight:500;font-size:15px;cursor:pointer;transition:all .3s ease;text-decoration:none}.nav-item:hover{background:#4299e114;color:#4299e1}.nav-item.active{background:#4299e11f;color:#4299e1;font-weight:600}.notif-badge{margin-left:auto;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;line-height:1;animation:badgePop .3s cubic-bezier(.68,-.55,.265,1.55) both}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.sidebar-footer{margin-top:auto;padding:12px;border-top:1px solid #e2e8f0}.profile-link{padding:10px 12px;gap:12px}.profile-avatar-small{width:36px;height:36px;border-radius:50%;background:#4299e1;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;overflow:hidden}.profile-avatar-small img{width:100%;height:100%;object-fit:cover}.profile-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.profile-name{font-size:14px;font-weight:600;color:#2d3748;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-points{font-size:12px;color:#718096;font-weight:500}.profile-link.active .profile-name{color:#4299e1}.sidebar-overlay{display:none}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .3s ease;background:#fffffff2;z-index:1001}.sidebar.open{transform:translate(0)}.sidebar-close-btn{display:flex}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.toast-stack{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;width:360px;max-width:calc(100vw - 32px);pointer-events:none}.notif-toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:14px;border:2px solid #3b82f6;background:#fff;box-shadow:0 8px 24px #3b82f626,0 2px 8px #00000014;pointer-events:all;position:relative;overflow:hidden;animation:toastSlideIn .38s cubic-bezier(.22,1,.36,1) both}@keyframes toastSlideIn{0%{opacity:0;transform:translate(120%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.toast-icon-wrap{flex-shrink:0;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.toast-body{flex:1;min-width:0}.toast-title{font-size:14px;font-weight:600;color:#1e293b;margin:0 0 3px;line-height:1.35}.toast-message{font-size:12.5px;color:#475569;margin:0;line-height:1.45}.toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;color:#94a3b8;padding:2px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.toast-close:hover{color:#1e293b;background:#3b82f614}.toast-progress-bar{position:absolute;bottom:0;left:0;height:3px;width:100%;transform-origin:left;animation:toastProgressShrink linear forwards;border-radius:0 0 0 14px}@keyframes toastProgressShrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.toast-success{border-color:#3b82f6}.toast-success .toast-icon-wrap{background:#22c55e1f;color:#16a34a}.toast-success .toast-progress-bar{background:#22c55e}.toast-badge{border-color:#3b82f6}.toast-badge .toast-icon-wrap{background:#f59e0b1f;color:#d97706}.toast-badge .toast-progress-bar{background:#f59e0b}.toast-progress{border-color:#3b82f6}.toast-progress .toast-icon-wrap{background:#3b82f61f;color:#2563eb}.toast-progress .toast-progress-bar{background:#3b82f6}.toast-ai{border-color:#3b82f6}.toast-ai .toast-icon-wrap{background:#a855f71f;color:#9333ea}.toast-ai .toast-progress-bar{background:#a855f7}.toast-streak{border-color:#3b82f6}.toast-streak .toast-icon-wrap{background:#f973161f;color:#ea580c}.toast-streak .toast-progress-bar{background:#f97316}.toast-info{border-color:#3b82f6}.toast-info .toast-icon-wrap{background:#3b82f61a;color:#3b82f6}.toast-info .toast-progress-bar{background:#3b82f6}.toast-warning{border-color:#3b82f6}.toast-warning .toast-icon-wrap{background:#eab3081f;color:#ca8a04}.toast-warning .toast-progress-bar{background:#eab308}@media (max-width: 480px){.toast-stack{top:12px;right:12px;left:12px;width:auto}}.app-container{display:flex;min-height:100vh;overflow:hidden}.main-content{flex:1;margin-left:240px;overflow-y:auto;padding:40px 48px}.mobile-menu-btn{display:none}@media (max-width: 768px){.main-content{margin-left:0;padding:70px 20px 24px}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;position:fixed;top:16px;left:16px;z-index:999;width:40px;height:40px;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:10px;cursor:pointer;color:#4299e1;box-shadow:0 2px 12px #00000014;transition:all .2s ease}.mobile-menu-btn:hover{background:#fffffff2;box-shadow:0 4px 16px #0000001f}}.home-page{width:100%;position:relative}.skill-intent-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.skill-intent-modal{background:#fff;border-radius:24px;max-width:600px;width:100%;padding:40px;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}.skill-intent-header{text-align:center;margin-bottom:32px}.skill-intent-header h2{font-size:28px;font-weight:700;color:#2d3748;margin-bottom:8px}.skill-intent-header p{font-size:16px;color:#718096}.skill-intent-content h3{font-size:18px;font-weight:600;color:#2d3748;text-align:center;margin-bottom:24px}.skill-intent-options{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.skill-intent-option{display:flex;flex-direction:column;align-items:center;padding:32px 24px;background:#4299e10d;border:2px solid rgba(66,153,225,.15);border-radius:16px;cursor:pointer;transition:all .3s ease;gap:12px}.skill-intent-option:hover{border-color:#4299e166;transform:translateY(-4px);box-shadow:0 8px 20px #4299e126}.skill-intent-option svg{color:#4299e1;margin-bottom:8px}.skill-intent-option .option-title{font-size:16px;font-weight:600;color:#2d3748}.skill-intent-option .option-description{font-size:13px;color:#718096;text-align:center}.skill-intent-option.yes-option:hover{background:linear-gradient(135deg,#10b9811a,#0596691a);border-color:#10b98166}.skill-intent-option.yes-option:hover svg{color:#10b981}.skill-intent-option.no-option:hover{background:#4299e114;border-color:#4299e166}.skill-intent-option.no-option:hover svg{color:#667eea}.skip-link{display:block;width:100%;text-align:center;padding:12px;background:none;border:none;color:#718096;font-size:14px;cursor:pointer;transition:color .3s ease}.skip-link:hover{color:#4a5568}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.welcome{display:flex;flex-direction:column;gap:4px}.welcome h1{font-size:28px;font-weight:700;color:#2d3748;letter-spacing:-.5px}.welcome p{font-size:15px;color:#718096;font-weight:400}.header-right{display:flex;align-items:center;gap:16px}.profile-btn{width:44px;height:44px;border-radius:50%;background:#4299e1;border:3px solid rgba(255,255,255,.9);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;box-shadow:0 4px 12px #4299e140;transition:all .3s ease}.profile-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e159}.skills-section{margin-bottom:48px}.section-title{font-size:32px;font-weight:700;color:#2d3748;letter-spacing:-.5px}.toggle-buttons{display:flex;gap:0;background:#fff9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:10px;padding:4px;border:1px solid rgba(255,255,255,.5)}.toggle-btn{padding:8px 20px;border:none;background:transparent;color:#718096;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .3s ease;text-decoration:none}.toggle-btn.active{background:#fff;color:#4299e1;box-shadow:0 2px 8px #00000014}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.skill-card--pending{cursor:default;border-color:#eab30859;background:#fffdebd9}.skill-card--pending:hover{transform:none;box-shadow:0 4px 16px #0000000a;border-color:#eab30880}.skill-plan-pending{display:flex;flex-direction:column;gap:10px;margin-top:8px}.skill-plan-pending-text{font-size:12.5px;color:#92400e;font-weight:500;background:#fcd34d4d;border:1px solid rgba(252,211,77,.5);border-radius:8px;padding:6px 10px}.skill-plan-retry-btn{padding:9px 16px;border-radius:10px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .18s,transform .18s;box-shadow:0 3px 10px #d9770659;align-self:flex-start}.skill-plan-retry-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.skill-plan-retry-btn:disabled{opacity:.6;cursor:not-allowed}.skill-image{width:100%;height:160px;background:#f0f4f8;overflow:hidden}.skill-content{padding:20px 24px 24px;display:flex;flex-direction:column;flex:1;justify-content:space-between}.skill-top,.skill-footer{display:flex;flex-direction:column}.skill-icon{width:48px;height:48px;background:#4299e1;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 4px 12px #4299e140;color:#fff}.skill-title{font-size:17px;font-weight:600;color:#2d3748;margin-bottom:8px;letter-spacing:-.3px;line-height:1.4}.skill-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:#718096;margin-bottom:16px}.progress-bar{width:100%;height:6px;background:#e2e8f099;border-radius:10px;overflow:hidden}.empty-state{text-align:center;padding:60px 20px}.empty-icon{width:80px;height:80px;margin:0 auto 24px;background:#4299e114;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#4299e1}.empty-title{font-size:18px;font-weight:600;color:#2d3748;margin-bottom:8px}.empty-text{font-size:14px;color:#718096}@media (max-width: 768px){.home-page{position:relative}.skill-intent-modal{padding:28px 20px;margin:20px}.skill-intent-header h2{font-size:24px}.skill-intent-options{grid-template-columns:1fr}.skill-intent-option{padding:24px 20px}.skills-grid{grid-template-columns:1fr}.home-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:28px;position:relative}.header-right{position:absolute;top:0;right:0}.profile-btn{width:38px;height:38px;font-size:14px}.welcome h1{font-size:22px;padding-right:50px}.welcome p{font-size:14px}.section-header{flex-direction:column;align-items:flex-start;gap:12px}}.csm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:csmFadeIn .25s ease-out}@keyframes csmFadeIn{0%{opacity:0}to{opacity:1}}.csm-modal{background:#fffffff7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.6);border-radius:24px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0000002e;animation:csmSlideUp .35s ease-out}@keyframes csmSlideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.csm-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 28px 0}.csm-header-left{display:flex;align-items:center;gap:14px}.csm-icon-badge{width:44px;height:44px;border-radius:12px;background:#4299e1;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.csm-title{font-size:20px;font-weight:700;color:#2d3748;margin:0 0 3px;letter-spacing:-.4px}.csm-subtitle{font-size:13px;color:#718096;margin:0}.csm-close{width:38px;height:38px;background:#4299e114;border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4299e1;transition:all .25s ease;flex-shrink:0}.csm-close:hover{background:#4299e12e;transform:rotate(90deg)}.csm-progress-dots{display:flex;align-items:center;justify-content:center;gap:0;padding:20px 28px 0}.csm-dot{width:10px;height:10px;border-radius:50%;background:#4299e133;transition:background .3s ease}.csm-dot.active{background:#4299e1}.csm-dot-line{flex:1;height:2px;max-width:60px;background:#4299e126;margin:0 8px}.csm-body{padding:24px 28px 28px;display:flex;flex-direction:column;gap:16px}.csm-label{font-size:15px;font-weight:600;color:#2d3748;line-height:1.5;margin:0}.csm-input{width:100%;padding:14px 16px;background:#fffc;border:1.5px solid rgba(66,153,225,.2);border-radius:12px;font-size:15px;color:#2d3748;transition:all .25s ease;box-sizing:border-box;font-family:inherit}.csm-input:focus{outline:none;border-color:#4299e180;box-shadow:0 0 0 3px #4299e11f}.csm-input::placeholder{color:#a0aec0}.csm-textarea{width:100%;padding:14px 16px;background:#fffc;border:1.5px solid rgba(66,153,225,.2);border-radius:12px;font-size:14px;color:#2d3748;transition:all .25s ease;resize:vertical;font-family:inherit;line-height:1.6;box-sizing:border-box}.csm-textarea:focus{outline:none;border-color:#4299e180;box-shadow:0 0 0 3px #4299e11f}.csm-textarea::placeholder{color:#a0aec0}.csm-textarea.disabled{background:#f1f3f5cc;color:#a0aec0;cursor:not-allowed;border-color:#a0aec033}.csm-hint{font-size:13px;color:#a0aec0;margin:-8px 0 0;line-height:1.5}.csm-general-btn{display:flex;align-items:center;gap:10px;padding:14px 18px;background:#fff9;border:1.5px solid rgba(113,128,150,.2);border-radius:12px;font-size:14px;color:#4a5568;cursor:pointer;transition:all .25s ease;text-align:left;width:100%;font-family:inherit}.csm-general-btn:hover{border-color:#4299e159;background:#4299e10d;color:#2d3748}.csm-general-btn.selected{border-color:#4299e1;background:#4299e114;color:#2d3748}.csm-general-btn.selected svg{color:#4299e1}.csm-radio-empty{width:16px;height:16px;border-radius:50%;border:2px solid #cbd5e0;flex-shrink:0}.csm-footer{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:4px}.csm-btn-primary{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease;font-family:inherit;white-space:nowrap}.csm-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #4299e159}.csm-btn-primary:disabled{opacity:.45;cursor:not-allowed}.csm-btn-large{padding:14px 28px;font-size:15px}.csm-btn-ghost{display:flex;align-items:center;gap:6px;padding:12px 18px;background:transparent;color:#718096;border:1.5px solid rgba(113,128,150,.25);border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .25s ease;font-family:inherit;white-space:nowrap}.csm-btn-ghost:hover{background:#71809614;color:#4a5568;border-color:#71809666}.csm-processing{align-items:center;padding:36px 28px 40px}.csm-processing-icon{width:72px;height:72px;border-radius:20px;background:#4299e11f;display:flex;align-items:center;justify-content:center;color:#4299e1;margin-bottom:8px}.csm-processing-title{font-size:18px;font-weight:700;color:#2d3748;margin:0 0 24px;letter-spacing:-.3px}.csm-processing-steps{width:100%;display:flex;flex-direction:column;gap:12px;max-width:360px}.csm-proc-step{display:flex;align-items:center;gap:12px;font-size:14px;color:#a0aec0;transition:color .3s ease}.csm-proc-step.active{color:#4299e1;font-weight:500}.csm-proc-step.done{color:#10b981}.csm-proc-icon{flex-shrink:0}.csm-proc-icon.done{color:#10b981}.csm-proc-icon-empty{width:16px;height:16px;border-radius:50%;border:2px solid rgba(160,174,192,.4);flex-shrink:0}.csm-spin{animation:csmSpin .8s linear infinite}@keyframes csmSpin{to{transform:rotate(360deg)}}.csm-result{align-items:center;text-align:center;padding:36px 28px}.csm-result-icon{width:68px;height:68px;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.csm-result-icon.warning{background:#f59e0b1f;color:#f59e0b}.csm-result-icon.error{background:#ef44441a;color:#ef4444}.csm-result-title{font-size:20px;font-weight:700;color:#2d3748;margin:8px 0 4px;letter-spacing:-.4px}.csm-result-desc{font-size:14px;color:#718096;line-height:1.6;margin:0;max-width:380px}.csm-result-desc.small{font-size:13px;color:#a0aec0}.csm-result-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px;margin-top:8px}.csm-result-actions .csm-btn-primary,.csm-result-actions .csm-btn-ghost{justify-content:center;width:100%}.csm-preview{gap:20px}.csm-preview-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#10b9811a;border:1px solid rgba(16,185,129,.25);border-radius:20px;font-size:13px;font-weight:600;color:#059669;align-self:flex-start}.csm-preview-card{border:1.5px solid rgba(66,153,225,.2);border-radius:16px;overflow:hidden;background:#fffc}.csm-preview-card-image{height:140px;background:#f0f4f8;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.csm-preview-card-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.csm-preview-card-letter{font-size:56px;font-weight:700;color:#4299e140;line-height:1}.csm-preview-community-tag{position:absolute;top:14px;right:14px;background:#ffffffd9;border:1px solid rgba(113,128,150,.15);border-radius:20px;padding:4px 10px;font-size:12px;color:#4a5568;font-weight:500;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.csm-preview-card-body{padding:20px;display:flex;flex-direction:column;gap:10px}.csm-preview-card-title{font-size:18px;font-weight:700;color:#2d3748;margin:0;letter-spacing:-.3px}.csm-preview-card-desc{font-size:13px;color:#718096;line-height:1.6;margin:0}.csm-preview-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:#718096}.csm-preview-meta span{display:flex;align-items:center;gap:4px;text-transform:capitalize}.csm-preview-learn{background:#4299e10a;border:1px solid rgba(66,153,225,.1);border-radius:10px;padding:12px 14px}.csm-preview-learn-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#4299e1;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.csm-preview-learn-list{margin:0;padding:0 0 0 16px;display:flex;flex-direction:column;gap:4px}.csm-preview-learn-list li{font-size:13px;color:#4a5568;line-height:1.5}.csm-preview-tools{display:flex;align-items:center;gap:6px;font-size:12px;color:#a0aec0}.csm-preview-footer{justify-content:space-between}@media (max-width: 600px){.csm-modal{border-radius:20px;max-height:95vh}.csm-header{padding:22px 20px 0}.csm-body{padding:20px 20px 24px}.csm-footer{flex-direction:column-reverse}.csm-btn-primary,.csm-btn-ghost{width:100%;justify-content:center}.csm-preview-footer{flex-direction:column}}.explore-page{width:100%}.page-header{margin-bottom:24px}.page-title{font-size:32px;font-weight:600;color:#2d3748;margin-bottom:8px;letter-spacing:-.5px}.page-subtitle{font-size:15px;color:#718096;font-weight:400}.search-bar{position:relative;margin-bottom:24px}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#718096;z-index:2;pointer-events:none}.search-input{width:100%;padding:14px 48px;background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px;font-size:15px;color:#2d3748;transition:all .3s ease}.search-input:focus{outline:none;border-color:#4299e180;box-shadow:0 4px 12px #4299e126}.search-input::placeholder{color:#a0aec0}.search-clear{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;color:#718096;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.search-clear:hover{color:#ef4444}.filter-section{display:flex;flex-direction:column;gap:16px;margin-bottom:24px;padding:20px;background:#ffffff80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px}.filter-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-label{font-size:14px;font-weight:500;color:#4a5568;min-width:80px}.filter-pills{display:flex;gap:8px;flex-wrap:wrap}.filter-pill{padding:8px 16px;background:#fffc;border:1px solid rgba(113,128,150,.2);border-radius:16px;font-size:13px;font-weight:500;color:#718096;cursor:pointer;transition:all .3s ease}.filter-pill:hover{background:#4299e11a;border-color:#4299e14d;color:#4299e1}.filter-pill.active{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 2px 8px #4299e14d}.categories{display:flex;gap:12px;margin-bottom:32px;flex-wrap:wrap;align-items:center}.category-pill{padding:10px 24px;background:#fff9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:20px;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:all .3s ease;white-space:nowrap}.category-pill:hover{background:#ffffffe6;color:#4299e1;border-color:#4299e14d}.category-pill.active{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 4px 12px #4299e14d}.clear-filter{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:50%;cursor:pointer;transition:all .3s ease;color:#718096}.clear-filter:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.ai-discovery-banner{display:flex;justify-content:space-between;align-items:center;padding:24px;margin-bottom:32px;background:#4299e114;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(66,153,225,.2);border-radius:16px;gap:16px}.ai-discovery-content{display:flex;align-items:center;gap:16px}.ai-discovery-content svg{color:#4299e1;flex-shrink:0}.ai-discovery-content h3{font-size:16px;font-weight:600;color:#2d3748;margin:0 0 4px}.ai-discovery-content p{font-size:14px;color:#718096;margin:0}.ai-discovery-btn{padding:12px 24px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.ai-discovery-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #4299e14d}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.skill-card{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #0000000a;display:flex;flex-direction:column}.skill-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014;border-color:#4299e14d}.skill-image{width:100%;height:180px;background:linear-gradient(135deg,#e0e7ff,#f3f4f6);overflow:hidden;position:relative}.skill-image img{width:100%;height:100%;object-fit:cover}.skill-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;font-weight:700;color:#4299e133}.skill-content{padding:24px;flex:1;display:flex;flex-direction:column}.skill-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.skill-title{font-size:18px;font-weight:600;color:#2d3748;letter-spacing:-.3px;flex:1}.skill-description{font-size:14px;color:#718096;line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.skill-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:#718096;margin-top:auto;padding-top:16px}.skill-meta span{display:flex;align-items:center;gap:4px}.difficulty-badge{font-weight:600;text-transform:capitalize}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.empty-state svg{color:#cbd5e0}.empty-state h3{font-size:20px;font-weight:600;color:#2d3748;margin:0}.empty-state p{font-size:15px;color:#718096;margin:0}.clear-filters-btn{margin-top:8px;padding:10px 24px;background:#4299e11a;color:#4299e1;border:1px solid rgba(66,153,225,.3);border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.clear-filters-btn:hover{background:#4299e133}.empty-state-divider{font-size:13px;color:#cbd5e0;margin:-4px 0}.create-skill-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit}.create-skill-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #4299e159}.skill-image{position:relative}.skill-community-badge{position:absolute;top:12px;right:12px;background:#ffffffe0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(113,128,150,.15);border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;color:#4a5568;letter-spacing:.2px}.community-skill-card{border-color:#667eea33}.community-skill-card:hover{border-color:#667eea66}.create-skill-banner{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;margin-top:40px;background:#ffffff80;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(102,126,234,.2);border-radius:16px;gap:16px}.create-skill-banner-content{display:flex;align-items:center;gap:14px}.create-skill-banner-icon{color:#667eea;flex-shrink:0}.create-skill-banner-text{font-size:15px;font-weight:500;color:#4a5568}.create-skill-banner-btn{padding:11px 22px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-family:inherit}.create-skill-banner-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #4299e14d}@media (max-width: 768px){.skills-grid{grid-template-columns:1fr}.categories{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px}.categories::-webkit-scrollbar{height:4px}.categories::-webkit-scrollbar-thumb{background:#7180964d;border-radius:10px}.filter-section{padding:16px}.filter-group{flex-direction:column;align-items:flex-start}.filter-label{min-width:auto}.ai-discovery-banner,.ai-discovery-content{flex-direction:column;text-align:center}.create-skill-banner{flex-direction:column;text-align:center;gap:14px}.create-skill-banner-content{flex-direction:column;text-align:center}.create-skill-banner-btn{width:100%}}.progress-page{width:100%}.progress-page .page-header{margin-bottom:32px}.progress-page .page-title{font-size:32px;font-weight:600;color:#2d3748;margin-bottom:8px;letter-spacing:-.5px}.progress-page .page-subtitle{font-size:15px;color:#718096;font-weight:400}.skill-switcher{display:flex;gap:12px;margin-bottom:32px;overflow-x:auto;padding-bottom:8px}.skill-tab{padding:12px 24px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:all .3s ease;white-space:nowrap;display:flex;align-items:center;gap:8px}.skill-tab:hover{background:#ffffffe6;border-color:#4299e14d}.skill-tab.active{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 4px 12px #4299e14d}.skill-tab-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.stat-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:18px 20px;transition:all .3s ease;box-shadow:0 4px 16px #0000000a;display:flex;flex-direction:row;align-items:center;gap:14px}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000000f}.days-icon-wrap{background:#48bb781f;color:#38a169}.time-icon-wrap{background:#4299e11f;color:#4299e1}.score-icon-wrap{background:#eab3081f;color:#ca8a04}.days-ring{stroke:#48bb78}.time-ring{stroke:#4299e1}.score-ring{stroke:#eab308}.stat-ring-value{font-size:12px;font-weight:700;color:#2d3748;line-height:1;text-align:center}.stat-label{font-size:13px;color:#718096;font-weight:500}.stat-change{font-size:12px;color:#10b981;display:flex;align-items:center;gap:4px}.stat-change.negative{color:#ef4444}.progress-page .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;min-height:400px}.progress-page .loading-spinner{width:48px;height:48px;border:4px solid rgba(66,153,225,.1);border-top-color:#4299e1;border-radius:50%;animation:progress-spin .8s linear infinite}@keyframes progress-spin{to{transform:rotate(360deg)}}.progress-page .loading-state p{font-size:15px;color:#718096}.graph-section{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:32px;margin-bottom:32px;box-shadow:0 4px 16px #0000000a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.time-filter{display:flex;gap:8px;background:#fff9;padding:4px;border-radius:10px}.time-btn{padding:6px 16px;border:none;background:transparent;color:#718096;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .3s ease}.time-btn.active{background:#fff;color:#4299e1;box-shadow:0 2px 8px #00000014}.graph-placeholder{width:100%;height:auto;aspect-ratio:420 / 140;background:#4299e10a;border-radius:12px;position:relative;overflow:hidden}.graph-placeholder.graph-empty{cursor:default}.graph-empty-label{position:absolute;bottom:14px;left:0;right:0;text-align:center;color:#a0aec0;font-size:13px;pointer-events:none}.graph-line{position:absolute;bottom:20%;left:0;width:100%;height:60%}.graph-line svg{width:100%;height:100%}.ai-icon{width:32px;height:32px;background:#4299e1;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.ai-insight-title{font-size:16px;font-weight:600;color:#2d3748}.exercise-section{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:32px;margin-bottom:32px;box-shadow:0 4px 16px #0000000a}.exercise-subtitle{font-size:15px;color:#718096;margin-bottom:16px;font-weight:500}.exercise-content{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:24px}.exercise-graph{background:#f8fafc99;border-radius:12px;padding:20px;height:250px;display:flex;align-items:flex-end;justify-content:space-around;gap:8px}.bar{flex:1;background:#4299e1;border-radius:6px 6px 0 0;position:relative;transition:all .3s ease;cursor:pointer}.bar:hover{opacity:.8;transform:scaleY(1.05)}.bar-label{position:absolute;bottom:-24px;left:50%;transform:translate(-50%);font-size:11px;color:#718096;white-space:nowrap}.bar-value{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:12px;font-weight:600;color:#2d3748}.recent-scores{display:flex;flex-direction:column;gap:12px}.score-item{background:#f8fafc99;border-radius:10px;padding:16px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.score-item:hover{background:#f8fafce6;transform:translate(4px)}.score-info h4{font-size:14px;color:#2d3748;margin-bottom:4px;font-weight:600}.score-info p{font-size:12px;color:#718096}.score-value{font-size:20px;font-weight:700;color:#4299e1}.exercise-ai-insight{margin-top:24px;margin-bottom:0}.view-all-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:10px;color:#4299e1;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;margin-top:16px}.view-all-btn:hover{background:#4299e11a;border-color:#4299e14d;transform:translate(4px)}.progress-page .badges-stats{display:grid;grid-template-columns:1fr 1fr;gap:24px}.progress-page .badges-section,.progress-page .stats-section{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:32px;box-shadow:0 4px 16px #0000000a}.progress-page .badges-section .section-title,.progress-page .stats-section .section-title{font-size:20px;font-weight:600;color:#2d3748;margin:0;padding:0;letter-spacing:normal}.progress-page .badges-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}.progress-page .badge{background:#ffffffbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:16px;padding:18px 12px 14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .25s ease;position:relative;box-shadow:0 2px 10px #0000000d}.progress-page .badge:hover{transform:translateY(-3px);box-shadow:0 6px 18px #00000017;background:#fffffff2}.progress-page .badge.gold{border-color:#fbbf2480;background:linear-gradient(145deg,#fffbebe6,#fffc)}.progress-page .badge.silver{border-color:#9ca3af80;background:linear-gradient(145deg,#f3f4f6e6,#fffc)}.progress-page .badge.bronze{border-color:#b4783c66;background:linear-gradient(145deg,#fef7ede6,#fffc)}.progress-page .badge.blue{border-color:#4299e166;background:linear-gradient(145deg,#ebf8ffe6,#fffc)}.progress-page .badge.locked{background:#f8fafc99;border-color:#cbd5e180;box-shadow:none}.progress-page .badge-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;position:relative}.progress-page .badge.gold .badge-icon{background:linear-gradient(135deg,#fde68a,#fbbf24);box-shadow:0 3px 10px #fbbf2459}.progress-page .badge.silver .badge-icon{background:linear-gradient(135deg,#f3f4f6,#d1d5db);box-shadow:0 3px 10px #9ca3af4d}.progress-page .badge.bronze .badge-icon{background:linear-gradient(135deg,#fde8c8,#d97706);box-shadow:0 3px 10px #d977064d}.progress-page .badge.blue .badge-icon{background:#4299e1;box-shadow:0 3px 10px #4299e14d}.progress-page .badge.locked .badge-icon{background:#e2e8f099}.badge-emoji-faded{opacity:.3;filter:grayscale(1);display:flex;align-items:center;justify-content:center;color:#64748b}.badge-lock-overlay{position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;background:#94a3b8;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 1px 4px #0003}.progress-page .badge-name{font-size:11px;font-weight:600;color:#374151;text-align:center;line-height:1.3}.progress-page .badge.locked .badge-name{color:#9ca3af}.progress-page .stats-list{display:flex;flex-direction:column;gap:20px;margin-top:24px}.progress-page .stat-row{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8fafc99;border-radius:10px}.progress-page .stat-row-left{display:flex;align-items:center;gap:12px}.progress-page .stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:0}.progress-page .stat-icon.streak{background:linear-gradient(135deg,#f59e0b,#d97706)}.progress-page .stat-icon.xp{background:#4299e1}.progress-page .stat-icon.time{background:linear-gradient(135deg,#10b981,#059669)}.progress-page .stat-row-info h4{font-size:14px;color:#2d3748;font-weight:600;margin-bottom:2px}.progress-page .stat-row-info p{font-size:12px;color:#718096}.progress-page .stat-row-value{font-size:24px;font-weight:700;color:#2d3748}@media (max-width: 1200px){.progress-page .badges-stats,.exercise-content{grid-template-columns:1fr}}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.graph-section{padding:16px}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.graph-scroll-wrapper{width:100%}.graph-scroll-wrapper .graph-placeholder{height:160px}}.graph-scroll-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.exercises-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.exercises-modal{background:#fff;border-radius:20px;width:100%;max-width:720px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #0000002e;overflow:hidden}.exercises-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 32px 24px;border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0}.exercises-modal-title{font-size:20px;font-weight:700;color:#2d3748;margin:0 0 4px}.exercises-modal-subtitle{font-size:13px;color:#718096;margin:0}.exercises-modal-close{background:#f8fafccc;border:1px solid rgba(0,0,0,.06);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#718096;transition:all .2s;flex-shrink:0}.exercises-modal-close:hover{background:#f1f5f9;color:#2d3748}.exercises-modal-body{overflow-y:auto;flex:1;padding:24px 32px}.exercises-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 0;color:#718096;font-size:14px;text-align:center}.exercises-list{display:flex;flex-direction:column;gap:10px}.exercise-list-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8fafccc;border:1px solid rgba(0,0,0,.04);border-radius:12px;transition:all .2s;gap:12px}.exercise-list-item:hover{background:#f8fafc;border-color:#4299e133;transform:translate(2px)}.eli-left{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.eli-icon{width:32px;height:32px;background:#4299e1;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.eli-info{min-width:0}.eli-info h4{font-size:14px;font-weight:600;color:#2d3748;margin:0 0 3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.eli-info p{font-size:12px;color:#718096;margin:0 0 3px}.eli-day{font-size:11px;font-weight:500;background:#4299e11a;color:#4299e1;padding:2px 8px;border-radius:20px}.eli-feedback-preview{font-size:12px;color:#4a5568;margin-top:4px!important;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.eli-pending{font-size:11px;color:#f59e0b;font-weight:500}.eli-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.eli-score{font-size:20px;font-weight:700}.eli-view-btn{font-size:11px;color:#4299e1;display:flex;align-items:center;gap:2px;font-weight:500;white-space:nowrap}.correction-detail{display:flex;flex-direction:column;gap:20px}.correction-back-btn{background:none;border:none;color:#4299e1;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:4px;align-self:flex-start}.correction-back-btn:hover{color:#2b6cb0}.correction-score-section{display:flex;align-items:center;gap:20px;padding:20px;background:#f8fafccc;border-radius:12px}.correction-score-badge{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.score-label{font-size:11px;color:#718096;font-weight:500}.score-value{font-size:28px;font-weight:700}.score-points{font-size:12px;color:#10b981;font-weight:600}.correction-meta{font-size:13px;color:#4a5568;line-height:1.6}.correction-section{background:#f8fafc80;border-radius:12px;padding:20px}.correction-section-title{font-size:15px;font-weight:600;color:#2d3748;margin:0 0 14px}.correction-submission-content{font-size:14px;color:#4a5568}.correction-code-block{background:#1a202c;border-radius:8px;overflow:hidden;position:relative}.correction-code-lang{background:#ffffff14;color:#a0aec0;font-size:11px;font-weight:500;padding:6px 14px;letter-spacing:.05em;text-transform:uppercase}.correction-code-block code{font-family:Fira Code,Cascadia Code,monospace;font-size:13px;color:#e2e8f0;line-height:1.6}.correction-text-content{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:8px;padding:14px;font-size:14px;line-height:1.7;color:#4a5568}.correction-file-info{font-size:13px;color:#4a5568;display:flex;flex-direction:column;gap:6px}.correction-feedback{display:flex;flex-direction:column;gap:16px}.feedback-summary{font-size:14px;line-height:1.7;color:#4a5568;padding:14px;background:#fff;border-left:3px solid #4299e1;border-radius:0 8px 8px 0}.feedback-category h4{font-size:14px;font-weight:600;color:#2d3748;margin:0 0 10px}.feedback-category ul{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.feedback-category ul li{font-size:13px;color:#4a5568;line-height:1.5}@media (max-width: 600px){.exercises-modal{max-height:92vh;border-radius:16px 16px 0 0;align-self:flex-end}.exercises-modal-overlay{align-items:flex-end;padding:0}.exercises-modal-header,.exercises-modal-body{padding:20px}}.badges-modal-section{margin-bottom:32px}.badges-modal-section:last-child{margin-bottom:0}.badges-modal-section-title{font-size:18px;font-weight:600;color:#2d3748;margin-bottom:16px}.badges-modal-grid{display:flex;flex-direction:column;gap:16px}.badge-modal-item{display:flex;gap:16px;padding:20px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px;transition:all .3s ease}.badge-modal-item:hover{background:#ffffffe6;transform:translateY(-2px);box-shadow:0 6px 20px #0000000f}.badge-modal-item.locked{opacity:1}.badge-modal-icon{width:64px;height:64px;min-width:64px;border-radius:14px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.badge-modal-icon.gold{background:linear-gradient(135deg,#fde68a,#fbbf24);color:#92400e;box-shadow:0 3px 12px #fbbf2459}.badge-modal-icon.silver{background:linear-gradient(135deg,#f3f4f6,#d1d5db);color:#374151;box-shadow:0 3px 12px #9ca3af4d}.badge-modal-icon.bronze{background:linear-gradient(135deg,#fde8c8,#d97706);color:#78350f;box-shadow:0 3px 12px #d977064d}.badge-modal-icon.blue{background:#4299e1;color:#fff;box-shadow:0 3px 12px #4299e14d}.badge-modal-icon.locked-icon{background:#e2e8f099;color:#94a3b8}.badge-modal-content{flex:1;display:flex;flex-direction:column;gap:8px}.badge-modal-name{font-size:16px;font-weight:600;color:#2d3748;margin:0}.badge-modal-description{font-size:14px;line-height:1.5;color:#718096;margin:0}.badge-modal-progress{display:flex;flex-direction:column;gap:6px;margin-top:4px}.badge-progress-bar{width:100%;height:6px;background:#00000014;border-radius:10px;overflow:hidden}.badge-progress-fill{height:100%;background:#4299e1;border-radius:10px;transition:width .3s ease}.badge-progress-text{font-size:12px;color:#718096;font-weight:500}.profile-page{padding:32px;min-height:100vh;background:#f5f7fa}.profile-container{max-width:1000px;margin:0 auto}.profile-header{background:#fff;border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:0 2px 8px #0000000d}.profile-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.profile-avatar-section{display:flex;gap:24px;align-items:center}.profile-avatar{position:relative;width:120px;height:120px;background:#4299e1;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-edit-btn{position:absolute;bottom:4px;right:4px;width:36px;height:36px;background:#fff;border:2px solid #e2e8f0;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#4a5568}.avatar-edit-btn:hover{background:#f7fafc;border-color:#4299e1;color:#4299e1}.profile-basic-info h1{font-size:32px;font-weight:700;color:#2d3748;margin:0 0 8px}.profile-email{display:flex;align-items:center;gap:8px;color:#718096;font-size:16px}.profile-name-input{font-size:32px;font-weight:700;color:#2d3748;border:2px solid #e2e8f0;border-radius:8px;padding:8px 12px;font-family:inherit;margin-bottom:8px;width:100%;max-width:400px}.profile-name-input:focus{outline:none;border-color:#4299e1}.profile-actions{display:flex;gap:12px}.btn-edit,.btn-save,.btn-cancel{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s;border:none}.btn-edit{background:#4299e1;color:#fff;box-shadow:0 4px 12px #4299e14d}.btn-edit:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.btn-save{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.btn-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{background:#e2e8f0;color:#4a5568}.btn-cancel:hover{background:#cbd5e0}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000d;transition:all .3s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.streak{background:#f973161f;color:#f97316}.stat-icon.points{background:#eab3081f;color:#ca8a04}.stat-icon.longest-streak{background:#8b5cf61f;color:#8b5cf6}.stat-icon.member-since{background:#4299e11f;color:#4299e1}.stat-content{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px}.stat-value{font-size:24px;font-weight:700;color:#2d3748;line-height:1.1}.stat-label{font-size:13px;color:#718096;font-weight:500;line-height:1}.profile-section{background:#fff;border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:0 2px 8px #0000000d}.profile-section h2{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 20px}.profile-bio{color:#4a5568;line-height:1.6;font-size:16px;margin:0}.profile-bio-input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:16px;font-family:inherit;color:#2d3748;resize:vertical;min-height:100px}.profile-bio-input:focus{outline:none;border-color:#4299e1}.account-details{display:flex;flex-direction:column;gap:16px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e2e8f0}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;color:#4a5568;font-size:15px}.detail-value{color:#2d3748;font-size:15px}.verified-badge{background:#d1fae5;color:#065f46;padding:4px 12px;border-radius:6px;font-size:14px;font-weight:600}.unverified-badge{background:#fee2e2;color:#991b1b;padding:4px 12px;border-radius:6px;font-size:14px;font-weight:600}.plan-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:13px;font-weight:700;border:1px solid transparent}.plan-badge-trial{background:#ebf8ff;color:#2b6cb0;border-color:#bee3f8}.plan-badge-starter{background:#f0fff4;color:#2f855a;border-color:#9ae6b4}.plan-badge-plus{background:#edf2ff;color:#4c51bf;border-color:#c3dafe}.plan-badge-premium{background:#faf5ff;color:#6b46c1;border-color:#d6bcfa}.plan-badge-unlimited{background:#fffaf0;color:#975a16;border-color:#fbd38d}.plan-badge-default{background:#f7fafc;color:#4a5568;border-color:#e2e8f0}.logout-section{display:flex;justify-content:center;padding:24px}.btn-logout{display:flex;align-items:center;gap:10px;padding:14px 32px;background:#fff;border:2px solid #e2e8f0;color:#dc2626;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s}.btn-logout:hover{background:#fef2f2;border-color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #dc262633}@media (max-width: 768px){.profile-page{padding:16px}.profile-header-content{flex-direction:column}.profile-avatar-section{flex-direction:column;text-align:center;width:100%}.profile-basic-info{width:100%}.profile-basic-info h1{font-size:24px}.profile-name-input{font-size:24px;max-width:100%}.profile-actions{width:100%}.btn-edit,.btn-save,.btn-cancel{flex:1}.profile-stats{grid-template-columns:1fr}.detail-row{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 480px){.profile-section,.profile-header{padding:20px}.profile-avatar{width:100px;height:100px}.stat-card{padding:16px}.stat-icon{width:48px;height:48px}.stat-value{font-size:24px}}.skill-detail-page{width:100%}.skill-banner{position:relative;width:100%;height:280px;border-radius:16px;overflow:hidden;margin-bottom:32px;box-shadow:0 4px 16px #00000014}.skill-banner img{width:100%;height:100%;object-fit:cover}.skill-banner-overlay{position:absolute;bottom:0;left:0;right:0;height:100%;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 50%,transparent 100%);display:flex;align-items:flex-end;padding:32px}.skill-banner-content{width:100%}.skill-banner-title{font-size:36px;font-weight:700;color:#fff;margin-bottom:16px;letter-spacing:-.5px;text-shadow:0 2px 8px rgba(0,0,0,.3)}.skill-banner-meta{display:flex;gap:32px;align-items:center;flex-wrap:wrap}.banner-meta-item{display:flex;align-items:center;gap:8px;font-size:16px;color:#fffffff2;font-weight:500}.banner-meta-item strong{color:#fff;font-weight:700}.back-button{display:inline-flex;align-items:center;gap:8px;color:#4299e1;font-size:14px;font-weight:500;background:none;border:none;cursor:pointer;margin-bottom:24px;transition:all .3s ease;font-family:inherit;padding:0}.skill-header{margin-bottom:32px}.skill-title{font-size:36px;font-weight:700;color:#2d3748;margin-bottom:12px;letter-spacing:-.5px}.skill-meta{display:flex;gap:24px;align-items:center;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:8px;font-size:15px;color:#718096}.meta-item strong{color:#2d3748;font-weight:600}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:18px 20px;box-shadow:0 4px 16px #0000000a;display:flex;flex-direction:row;align-items:center;gap:14px}.stat-card.highlight{background:#4299e11a;border-color:#4299e14d}.stat-card-icon-wrap{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.streak-icon-wrap{background:#f973161f;color:#f97316}.commitment-icon-wrap{background:#4299e11f;color:#4299e1}.lessons-icon-wrap{background:#48bb781f;color:#38a169}.stat-card-icon{display:block}.stat-card-label{flex:1;font-size:14px;font-weight:500;color:#4a5568;line-height:1.3}.stat-ring-wrap{position:relative;width:56px;height:56px;flex-shrink:0}.stat-ring-svg{width:56px;height:56px;transform:rotate(-90deg)}.stat-ring-bg{fill:none;stroke:#00000012;stroke-width:6}.stat-ring-fill{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dasharray .6s ease}.streak-ring{stroke:#f97316}.commitment-ring{stroke:#4299e1}.lessons-ring{stroke:#48bb78}.stat-ring-inner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.stat-ring-value{font-size:13px;font-weight:700;color:#2d3748;line-height:1}.stat-label{font-size:13px;color:#718096;font-weight:500;text-align:center}.stat-icon{font-size:32px;margin-bottom:12px}.stat-value{font-size:28px;font-weight:700;color:#2d3748}.ai-insight{background:#4299e11a;border:1px solid rgba(66,153,225,.2);border-radius:16px;padding:24px;margin-bottom:32px;position:relative;overflow:hidden}.ai-insight:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:#4299e1}.ai-insight-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.ai-icon{width:32px;height:32px;background:#4299e1;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 10px #4299e159}.ai-insight-title{font-size:16px;font-weight:600;color:#2d3748;margin:0}.ai-insight-content{font-size:15px;line-height:1.7;color:#4a5568;padding-left:44px}.ai-insight-content strong{color:#4299e1;font-weight:600}.lessons-section{margin-top:32px}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.section-icon{width:40px;height:40px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #4299e14d}.section-icon-badge{display:inline-flex;align-items:center;background:#4299e1;border-radius:12px;padding-right:16px;box-shadow:0 4px 16px #4299e159;overflow:hidden}.section-icon-badge .section-icon{border-radius:10px 0 0 10px;box-shadow:none}.section-badge-label{color:#fff;font-size:15px;font-weight:600;letter-spacing:.01em;margin-left:10px}.section-title{font-size:20px;font-weight:600;color:#2d3748}.lessons-grid{display:grid;gap:20px}.lesson-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:24px;transition:all .3s ease;box-shadow:0 4px 16px #0000000a;position:relative}.lesson-card.completed{opacity:.7}.lesson-card.current{border-color:#4299e166;background:#4299e114}.lesson-card.current:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:#4299e1;border-radius:16px 0 0 16px}.lesson-card.future{opacity:.6}.lesson-status{display:inline-block;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;margin-bottom:12px}.lesson-status.completed{background:#10b9811a;color:#10b981}.lesson-status.current{background:#4299e126;color:#4299e1}.lesson-status.upcoming{background:#e2e8f080;color:#718096}.lesson-card-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.lesson-card-top-row .lesson-status{margin-bottom:0}.lesson-diff-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:700;letter-spacing:.02em;flex-shrink:0}.diff-easy{background:#22c55e1f;color:#16a34a;border:1px solid rgba(34,197,94,.3)}.diff-intermediate{background:#eab3081f;color:#ca8a04;border:1px solid rgba(234,179,8,.3)}.diff-hard{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.25)}.lesson-title{font-size:18px;font-weight:600;color:#2d3748;margin-bottom:8px;text-align:right}.lesson-description{font-size:14px;line-height:1.6;color:#718096;margin-bottom:16px}.lesson-meta{display:flex;flex-direction:column;align-items:flex-start;gap:6px;font-size:13px;color:#718096}.lesson-meta span{display:flex;align-items:center;gap:6px;line-height:1.4}.lesson-meta span svg{flex-shrink:0}.current-lesson-summary{background:#ffffffe6;border-radius:12px;padding:20px;margin-top:16px;border:2px solid rgba(66,153,225,.2)}.summary-title{font-size:14px;font-weight:600;color:#4299e1;margin-bottom:12px}.summary-list{list-style:none;padding:0}.summary-list li{padding:8px 0 8px 24px;position:relative;font-size:14px;color:#4a5568;line-height:1.5}.summary-list li:before{content:"→";position:absolute;left:0;color:#4299e1;font-weight:700}.continue-button{display:inline-flex;align-items:center;gap:12px;padding:16px 32px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-family:inherit;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #4299e166;transition:all .3s ease;margin-top:16px}.continue-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4299e180}.brief-roadmap-section{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:24px;margin-bottom:32px;box-shadow:0 4px 16px #0000000a}.roadmap-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.roadmap-title{font-size:18px;font-weight:600;color:#2d3748;margin:0}.view-all-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#4299e11a;color:#4299e1;border:1px solid rgba(66,153,225,.2);border-radius:8px;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.view-all-btn:hover{background:#4299e126;border-color:#4299e14d}.brief-roadmap-track{display:flex;align-items:flex-start;justify-content:flex-start;overflow-x:auto;scrollbar-width:none;padding:12px 0}.brief-roadmap-track::-webkit-scrollbar{display:none}.brief-roadmap-item{display:contents}.brief-roadmap-node{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0;padding:0 12px}.brief-roadmap-circle{width:40px;height:40px;border-radius:50%;background:#e2e8f0cc;border:2px solid rgba(203,213,225,.7);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#94a3b8;transition:all .3s ease}.brief-roadmap-node.milestone .brief-roadmap-circle{background:#4299e1;border-color:transparent;color:#fff;box-shadow:0 4px 14px #4299e180}.brief-roadmap-node.current .brief-roadmap-circle{background:linear-gradient(135deg,#f59e0b,#f97316);border-color:transparent;color:#fff;box-shadow:0 4px 14px #f59e0b80;animation:pulse 2s infinite}.brief-roadmap-node.completed .brief-roadmap-circle{background:#48bb78;border-color:transparent;color:#fff}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.brief-roadmap-label{font-size:11px;font-weight:500;color:#64748b;text-align:center;max-width:140px;line-height:1.4;word-wrap:break-word;white-space:normal}.brief-roadmap-node.milestone .brief-roadmap-label{color:#4299e1;font-weight:600}.brief-roadmap-node.current .brief-roadmap-label{color:#f59e0b;font-weight:600}.brief-roadmap-node.completed .brief-roadmap-label{color:#48bb78}.brief-roadmap-connector{flex:1;height:2px;background:#cbd5e1b3;margin-top:20px;align-self:flex-start;min-width:30px;transition:background .4s ease}.brief-roadmap-connector.filled{background:#4299e1}@media (max-width: 768px) and (min-width: 481px){.skill-title{font-size:28px}.stats-row{grid-template-columns:1fr}.brief-roadmap-container{padding:0 12px}.brief-roadmap-node{padding:0 8px}.brief-roadmap-day{font-size:11px}.brief-roadmap-label{font-size:10px;max-width:120px}.brief-roadmap-connector{min-width:20px}}@media (max-width: 480px){.back-button{font-size:13px;margin-bottom:16px}.skill-title{font-size:24px}.skill-meta{gap:12px}.meta-item{font-size:13px}.stats-row{gap:12px;margin-bottom:24px}.stat-card{padding:14px 16px;gap:10px}.stat-ring-wrap,.stat-ring-svg{width:48px;height:48px}.stat-ring-value{font-size:11px}.stat-card-label{font-size:13px}.section-header{font-size:18px;margin-bottom:16px}.view-all-btn{padding:10px 18px;font-size:13px}.brief-roadmap-container{padding:0 16px}.brief-roadmap-track{gap:0}.brief-roadmap-node{min-width:auto;width:auto;height:auto;padding:0 12px}.brief-roadmap-circle{width:40px;height:40px}.brief-roadmap-day{font-size:10px}.brief-roadmap-label{font-size:11px;max-width:140px;line-height:1.4}.brief-roadmap-connector{min-width:40px;flex:0 0 40px}.lesson-card{padding:16px}.lesson-card-header{flex-direction:column;align-items:flex-start;gap:8px}.lesson-day-badge{padding:6px 12px;font-size:12px}.lesson-card-title{font-size:16px}.lesson-card-meta{font-size:13px}.lesson-meta span{font-size:12px}.start-lesson-btn,.continue-lesson-btn,.review-lesson-btn{padding:10px 20px;font-size:13px}}.learning-container{display:flex;height:100vh;height:100dvh;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#e8ecf1)}.lesson-sidebar{width:180px;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.3);padding:32px 16px;display:flex;flex-direction:column;gap:12px;box-shadow:4px 0 24px #00000008;transition:width .3s ease,padding .3s ease;flex-shrink:0;position:relative}.lesson-sidebar.nav-collapsed{width:48px;padding:32px 10px;overflow:hidden}.lesson-sidebar.nav-collapsed .lesson-nav-btn{display:none}.nav-collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffffb3;border:1px solid rgba(226,232,240,.7);border-radius:8px;cursor:pointer;color:#718096;transition:all .2s ease;align-self:flex-end;flex-shrink:0}.nav-collapse-btn:hover{background:#4299e11a;color:#4299e1;border-color:#4299e14d}.lesson-nav-btn{padding:14px 20px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px;font-family:inherit;font-size:15px;font-weight:500;color:#718096;cursor:pointer;transition:all .3s ease;text-align:center}.lesson-nav-btn:hover{background:#ffffffe6;border-color:#4299e14d;color:#4299e1}.lesson-nav-btn.active{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 4px 12px #4299e14d}.main-learning-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.learning-header{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.3);padding:20px 32px;box-shadow:0 4px 12px #00000005}.header-collapsed-bar{display:flex;align-items:center;gap:10px;padding:7px 16px;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #00000005}.header-collapsed-progress{flex:1;height:6px;background:#e2e8f099;border-radius:10px;overflow:hidden}.header-collapsed-fill{height:100%;background:#4299e1;border-radius:10px;transition:width .5s ease}.header-show-btn,.header-hide-btn{width:28px;height:28px;border:1px solid rgba(66,153,225,.3);border-radius:6px;background:#4299e114;color:#4299e1;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s}.header-show-btn:hover,.header-hide-btn:hover{background:#4299e12e}.header-content{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:12px}.header-content:before{content:"";display:block}.lesson-title{grid-column:2;text-align:center;font-size:20px;font-weight:600;color:#2d3748;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;padding:0 12px}.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0}.desktop-ai-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#fff9;border:1px solid rgba(255,255,255,.5);border-radius:8px;cursor:pointer;font-size:18px;line-height:1;transition:all .2s ease}.desktop-ai-toggle:hover{background:#4299e11a;border-color:#4299e14d}.tab-steps{display:flex;align-items:flex-start;justify-content:center;padding:12px 0 6px;overflow-x:auto;scrollbar-width:none;width:100%}.tab-steps::-webkit-scrollbar{display:none}.tab-step-item{display:contents}.tab-step{display:flex;flex-direction:column;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:0 8px;flex-shrink:0}.tab-step-circle{width:34px;height:34px;border-radius:50%;background:#e2e8f0cc;border:2px solid rgba(203,213,225,.7);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#94a3b8;transition:all .3s ease}.tab-step:hover .tab-step-circle{border-color:#93c5fd;color:#3b82f6}.tab-step.active .tab-step-circle{background:#4299e1;border-color:transparent;color:#fff;box-shadow:0 4px 14px #4299e180;transform:scale(1.15)}.tab-step.completed .tab-step-circle{background:#48bb78;border-color:transparent;color:#fff}.tab-step-label{font-size:12px;font-weight:500;color:#94a3b8;transition:color .2s ease;white-space:nowrap}.tab-step:hover .tab-step-label{color:#3b82f6}.tab-step.active .tab-step-label{color:#4299e1;font-weight:700}.tab-step.completed .tab-step-label{color:#48bb78}.tab-step-connector{flex:1;height:2px;background:#cbd5e1b3;margin-top:16px;align-self:flex-start;transition:background .4s ease;min-width:16px}.tab-step-connector.filled{background:#4299e1}.close-btn{width:36px;height:36px;background:#fff9;border:1px solid rgba(255,255,255,.5);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#718096}.close-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.progress-container{display:flex;align-items:center;gap:12px}.progress-bar{flex:1;height:6px;background:#e2e8f099;border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:#4299e1;border-radius:10px;transition:width .5s ease}.progress-text{font-size:13px;font-weight:600;color:#4299e1;min-width:36px;text-align:right}.day-progress-label{font-size:13px;font-weight:500;color:#718096;white-space:nowrap;min-width:100px}.points-chip{display:flex;align-items:center;gap:6px;padding:5px 14px;background:#fff9;border:1px solid rgba(255,255,255,.5);border-radius:999px;font-size:13px;font-weight:600;color:#2d3748;margin-right:8px;white-space:nowrap}.nav-btn.success{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-color:transparent;box-shadow:0 4px 12px #48bb784d}.nav-btn.success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #48bb7866}.nav-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.lesson-completed-badge{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#48bb781a;border:1px solid rgba(72,187,120,.3);border-radius:10px;font-size:14px;font-weight:600;color:#38a169}.content-area{flex:1;padding:32px;overflow-y:auto}.content-section{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:32px;box-shadow:0 4px 16px #0000000a;max-width:1000px;margin:0 auto;font-family:Open Sans,sans-serif;position:relative;--dynamic-font-size: 17px}.content-section h2{font-size:24px;font-weight:600;color:#2d3748;margin-bottom:20px}.content-section h3{font-size:18px;font-weight:600;color:#2d3748;margin-top:24px;margin-bottom:12px}.content-section p{font-size:var(--dynamic-font-size, 17px);line-height:1.8;color:#4a5568;margin-bottom:16px}.content-section ul,.content-section ol{margin-left:24px;margin-bottom:16px}.content-section li{font-size:var(--dynamic-font-size, 17px);line-height:1.8;color:#4a5568;margin-bottom:8px}.video-container{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#e0e7ff,#f3f4f6);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.video-lessons{display:flex;flex-direction:column;gap:24px}.video-lesson{background:#f8fafce6;border-radius:16px;padding:20px;box-shadow:0 4px 12px #0f172a0a}.video-lesson-title{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:12px}.video-lesson-meta{font-size:14px;color:#6b7280;margin-top:8px}.video-embed-wrapper{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#000}.video-embed-wrapper iframe{width:100%;height:100%;border:none;display:block}.video-segments{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.video-segment-chip{padding:6px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:#ffffffe6;font-size:13px;color:#4b5563;cursor:pointer;transition:all .2s ease}.video-segment-chip:hover{background:#eff6ff;border-color:#3b82f6;color:#4299e1}.video-segment-chip.active{background:#4299e1;border-color:transparent;color:#fff;box-shadow:0 3px 10px #3b82f659}.video-segment-description{font-size:14px;color:#4b5563;margin-top:10px}.video-placeholder{display:flex;flex-direction:column;align-items:center;gap:16px}.play-button{width:80px;height:80px;background:#4299e1;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #4299e166;color:#fff}.play-button:hover{transform:scale(1.1);box-shadow:0 12px 32px #4299e180}.example-box,.exercise-box{background:#4299e10d;border:2px solid rgba(66,153,225,.2);border-radius:12px;padding:24px;margin-top:24px}.text-lesson-card{background:#f8fafce6;border-radius:12px;padding:18px 20px;margin-top:20px;box-shadow:0 3px 10px #0f172a08}.text-lesson-title{font-size:17px;font-weight:600;color:#1f2937;margin-bottom:8px}.text-lesson-summary{font-size:var(--dynamic-font-size, 15px);line-height:1.7;color:#4b5563}.text-lesson-keypoints{margin:12px 0 0 20px}.text-lesson-keypoints li{list-style:disc}.text-lesson-sections{margin-top:12px}.text-lesson-section{margin-top:10px}.text-lesson-section-heading{font-size:15px;font-weight:600;color:#111827;margin-bottom:4px}.text-lesson-source{margin-top:12px;padding:12px 14px;border-radius:10px;background:#f3f4f6e6}.text-lesson-source-title{font-size:14px;font-weight:500;color:#1f2937}.text-lesson-source-meta{font-size:12px;color:#6b7280;margin-top:2px}.text-lesson-source-description{font-size:13px;color:#4b5563;margin-top:6px}.code-block{background:#1e293b;color:#e2e8f0;padding:20px;border-radius:12px;font-family:Courier New,monospace;font-size:14px;line-height:1.6;overflow-x:auto;margin:16px 0;white-space:pre-wrap}.exercise-title{font-size:18px;font-weight:600;color:#4299e1;margin-bottom:16px;display:flex;align-items:center;gap:8px}.answer-input{width:100%;min-height:120px;padding:16px;background:#fffc;border:1px solid rgba(226,232,240,.6);border-radius:10px;font-family:inherit;font-size:14px;color:#2d3748;resize:vertical;margin-bottom:16px}.answer-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.submit-btn{padding:12px 28px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #4299e14d;transition:all .3s ease}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.bottom-nav{padding:20px 32px;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.3);display:flex;justify-content:space-between;align-items:center}.nav-btn{padding:12px 24px;background:#fff9;border:1px solid rgba(255,255,255,.5);border-radius:10px;font-family:inherit;font-size:15px;font-weight:500;color:#718096;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.nav-btn:hover{background:#ffffffe6;border-color:#4299e14d;color:#4299e1}.nav-btn.primary{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 4px 12px #4299e14d}.nav-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.assistant-sidebar{width:360px;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid rgba(255,255,255,.3);display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000008;transition:width .3s ease;flex-shrink:0}.assistant-sidebar.ai-panel-collapsed{width:0;overflow:hidden;border-left:none;box-shadow:none}.assistant-header{padding:24px;border-bottom:1px solid rgba(226,232,240,.3)}.assistant-title{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.mascot{width:48px;height:48px;background:#4299e1;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 12px #4299e14d}.assistant-name{font-size:18px;font-weight:600;color:#2d3748}.assistant-subtitle{font-size:13px;color:#718096;padding-left:60px}.chat-area{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.chat-message{display:flex;gap:12px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.message-avatar.bot{background:#4299e1}.message-avatar.user{background:#e2e8f099}.message-content{flex:1;background:#f8fafccc;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.6;color:#2d3748}.chat-message.bot .message-content{background:#4299e114}.chat-input-area{padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom));border-top:1px solid rgba(226,232,240,.3)}.chat-input-container{display:flex;gap:8px;align-items:flex-end}.chat-input{flex:1;padding:12px 16px;background:#fffc;border:1.5px solid #4299e1;border-radius:10px;font-family:inherit;font-size:14px;color:#2d3748;resize:none;overflow:hidden;min-height:44px;max-height:120px;line-height:1.5;display:block}.chat-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.send-btn{width:44px;height:44px;flex-shrink:0;background:#4299e1;border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #4299e14d;color:#fff}.send-btn:hover{transform:scale(1.05)}.lesson-sidebar-toggle,.tab-menu-toggle,.tab-dropdown-mobile,.ai-chat-fab,.ai-chat-close-btn{display:none}@media (max-width: 768px){.nav-collapse-btn{display:none}}@media (max-width: 1200px){.desktop-ai-toggle{display:none}.assistant-sidebar.ai-panel-collapsed{width:360px;overflow:visible;border-left:1px solid rgba(255,255,255,.3)}}.lesson-sidebar-overlay,.ai-chat-overlay{display:none}@media (max-width: 1200px){.assistant-sidebar{position:fixed;right:-360px;top:0;height:100vh;height:100dvh;z-index:1001;transition:right .3s ease;background:#fffffff2}.assistant-sidebar.open{right:0}.ai-chat-fab{display:flex;align-items:center;justify-content:center;position:fixed;bottom:24px;right:24px;width:56px;height:56px;background:#4299e1;border:none;border-radius:50%;cursor:pointer;z-index:998;box-shadow:0 6px 20px #4299e166;transition:all .3s ease}.ai-chat-fab:hover{transform:scale(1.1);box-shadow:0 8px 28px #4299e180}.ai-chat-fab-icon{font-size:28px;line-height:1}.ai-chat-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#0000000d;border:none;border-radius:8px;cursor:pointer;color:#718096;transition:all .2s ease;margin-left:auto}.ai-chat-close-btn:hover{background:#ef44441a;color:#ef4444}.ai-chat-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:1000;animation:fadeInOverlay .2s ease}}@media (max-width: 768px){.lesson-sidebar{position:fixed;left:-180px;top:0;height:100vh;height:100dvh;z-index:1000;transition:left .3s ease;background:#fffffff2}.lesson-sidebar.open{left:0}.lesson-sidebar-toggle{display:flex;align-items:center;gap:6px;position:fixed;top:12px;left:12px;z-index:999;padding:8px 14px;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:10px;cursor:pointer;color:#4299e1;font-family:inherit;font-size:13px;font-weight:600;box-shadow:0 2px 12px #00000014;transition:all .2s ease}.lesson-sidebar-toggle:hover{background:#fffffff2}.lesson-sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:999;animation:fadeInOverlay .2s ease}.content-area{padding:56px 20px 20px}.learning-header{padding:16px 20px}.header-content{display:flex;align-items:center;gap:8px}.header-content:before{display:none}.lesson-title{grid-column:unset;flex:1;min-width:0;text-align:left;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0}.header-actions{grid-column:unset;flex:0 0 auto}.bottom-nav{padding:16px 20px}.nav-btn{padding:10px 16px;font-size:13px}.ai-chat-fab{bottom:80px;right:16px;width:50px;height:50px}.ai-chat-fab-icon{font-size:24px}.tab-steps{display:none!important}.tab-menu-toggle{display:flex;align-items:center;gap:5px;padding:6px 10px;background:#4299e11a;border:1px solid rgba(66,153,225,.3);border-radius:8px;font-family:inherit;font-size:13px;font-weight:600;color:#4299e1;cursor:pointer;transition:all .2s ease}.tab-menu-toggle:hover{background:#4299e12e}.tab-dropdown-mobile{display:flex;flex-direction:column;gap:8px;padding:12px 0 4px;animation:fadeInOverlay .15s ease}.tab-dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 16px;background:#ffffffd9;border:1px solid rgba(226,232,240,.7);border-radius:10px;font-family:inherit;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.tab-dropdown-item.active{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 3px 10px #4299e14d}.tab-dropdown-item.completed{border-color:#48bb7866}.tab-dropdown-circle{width:26px;height:26px;border-radius:50%;background:#e2e8f0cc;border:2px solid rgba(203,213,225,.7);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#94a3b8;flex-shrink:0}.tab-dropdown-item.active .tab-dropdown-circle{background:#ffffff40;border-color:#ffffff80;color:#fff}.tab-dropdown-item.completed .tab-dropdown-circle{background:#48bb78;border-color:transparent;color:#fff}.bottom-nav{padding-bottom:max(16px,env(safe-area-inset-bottom))}}@media (max-width: 480px){.header-content{display:flex;flex-direction:row;align-items:center;gap:6px}.header-content:before{display:none}.lesson-title{grid-column:unset;flex:1;text-align:left;font-size:14px;padding:0}.header-actions{grid-column:unset;gap:5px;flex-shrink:0}.tab-menu-toggle span{display:none}.tab-menu-toggle{padding:6px;min-width:32px;justify-content:center}.points-chip{font-size:11px;padding:4px 8px}.header-hide-btn,.close-btn{width:30px;height:30px}.learning-header{padding:52px 14px 12px}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.theory-section{margin-top:8px}.theory-introduction{font-size:var(--dynamic-font-size, 15px);line-height:1.8;color:#374151;margin-bottom:24px;padding:16px 20px;background:#4299e10d;border-left:4px solid #4299e1;border-radius:0 12px 12px 0}.concept-card{background:#f8fafce6;border-radius:12px;padding:20px;margin-top:16px;border:1px solid rgba(226,232,240,.6)}.concept-title{font-size:17px;font-weight:600;color:#1f2937;margin-bottom:10px}.concept-explanation{font-size:var(--dynamic-font-size, 15px);line-height:1.7;color:#4b5563;margin-bottom:12px}.concept-section-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin-bottom:6px}.concept-keypoints{list-style:none;margin:0 0 12px 4px;padding:0}.concept-keypoints li{position:relative;padding-left:20px;margin-bottom:4px;color:#4b5563;font-size:14px;line-height:1.6}.concept-keypoints li:before{content:"✓";position:absolute;left:0;color:#059669;font-weight:700}.concept-mistakes{list-style:none;margin:0 0 0 4px;padding:0}.concept-mistakes li{position:relative;padding-left:22px;padding-top:2px;padding-bottom:2px;color:#991b1b;font-size:14px;line-height:1.6}.concept-mistakes li:before{content:"⚠";position:absolute;left:0}.theory-summary{margin-top:20px;padding:16px 20px;background:#10b9810d;border-left:4px solid #10b981;border-radius:0 12px 12px 0;font-size:15px;line-height:1.7;color:#374151}.example-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.example-header h3{margin:0}.difficulty-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.difficulty-badge.basic{background:#10b9811a;color:#059669}.difficulty-badge.intermediate{background:#f59e0b1a;color:#d97706}.difficulty-badge.advanced{background:#ef44441a;color:#dc2626}.example-image{max-width:100%;height:auto;border-radius:10px;border:1px solid rgba(226,232,240,.6);margin:12px 0;display:block}.theory-image{max-width:100%;height:auto;border-radius:10px;border:1px solid rgba(226,232,240,.6);margin:14px 0;display:block}.concept-image{max-width:480px}.text-lesson-image{max-width:560px}.practice-requirements{margin:16px 0}.practice-requirement{display:flex;align-items:flex-start;gap:8px;padding:6px 0;color:#374151;font-size:15px;line-height:1.6}.practice-requirement:before{content:"✅";flex-shrink:0}.practice-hints{background:#f59e0b0d;border:1px solid rgba(245,158,11,.2);border-radius:10px;padding:16px;margin:16px 0}.practice-hints-title{font-size:14px;font-weight:600;color:#d97706;margin-bottom:8px}.practice-hint{display:flex;align-items:flex-start;gap:8px;padding:4px 0;color:#92400e;font-size:14px;line-height:1.6}.practice-hint:before{content:"💡";flex-shrink:0}.practice-estimated-time{font-size:14px;color:#6b7280;margin:12px 0 16px}.quiz-section{margin-top:32px;padding-top:24px;border-top:2px solid rgba(226,232,240,.6)}.quiz-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.quiz-title{font-size:18px;font-weight:600;color:#2d3748}.quiz-score{font-size:15px;font-weight:600;padding:6px 16px;border-radius:999px;background:#4299e1;color:#fff}.checkpoint-card{background:#f8fafce6;border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid rgba(226,232,240,.6);transition:border-color .3s ease}.checkpoint-card.correct{border-color:#10b981;background:#10b98108}.checkpoint-card.incorrect{border-color:#ef4444;background:#ef444408}.checkpoint-question{font-size:15px;font-weight:600;color:#1f2937;margin-bottom:12px}.checkpoint-options{display:flex;flex-direction:column;gap:8px}.checkpoint-option{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fffc;border:1px solid rgba(226,232,240,.6);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;color:#374151}.checkpoint-option:hover:not(.disabled){border-color:#4299e1;background:#4299e10d}.checkpoint-option.selected{border-color:#4299e1;background:#4299e114;font-weight:500}.checkpoint-option.correct-answer{border-color:#10b981;background:#10b98114;color:#065f46}.checkpoint-option.wrong-answer{border-color:#ef4444;background:#ef444414;color:#991b1b}.checkpoint-option.disabled{cursor:default}.checkpoint-option-radio{width:18px;height:18px;border-radius:50%;border:2px solid #cbd5e1;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.checkpoint-option.selected .checkpoint-option-radio{border-color:#4299e1;background:#4299e1}.checkpoint-option.correct-answer .checkpoint-option-radio{border-color:#10b981;background:#10b981}.checkpoint-option.wrong-answer .checkpoint-option-radio{border-color:#ef4444;background:#ef4444}.checkpoint-explanation{margin-top:10px;padding:10px 14px;background:#4299e10d;border-radius:8px;font-size:13px;line-height:1.6;color:#4b5563}.quiz-submit-btn{margin-top:16px;padding:12px 28px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #4299e14d;transition:all .3s ease}.quiz-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.quiz-submit-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.learning-header{padding:16px 20px}.learning-content{padding:24px 20px}.step-navigator{gap:8px;padding:0 12px}.step-node{min-width:56px;width:56px;height:56px}.step-day{font-size:11px}.step-label{font-size:10px;max-width:60px}.theory-image,.concept-image,.text-lesson-image,.example-image{max-width:100%!important;height:auto;margin:12px 0}.video-lesson iframe{width:100%;height:auto;aspect-ratio:16/9}}@media (max-width: 480px){.lesson-sidebar{display:none!important}.nav-collapse-btn{display:none}.lesson-nav-btn{white-space:nowrap}.learning-header{padding:12px 16px}.theory-image,.concept-image,.text-lesson-image,.example-image{max-width:100%!important;border-radius:8px;margin:10px 0}.example-box,.text-lesson,.video-lesson{padding:16px;margin-bottom:16px}.bottom-nav{padding:12px 16px;gap:8px}}.font-size-controls{position:absolute;top:32px;right:32px;display:flex;align-items:center;gap:8px;background:#ffffffe6;padding:6px 12px;border-radius:10px;border:1px solid rgba(226,232,240,.6);box-shadow:0 2px 8px #0000000d}.font-size-label{font-size:13px;color:#718096;font-weight:500;margin-right:4px}.font-size-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#4299e11a;border:1px solid rgba(66,153,225,.2);border-radius:6px;cursor:pointer;transition:all .2s ease;color:#4299e1;font-size:16px;font-weight:700}.font-size-btn:hover{background:#4299e133;border-color:#4299e1}.font-size-btn:active{transform:scale(.95)}.text-selection-toolbar{position:fixed;z-index:1000;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(226,232,240,.8);border-radius:12px;padding:8px;display:flex;align-items:center;gap:4px;box-shadow:0 8px 24px #0000001f;opacity:0;pointer-events:none;transition:opacity .2s ease}.text-selection-toolbar.visible{opacity:1;pointer-events:all}.toolbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff9;border:1px solid rgba(226,232,240,.6);border-radius:8px;cursor:pointer;transition:all .2s ease;color:#4a5568}.toolbar-btn:hover{background:#4299e11a;border-color:#4299e1;color:#4299e1}.toolbar-btn.bold{font-weight:700;font-size:16px}.toolbar-btn.underline{text-decoration:underline;font-size:16px}.toolbar-btn.highlight{background:linear-gradient(#ffeb3b4d,#ffeb3b4d)}.toolbar-btn.ai{background:#4299e1;color:#fff;border:none}.toolbar-btn.ai:hover{transform:scale(1.05);box-shadow:0 4px 12px #4299e14d}.toolbar-btn.undo{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.toolbar-btn.undo:hover{background:#ef444433;border-color:#ef4444;color:#dc2626}.toolbar-divider{width:1px;height:24px;background:#e2e8f099;margin:0 4px}.user-highlighted{background:linear-gradient(#ffeb3b66,#ffeb3b66);padding:2px 0;border-radius:3px}.user-bold{font-weight:700!important}.user-underline{text-decoration:underline;text-decoration-color:#4299e1;text-decoration-thickness:2px}.code-exercise{margin-top:12px}.code-exercise-toolbar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#1e293b;border-radius:10px 10px 0 0}.language-selector{padding:4px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#e2e8f0;font-size:13px;font-family:inherit;cursor:pointer}.language-selector option{background:#1e293b;color:#e2e8f0}.code-lang-badge{font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.code-editor{width:100%;min-height:220px;padding:16px;background:#1e293b;border:none;border-radius:0;font-family:Courier New,Fira Code,monospace;font-size:14px;line-height:1.6;color:#e2e8f0;resize:vertical;box-sizing:border-box;-moz-tab-size:2;tab-size:2;outline:none}.code-actions{display:flex;gap:8px;padding:8px 12px;background:#1e293b;border-radius:0 0 10px 10px;border-top:1px solid rgba(255,255,255,.06)}.run-btn{display:flex;align-items:center;gap:6px;padding:7px 18px;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:7px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #48bb7859}.run-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #48bb7873}.run-btn:disabled{opacity:.5;cursor:not-allowed}.code-output-panel{margin-top:12px;background:#1e293b0f;border:1px solid rgba(30,41,59,.15);border-radius:10px;overflow:hidden}.code-output-section{padding:10px 16px}.code-output-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#48bb78;margin-bottom:4px}.code-output-label.error{color:#fc8181}.code-output-text{font-family:Courier New,monospace;font-size:13px;color:#2d3748;white-space:pre-wrap;margin:0;line-height:1.5}.code-output-text.error{color:#c53030}.code-output-error{padding:12px 16px;color:#c53030;font-size:13px;font-weight:500}.code-output-status{padding:6px 16px;font-size:12px;color:#718096;border-top:1px solid rgba(0,0,0,.05)}.test-results{padding:12px 16px}.test-results-header{font-size:13px;font-weight:600;color:#2d3748;margin-bottom:10px}.test-case{display:flex;flex-direction:column;gap:4px;padding:8px 12px;border-radius:8px;margin-bottom:6px;font-size:13px}.test-case.pass{background:#48bb7814;border:1px solid rgba(72,187,120,.25)}.test-case.fail{background:#fc818114;border:1px solid rgba(252,129,129,.25)}.test-case-label{font-weight:600;color:#2d3748}.test-case.pass .test-case-label{color:#276749}.test-case.fail .test-case-label{color:#c53030}.test-case-detail{display:flex;flex-direction:column;gap:2px;font-size:12px;color:#718096;padding-left:16px}.test-case-detail code{background:#0000000f;padding:1px 4px;border-radius:3px;font-family:monospace}.stdin-panel{background:#1e293b;border-top:1px solid rgba(255,255,255,.07)}.stdin-panel--required{border-top:2px solid #f6ad55}.stdin-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 14px;background:transparent;border:none;color:#94a3b8;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;transition:color .15s ease}.stdin-toggle:hover{color:#e2e8f0}.stdin-chevron{font-size:10px;opacity:.7}.stdin-required-badge{display:inline-block;margin-left:7px;padding:1px 7px;background:#f6ad55;color:#1a202c;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;vertical-align:middle}.stdin-hint{padding:8px 14px;background:#f6ad551f;border-top:1px solid rgba(246,173,85,.3);color:#c05621;font-size:12px;line-height:1.6}.stdin-hint code{background:#00000014;padding:1px 4px;border-radius:3px;font-family:monospace;font-size:12px}.stdin-editor{width:100%;padding:10px 14px;background:#0f172a;border:none;border-top:1px solid rgba(255,255,255,.05);font-family:Courier New,monospace;font-size:13px;color:#cbd5e0;resize:vertical;box-sizing:border-box;outline:none;line-height:1.55}.stdin-editor::placeholder{color:#475569;font-style:italic}.stdin-warning-output{display:flex;align-items:flex-start;gap:12px;padding:18px 20px;background:#f6ad5514;border-left:4px solid #f6ad55}.stdin-warning-icon{font-size:28px;line-height:1}.stdin-warning-text{font-size:13px;line-height:1.7;color:#2d3748}.stdin-warning-text code{background:#00000012;padding:1px 5px;border-radius:3px;font-family:monospace;font-size:12px}.code-preview-wrap{border-top:1px solid rgba(0,0,0,.06)}.code-preview-header{padding:8px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#667eea;background:#667eea0f;border-bottom:1px solid rgba(102,126,234,.15)}.code-preview-iframe{width:100%;min-height:340px;border:none;display:block;background:#fff}.language-selector optgroup{color:#94a3b8;font-size:11px}.word-count{font-size:12px;color:#718096;margin-top:4px;margin-bottom:12px;text-align:right}.media-upload-zone{margin:12px 0}.upload-drop-area{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 20px;background:#4299e10a;border:2px dashed rgba(66,153,225,.3);border-radius:12px;cursor:pointer;transition:all .2s ease}.upload-drop-area:hover{background:#4299e114;border-color:#4299e1}.upload-icon{font-size:36px}.upload-label{font-size:13px;color:#718096;text-align:center}.file-preview{display:flex;flex-direction:column;gap:10px;padding:12px;background:#f8fafce6;border-radius:10px;border:1px solid rgba(226,232,240,.6)}.file-preview-img{max-width:100%;max-height:200px;object-fit:contain;border-radius:8px}.file-preview-video,.file-preview-audio{width:100%;border-radius:8px}.file-preview-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.file-preview-name{font-size:13px;font-weight:500;color:#2d3748;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-size{font-size:12px;color:#718096}.file-remove-btn{padding:4px 10px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:6px;font-size:12px;color:#c53030;cursor:pointer;transition:all .2s ease}.file-remove-btn:hover{background:#ef444433}.file-validation-error{margin-top:6px;padding:8px 12px;background:#fc81811a;border:1px solid rgba(252,129,129,.3);border-radius:8px;font-size:13px;color:#c53030}.exercise-submit-row{display:flex;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}.draft-indicator{font-size:12px;color:#a0aec0;font-style:italic}.submit-error{margin-top:8px;padding:8px 12px;background:#fc81811a;border:1px solid rgba(252,129,129,.3);border-radius:8px;font-size:13px;color:#c53030;width:100%}.submission-history{margin-top:28px;padding-top:20px;border-top:2px solid rgba(226,232,240,.6)}.submission-history-title{font-size:16px;font-weight:600;color:#2d3748;margin-bottom:12px}.submission-card{background:#f8fafce6;border-radius:10px;padding:14px 16px;margin-bottom:10px;border:1px solid rgba(226,232,240,.6)}.submission-card-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.submission-attempt{font-size:13px;font-weight:600;color:#2d3748}.submission-time{font-size:12px;color:#a0aec0;flex:1}.grading-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600}.grading-badge.graded{background:#4299e11f;color:#2b6cb0}.grading-badge.grading{background:#f59e0b1f;color:#b7791f}.grading-badge.pending{background:#a0aec026;color:#718096}.submission-feedback{margin-top:10px;padding-top:10px;border-top:1px solid rgba(226,232,240,.5);font-size:13px;color:#4a5568;display:flex;flex-direction:column;gap:6px}.submission-feedback-summary{color:#2d3748;line-height:1.6}.submission-feedback-strengths{color:#276749}.submission-feedback-improvements{color:#744210}.submission-points{font-size:13px;font-weight:700;color:#4299e1}.question-counter{font-size:12px;color:#a0aec0}.quick-actions{display:flex;flex-wrap:wrap;gap:6px;padding:10px 20px;border-top:1px solid rgba(226,232,240,.3)}.quick-action-chip{padding:5px 12px;background:#4299e114;border:1px solid rgba(66,153,225,.2);border-radius:999px;font-size:12px;font-weight:500;color:#4299e1;cursor:pointer;transition:all .2s ease;font-family:inherit}.quick-action-chip:hover:not(:disabled){background:#4299e126;border-color:#4299e1}.quick-action-chip:disabled{opacity:.4;cursor:not-allowed}.tutor-limit-banner{margin:0 20px 10px;padding:10px 14px;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:10px;font-size:13px;color:#92400e;text-align:center}.chat-code-block{position:relative;margin:8px 0;font-size:12px}.chat-code-lang{position:absolute;top:6px;right:10px;font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.inline-code{background:#0000000f;padding:1px 5px;border-radius:4px;font-family:monospace;font-size:13px}.streaming-dots{display:inline-flex;gap:3px;align-items:center}.streaming-dots span{display:inline-block;width:6px;height:6px;background:#4299e1;border-radius:50%;animation:dotBounce 1.2s ease-in-out infinite}.streaming-dots span:nth-child(2){animation-delay:.2s}.streaming-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:scale(.7);opacity:.5}40%{transform:scale(1);opacity:1}}@media (max-width: 768px){.font-size-controls{position:static;margin-bottom:12px;align-self:flex-end;padding:4px 8px}.content-section{display:flex;flex-direction:column;padding:20px 16px}.font-size-label{font-size:11px}.font-size-btn{width:24px;height:24px;font-size:14px}.text-selection-toolbar{padding:6px;gap:2px}.toolbar-btn{width:32px;height:32px;font-size:14px}}.view-correction-btn{margin-top:12px;padding:8px 16px;background:#4299e1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #4299e14d}.view-correction-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.view-correction-btn:active{transform:translateY(0)}.submission-feedback-preview{margin-top:12px;padding:12px;background:#f8fafc;border-radius:8px;border-left:3px solid #4299e1}.submission-feedback-preview .submission-feedback-summary{font-size:14px;color:#475569;line-height:1.5;margin-bottom:12px}.correction-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}.correction-modal{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeInUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.correction-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid #e2e8f0}.correction-modal-header h2{margin:0;font-size:22px;font-weight:700;color:#1e293b}.correction-modal-close{background:none;border:none;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;transition:all .2s ease}.correction-modal-close:hover{background:#f1f5f9;color:#1e293b}.correction-modal-content{flex:1;overflow-y:auto;padding:28px}.correction-score-section{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px;background:#4299e10d;border-radius:12px;margin-bottom:24px;color:#1e293b;border:2px solid rgba(66,153,225,.15)}.correction-score-badge{display:flex;flex-direction:column;gap:4px}.score-label{font-size:13px;font-weight:500;color:#64748b}.score-value{font-size:40px;font-weight:700;line-height:1;color:#4299e1}.score-points{font-size:14px;font-weight:600;margin-top:4px;color:#10b981}.correction-date{font-size:13px;color:#64748b;text-align:right}.correction-section{margin-bottom:28px}.correction-section-title{font-size:16px;font-weight:700;color:#1e293b;margin:0 0 12px;display:flex;align-items:center;gap:8px}.correction-summary{font-size:15px;color:#475569;line-height:1.6;padding:16px;background:#f8fafc;border-radius:10px;border-left:3px solid #4299e1}.correction-submission-content{background:#f8fafc;border-radius:10px;padding:16px;border:1px solid #e2e8f0}.correction-code-block{position:relative;background:#1e293b;border-radius:8px;overflow:hidden}.correction-code-lang{position:absolute;top:12px;right:12px;font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.correction-code-block pre{margin:0;padding:16px;overflow-x:auto}.correction-code-block code{font-family:Fira Code,Monaco,Courier New,monospace;font-size:13px;line-height:1.6;color:#e2e8f0}.correction-text-content{font-size:14px;color:#334155;line-height:1.7;white-space:pre-wrap;word-break:break-word}.correction-file-info{font-size:14px;color:#475569}.correction-file-details p{margin:8px 0}.correction-file-details strong{color:#1e293b;font-weight:600}.correction-media-note{margin-top:16px;padding:12px 16px;background:#dbeafe;border-left:3px solid #4299e1;border-radius:8px;display:flex;align-items:center;gap:10px;font-size:14px;color:#475569}.media-icon{font-size:24px}.correction-list{list-style:none;padding:0;margin:0}.correction-list-item{margin-bottom:8px;border-radius:8px;font-size:14px;line-height:1.6;position:relative;padding:12px 16px 12px 44px}.correction-list-item:before{content:"";position:absolute;left:16px;top:16px;width:6px;height:6px;border-radius:50%}.correction-strengths .correction-section-title{color:#059669}.strength-item{background:#d1fae5;border-left:3px solid #10b981;color:#065f46}.strength-item:before{background:#10b981}.correction-improvements .correction-section-title{color:#dc2626}.improvement-item{background:#fee2e2;border-left:3px solid #ef4444;color:#991b1b}.improvement-item:before{background:#ef4444}.correction-next-steps .correction-section-title{color:#2563eb}.correction-next-steps-content{padding:16px;background:#dbeafe;border-radius:10px;border-left:3px solid #3b82f6;font-size:14px;color:#1e40af;line-height:1.6}.correction-modal-footer{padding:20px 28px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}.correction-close-btn{padding:10px 24px;background:#f1f5f9;color:#475569;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.correction-close-btn:hover{background:#e2e8f0;color:#1e293b}@media (max-width: 768px){.correction-modal{max-height:95vh;margin:10px}.correction-modal-header{padding:20px}.correction-modal-header h2{font-size:18px}.correction-modal-content{padding:20px}.correction-score-section{flex-direction:column;align-items:flex-start}.score-value{font-size:28px}.correction-date{text-align:left}.correction-section-title{font-size:15px}.correction-list-item{padding:10px 12px 10px 36px;font-size:13px}.correction-list-item:before{left:12px;top:14px}}@keyframes badgeUnlock{0%{transform:scale(.3) translateY(-100px);opacity:0}50%{transform:scale(1.1) translateY(0)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}@keyframes spin{0%{transform:rotate(0) scale(.5)}50%{transform:rotate(180deg) scale(1.2)}to{transform:rotate(360deg) scale(1)}}.content-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1428b8;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9000;display:flex;align-items:center;justify-content:center;animation:fadeIn .25s ease}.content-loading-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:48px 40px 40px;max-width:400px;width:90%;text-align:center;box-shadow:0 32px 80px #0000004d,0 0 0 1px #fff9;animation:cardPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes cardPop{0%{transform:scale(.85) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.content-loading-spinner{position:relative;width:72px;height:72px;margin:0 auto 24px}.content-loading-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid rgba(66,153,225,.15);border-top-color:#4299e1;border-right-color:#667eea;animation:ringRotate 1s linear infinite}@keyframes ringRotate{to{transform:rotate(360deg)}}.content-loading-emoji{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:28px;animation:emojiBounce 2s ease-in-out infinite}@keyframes emojiBounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.content-loading-title{font-size:20px;font-weight:700;color:#1a202c;margin:0 0 10px}.content-loading-subtitle{font-size:14px;color:#718096;margin:0 0 28px;line-height:1.6}.content-loading-steps{display:flex;flex-direction:column;gap:10px;text-align:left}.content-loading-step{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:#718096;padding:10px 14px;border-radius:10px;background:#4299e10f;transition:all .3s ease}.content-loading-step.active{color:#4299e1;background:#4299e11f}.content-loading-step.done{color:#38a169;background:#38a16914}.step-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}.content-loading-step.active .step-dot{animation:dotPulse 1s ease-in-out infinite}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}.lesson-complete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f121eb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:lcOverlayIn .25s ease both}@keyframes lcOverlayIn{0%{opacity:0}to{opacity:1}}.lesson-complete-modal{position:relative;background:#ffffffeb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:20px;padding:40px 36px 32px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;overflow-x:hidden;text-align:center;box-shadow:0 16px 48px #0000001a,0 4px 16px #0000000f;animation:lcModalPop .45s cubic-bezier(.34,1.56,.64,1) both;scrollbar-width:thin;scrollbar-color:rgba(113,128,150,.3) transparent}@keyframes lcModalPop{0%{transform:scale(.82) translateY(40px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.lc-confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.lc-dot{position:absolute;width:10px;height:10px;border-radius:50%;animation:lcDotFall 2.2s ease-in forwards;opacity:0}.lc-dot-1{background:#3b82f6;left:8%;animation-delay:.05s}.lc-dot-2{background:#f59e0b;left:18%;animation-delay:.18s}.lc-dot-3{background:#22c55e;left:32%;animation-delay:.08s}.lc-dot-4{background:#a855f7;left:50%;animation-delay:.25s}.lc-dot-5{background:#ef4444;left:66%;animation-delay:.12s}.lc-dot-6{background:#f97316;left:80%;animation-delay:.3s}.lc-dot-7{background:#06b6d4;left:90%;animation-delay:.2s}.lc-dot-8{background:#3b82f6;left:12%;animation-delay:.4s;width:7px;height:7px}.lc-dot-9{background:#f59e0b;left:26%;animation-delay:.35s;width:8px;height:8px;border-radius:2px}.lc-dot-10{background:#22c55e;left:44%;animation-delay:.5s;width:6px;height:6px}.lc-dot-11{background:#a855f7;left:58%;animation-delay:.15s;width:9px;height:9px;border-radius:2px}.lc-dot-12{background:#ef4444;left:72%;animation-delay:.45s;width:7px;height:7px}.lc-dot-13{background:#f97316;left:85%;animation-delay:.28s;width:8px;height:8px}.lc-dot-14{background:#06b6d4;left:5%;animation-delay:.55s;width:6px;height:6px}.lc-dot-15{background:#3b82f6;left:38%;animation-delay:.6s;width:10px;height:10px}.lc-dot-16{background:#f59e0b;left:54%;animation-delay:.22s;width:8px;height:8px;border-radius:2px}.lc-dot-17{background:#22c55e;left:76%;animation-delay:.48s;width:7px;height:7px}.lc-dot-18{background:#a855f7;left:94%;animation-delay:.38s;width:9px;height:9px}@keyframes lcDotFall{0%{transform:translateY(-20px) rotate(0);opacity:1}80%{opacity:1}to{transform:translateY(420px) rotate(540deg);opacity:0}}.lc-trophy{font-size:64px;line-height:1;margin-bottom:12px;animation:lcTrophyBounce .7s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes lcTrophyBounce{0%{transform:scale(0) rotate(-15deg)}to{transform:scale(1) rotate(0)}}.lc-title{font-size:22px;font-weight:800;color:#1e293b;margin:0 0 8px;line-height:1.25}.lc-subtitle{font-size:14px;color:#475569;margin:0 0 24px;line-height:1.55}.lc-stats{display:flex;align-items:center;justify-content:center;gap:0;background:#fff9;border:1px solid rgba(255,255,255,.4);border-radius:14px;padding:16px 0;margin-bottom:20px;box-shadow:0 2px 8px #0000000a}.lc-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.lc-stat-divider{width:1px;height:40px;background:#71809633}.lc-stat-value{font-size:22px;font-weight:800;color:#4299e1;line-height:1}.lc-stat-label{font-size:11px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.lc-progress-wrap{margin-bottom:20px;text-align:left}.lc-progress-bar{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin-bottom:6px}.lc-progress-fill{height:100%;border-radius:999px;background:#4299e1;transition:width .8s cubic-bezier(.22,1,.36,1)}.lc-progress-label{font-size:12px;color:#64748b;font-weight:500}.lc-projection{display:flex;align-items:flex-start;gap:10px;background:#fffbeb;border:1.5px solid #fde68a;border-radius:12px;padding:14px 16px;margin-bottom:16px;text-align:left}.lc-projection-icon{font-size:20px;flex-shrink:0;line-height:1.4}.lc-projection p{font-size:13.5px;color:#78350f;margin:0;line-height:1.55}.lc-projection strong{color:#92400e}.lc-week-preview{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:14px;padding:16px 18px;margin-bottom:16px;text-align:left}.lc-week-preview-header{display:flex;align-items:center;gap:8px;font-size:13.5px;color:#1e3a5f;font-weight:600;margin-bottom:12px}.lc-week-cal-icon{font-size:18px;flex-shrink:0}.lc-week-preview-header strong{color:#16a34a}.lc-week-projects{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.lc-week-project-item{display:flex;align-items:flex-start;gap:10px;background:#ffffffb3;border-radius:10px;padding:10px 12px;border:1px solid rgba(187,247,208,.6)}.lc-week-proj-icon{font-size:20px;flex-shrink:0;line-height:1.3}.lc-week-proj-text{display:flex;flex-direction:column;gap:2px}.lc-week-proj-title{font-size:13px;font-weight:700;color:#1e293b;line-height:1.3}.lc-week-proj-desc{font-size:12px;color:#475569;line-height:1.45}.lc-encourage{font-size:13px;color:#64748b;margin:0 0 28px;line-height:1.5}.lc-actions{display:flex;flex-direction:column;gap:10px}.lc-actions-top-row{display:flex;gap:10px}.lc-btn-secondary{flex:1;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.5);background:#fff9;color:#718096;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .18s,color .18s,border-color .18s}.lc-btn-secondary:hover{background:#ffffffe6;border-color:#4299e14d;color:#4299e1}.lc-btn-primary{flex:1;padding:12px 14px;border-radius:10px;border:none;background:#4299e1;color:#fff;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:0 4px 12px #4299e14d;transition:transform .18s,box-shadow .18s}.lc-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.lc-btn-next{width:100%;padding:13px 16px;border-radius:10px;border:none;background:#38a169;color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:0 4px 12px #38a1694d;transition:transform .18s,box-shadow .18s}.lc-btn-next:hover{transform:translateY(-2px);box-shadow:0 6px 16px #38a16966}@media (max-width: 520px){.lesson-complete-modal{padding:28px 18px 22px;border-radius:20px;max-height:92vh}.lc-trophy{font-size:52px}.lc-title{font-size:19px}.lc-actions-top-row{flex-direction:column}.lc-stat-value{font-size:18px}}.skill-overview-page{width:100%}.back-btn{display:inline-flex;align-items:center;gap:8px;color:#4299e1;font-size:14px;font-weight:500;background:none;border:none;cursor:pointer;margin-bottom:24px;transition:all .3s ease;font-family:inherit;padding:0}.back-btn:hover{gap:12px}.overview-hero{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:20px;overflow:hidden;box-shadow:0 4px 16px #0000000a;margin-bottom:32px}.overview-hero-image{width:100%;height:240px;position:relative;overflow:hidden}.overview-hero-image img{width:100%;height:100%;object-fit:cover}.hero-overlay{position:absolute;bottom:16px;left:16px;display:flex;gap:10px}.hero-category,.hero-difficulty{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.hero-category{background:#4299e1d9;color:#fff}.hero-difficulty{background:#ffffffd9;color:#2d3748}.overview-hero-content{padding:28px 32px}.overview-title{font-size:32px;font-weight:700;color:#2d3748;margin-bottom:16px;letter-spacing:-.5px}.overview-quick-info{display:flex;gap:24px;flex-wrap:wrap}.quick-info-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#718096;font-weight:500}.quick-info-item svg{color:#4299e1}.overview-section{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:20px;padding:28px 32px;margin-bottom:24px;box-shadow:0 4px 16px #0000000a}.overview-section-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.overview-section-header svg{color:#4299e1}.overview-section-header h2{font-size:20px;font-weight:600;color:#2d3748}.overview-description{font-size:15px;color:#4a5568;line-height:1.8}.benefits-list{display:flex;flex-direction:column;gap:16px}.benefit-item{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:#4299e10f;border:1px solid rgba(66,153,225,.12);border-radius:12px;transition:all .3s ease}.benefit-item:hover{border-color:#4299e140;transform:translate(4px)}.benefit-item svg{color:#4299e1;flex-shrink:0;margin-top:2px}.benefit-item span{font-size:14px;color:#4a5568;line-height:1.6}.timeline{display:flex;flex-direction:column}.timeline-item{display:flex;gap:20px}.timeline-marker{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.timeline-dot{width:14px;height:14px;border-radius:50%;background:#4299e1;box-shadow:0 0 0 4px #4299e126;flex-shrink:0}.timeline-line{width:2px;flex:1;background:#4299e133;min-height:40px}.timeline-content{padding-bottom:28px;padding-top:0}.timeline-item:last-child .timeline-content{padding-bottom:0}.timeline-week{display:inline-block;font-size:13px;font-weight:600;color:#4299e1;background:#4299e11a;padding:4px 12px;border-radius:6px;margin-bottom:8px}.timeline-topic{font-size:14px;color:#4a5568;line-height:1.6}.overview-cta{display:flex;justify-content:center;padding:16px 0 32px}.start-learning-btn{display:inline-flex;align-items:center;gap:12px;padding:18px 48px;background:#4299e1;color:#fff;border:none;border-radius:14px;font-family:inherit;font-size:17px;font-weight:600;cursor:pointer;box-shadow:0 4px 20px #4299e166;transition:all .3s ease}.start-learning-btn:hover{transform:translateY(-3px);box-shadow:0 8px 28px #4299e180}.not-found{text-align:center;padding:60px 20px}.not-found h2{font-size:24px;font-weight:600;color:#2d3748;margin-bottom:8px}.not-found p{font-size:15px;color:#718096}.loading-state p{font-size:15px;color:#718096}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;min-height:400px}.error-state svg{color:#ef4444}.error-state h3{font-size:20px;font-weight:600;color:#2d3748;margin:0}.error-state p{font-size:15px;color:#718096;margin:0}.retry-btn{margin-top:8px;padding:10px 24px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4299e14d}.hero-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:96px;font-weight:700;color:#4299e133;background:linear-gradient(135deg,#e0e7ff,#f3f4f6)}.enrollment-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:20px;color:#10b981;font-size:13px;font-weight:500;margin-top:16px}.prerequisites-list{display:flex;flex-direction:column;gap:12px}.prerequisite-item{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:#4a5568;line-height:1.6}.prerequisite-bullet{color:#4299e1;font-weight:700;font-size:18px;flex-shrink:0}.tools-list{display:flex;flex-wrap:wrap;gap:12px}.tool-item{padding:10px 16px;background:#4299e11a;border:1px solid rgba(66,153,225,.2);border-radius:8px;font-size:14px;color:#2d3748;font-weight:500}.start-learning-btn.enrolled{background:linear-gradient(135deg,#10b981,#059669)}.start-learning-btn.enrolled:hover{box-shadow:0 8px 24px #10b9814d}.start-learning-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.start-learning-btn:disabled:hover{transform:none;box-shadow:0 4px 20px #4299e166}.overview-cta{display:flex;flex-direction:column;align-items:center;padding:16px 0 32px}.enrolled-note{font-size:14px;color:#718096;text-align:center;margin-top:12px}@media (max-width: 768px){.overview-hero-image{height:180px}.overview-hero-content{padding:20px 24px}.overview-title{font-size:26px}.overview-quick-info{gap:16px}.overview-section{padding:20px 24px}.start-learning-btn{width:100%;justify-content:center;padding:16px 32px}.questionnaire-modal{max-width:95%;max-height:90vh;overflow-y:auto}.option-group{flex-direction:column}.option-btn{width:100%}.questionnaire-actions{flex-direction:column;gap:12px}.questionnaire-btn{width:100%;justify-content:center}.plan-preview-stats{flex-direction:column;gap:12px}.plan-stat{width:100%}}.questionnaire-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.questionnaire-modal{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:24px;max-width:600px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000026;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.questionnaire-header{display:flex;justify-content:space-between;align-items:flex-start;padding:32px 32px 24px;border-bottom:1px solid rgba(66,153,225,.1)}.questionnaire-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 4px;letter-spacing:-.5px}.questionnaire-subtitle{font-size:14px;color:#718096;margin:0}.questionnaire-close{background:#4299e11a;border:none;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4299e1;transition:all .3s ease;flex-shrink:0}.questionnaire-close:hover{background:#4299e133;transform:rotate(90deg)}.questionnaire-progress-container{padding:20px 32px;display:flex;align-items:center;gap:16px}.questionnaire-progress-bar{flex:1;height:8px;background:#4299e11a;border-radius:10px;overflow:hidden}.questionnaire-progress-fill{height:100%;background:#4299e1;border-radius:10px;transition:width .4s ease}.questionnaire-progress-text{font-size:13px;font-weight:600;color:#4299e1;white-space:nowrap}.questionnaire-step{padding:24px 32px 32px;min-height:300px}.step-title{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 28px;text-align:center}.question-group{margin-bottom:28px}.question-label{display:block;font-size:15px;font-weight:600;color:#2d3748;margin-bottom:12px}.option-group{display:flex;gap:12px;flex-wrap:wrap}.option-btn{flex:1;min-width:120px;padding:14px 20px;background:#4299e10d;border:2px solid rgba(66,153,225,.2);border-radius:12px;font-size:14px;font-weight:500;color:#4a5568;cursor:pointer;transition:all .3s ease;font-family:inherit}.option-btn:hover{background:#4299e11a;border-color:#4299e166;transform:translateY(-2px)}.option-btn.selected{background:#4299e1;border-color:#4299e1;color:#fff;box-shadow:0 4px 12px #4299e14d}.text-input{width:100%;padding:14px 16px;background:#4299e10d;border:2px solid rgba(66,153,225,.2);border-radius:12px;font-size:14px;color:#2d3748;font-family:inherit;transition:all .3s ease}.text-input:focus{outline:none;border-color:#4299e1;background:#4299e114}.text-input::placeholder{color:#a0aec0}.review-section{background:#4299e10d;border:1px solid rgba(66,153,225,.15);border-radius:16px;padding:20px;margin-bottom:20px}.review-subtitle{font-size:16px;font-weight:600;color:#2d3748;margin:0 0 16px}.review-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(66,153,225,.1)}.review-item:last-child{border-bottom:none;padding-bottom:0}.review-label{font-size:14px;color:#718096;font-weight:500}.review-value{font-size:14px;color:#2d3748;font-weight:600;text-transform:capitalize}.plan-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.plan-loading-content{text-align:center;max-width:400px}.plan-loading-spinner{color:#4299e1;animation:spin 1s linear infinite;margin:0 auto 24px}.plan-loading-title{font-size:22px;font-weight:600;color:#2d3748;margin:0 0 12px}.plan-loading-text{font-size:15px;color:#718096;line-height:1.6;margin:0}.plan-preview{display:flex;align-items:center;justify-content:center;min-height:400px}.plan-preview-content{text-align:center;max-width:450px}.plan-preview-icon{color:#10b981;margin:0 auto 24px;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.plan-preview-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 12px}.plan-preview-text{font-size:15px;color:#718096;line-height:1.6;margin:0 0 32px}.plan-preview-stats{display:flex;gap:16px;margin-bottom:32px}.plan-stat{flex:1;background:#4299e11a;border:1px solid rgba(66,153,225,.2);border-radius:12px;padding:16px}.plan-stat-label{display:block;font-size:12px;color:#718096;font-weight:500;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.plan-stat-value{display:block;font-size:24px;font-weight:700;color:#2d3748;text-transform:capitalize}.plan-start-btn{display:inline-flex;align-items:center;gap:12px;padding:16px 40px;background:#4299e1;color:#fff;border:none;border-radius:14px;font-family:inherit;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 20px #4299e166;transition:all .3s ease}.plan-start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #4299e180}.validation-error{display:flex;align-items:center;gap:10px;padding:14px 20px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#dc2626;font-size:14px;margin:0 32px 20px;animation:shake .4s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.validation-error svg{flex-shrink:0}.questionnaire-actions{display:flex;gap:16px;padding:20px 32px 32px;border-top:1px solid rgba(66,153,225,.1)}.questionnaire-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 28px;border:none;border-radius:12px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.questionnaire-btn.primary{background:#4299e1;color:#fff;box-shadow:0 4px 16px #4299e14d}.questionnaire-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4299e166}.questionnaire-btn.primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.questionnaire-btn.secondary{background:#4299e11a;color:#4299e1;border:1px solid rgba(66,153,225,.2)}.questionnaire-btn.secondary:hover{background:#4299e126;transform:translateY(-2px)}.plan-roadmap{display:flex;align-items:flex-start;justify-content:center;padding:24px 0;overflow-x:auto;scrollbar-width:none;width:100%;margin:16px 0}.plan-roadmap::-webkit-scrollbar{display:none}.plan-roadmap-item{display:contents}.plan-roadmap-node{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0;padding:0 12px}.plan-roadmap-circle{width:44px;height:44px;border-radius:50%;background:#e2e8f0cc;border:2px solid rgba(203,213,225,.7);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#94a3b8;transition:all .3s ease}.plan-roadmap-node.milestone .plan-roadmap-circle{background:#4299e1;border-color:transparent;color:#fff;box-shadow:0 4px 14px #4299e180;transform:scale(1.1)}.plan-roadmap-label{font-size:12px;font-weight:500;color:#64748b;text-align:center;max-width:140px;line-height:1.4;word-wrap:break-word;white-space:normal}.plan-roadmap-node.milestone .plan-roadmap-label{color:#4299e1;font-weight:600}.plan-roadmap-connector{flex:1;height:2px;background:#cbd5e1b3;margin-top:22px;align-self:flex-start;min-width:40px}.discovery-wrapper{width:100%;height:calc(100vh - 100px);display:flex;justify-content:center}.discovery-glass-container{width:100%;max-width:1600px;height:100%;display:flex;background:#fff6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 24px #0000000a;overflow:hidden;position:relative}.discovery-sidebar{width:260px;background:#fff9;border-right:1px solid rgba(255,255,255,.5);display:flex;flex-direction:column;transition:width .3s ease,transform .3s ease;flex-shrink:0;z-index:20}.discovery-sidebar.closed{width:0;overflow:hidden;border:none;padding:0}.sidebar-header{padding:16px}.new-chat-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffffb3;border:1px solid rgba(255,255,255,.6);border-radius:8px;color:#2d3748;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left}.new-chat-btn:hover{background:#ffffffe6;border-color:#4299e14d;box-shadow:0 2px 8px #0000000a}.sidebar-content{flex:1;padding:0 12px;overflow-y:auto}.sidebar-section{margin-bottom:24px}.sidebar-title{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;margin-bottom:12px;padding:0 8px}.history-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:#4a5568;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-item:hover{background:#ffffff80}.history-item.active{background:#4299e11a;color:#3182ce;font-weight:500}.history-item.recommendation{color:#2d3748}.history-item.recommendation svg{color:#ecc94b}.discovery-sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.5)}.user-profile{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;cursor:pointer;transition:all .2s ease}.user-profile:hover{background:#ffffff80}.user-avatar-sm{width:32px;height:32px;background:#4299e1;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600}.user-info{display:flex;flex-direction:column}.user-name{font-size:14px;font-weight:500;color:#2d3748}.user-plan{font-size:12px;color:#718096}.sidebar-toggle-btn{position:absolute;top:50%;left:260px;transform:translateY(-50%);width:24px;height:48px;background:#ffffffe6;border:1px solid rgba(255,255,255,.5);border-left:none;border-radius:0 8px 8px 0;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:25;color:#718096;box-shadow:2px 0 8px #0000000a;transition:left .3s ease,color .2s ease}.discovery-sidebar.closed~.sidebar-toggle-btn{left:0}.sidebar-toggle-btn:hover{background:#fff;color:#4299e1}.discovery-main{flex:1;display:flex;flex-direction:column;position:relative;background:#ffffff4d;min-width:0}.chat-header{padding:16px 24px;border-bottom:1px solid rgba(255,255,255,.5);display:flex;justify-content:center;align-items:center}.model-selector{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff9;border-radius:20px;font-size:14px;color:#4a5568;cursor:pointer;transition:all .2s ease}.model-selector:hover{background:#fffc}.model-icon{color:#4299e1}.model-name{font-weight:600}.model-version{color:#718096;font-size:12px;background:#0000000d;padding:2px 6px;border-radius:4px}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px;scroll-behavior:smooth}.chat-message{display:flex;gap:16px;max-width:800px;margin:0 auto;width:100%}.chat-message.user{flex-direction:row-reverse}.message-avatar{flex-shrink:0}.avatar-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.avatar-icon.assistant{background:#4299e1;color:#fff}.avatar-icon.user{background:#fffc;color:#4a5568;border:1px solid rgba(255,255,255,.5)}.message-content{display:flex;flex-direction:column;gap:4px;max-width:80%}.chat-message.user .message-content{align-items:flex-end}.message-bubble{padding:16px 20px;border-radius:16px;font-size:15px;line-height:1.6;color:#2d3748;background:#fffc;border:1px solid rgba(255,255,255,.5);box-shadow:0 2px 8px #00000005}.chat-message.user .message-bubble{background:#4299e1;color:#fff;border:none;box-shadow:0 4px 12px #4299e133}.chat-message.assistant .message-bubble{background:#fff;border-top-left-radius:4px;border:1px solid rgba(66,153,225,.3);box-shadow:0 4px 12px #4299e126}.chat-message.user .message-bubble{border-top-right-radius:4px}.message-time{font-size:11px;color:#a0aec0;padding:0 4px}.typing-dots{display:flex;gap:4px;padding:4px}.typing-dots span{width:6px;height:6px;background:#cbd5e0;border-radius:50%;animation:typing 1.4s infinite ease-in-out both}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-container{padding:24px;background:#fff6;border-top:1px solid rgba(255,255,255,.5)}.chat-input-wrapper{width:100%;margin:0;position:relative;display:flex;align-items:center;background:#fff;border:1px solid rgba(226,232,240,.8);border-radius:16px;padding:8px;box-shadow:0 4px 16px #0000000a;transition:all .3s ease}.chat-input-wrapper:focus-within{border-color:#4299e1;box-shadow:0 8px 24px #4299e11a;transform:translateY(-2px)}.chat-input{flex:1;border:none;background:transparent;padding:12px 16px;font-size:15px;color:#2d3748;font-family:inherit;min-height:48px}.chat-input:focus{outline:none}.send-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#4299e1;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease}.send-button:disabled{background:#cbd5e0;cursor:not-allowed;transform:none}.send-button:not(:disabled):hover{transform:scale(1.05);box-shadow:0 4px 12px #4299e14d}.input-footer{text-align:center;margin-top:12px}.input-footer p{font-size:12px;color:#a0aec0;margin:0}.chat-messages::-webkit-scrollbar,.sidebar-content::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb,.sidebar-content::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}.chat-messages::-webkit-scrollbar-track,.sidebar-content::-webkit-scrollbar-track{background:transparent}.empty-chat-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:.8}.discovery-logo-icon{width:64px;height:64px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#4299e1;box-shadow:0 8px 32px #4299e133}.empty-chat-state h2{font-size:24px;font-weight:600;color:#2d3748}.loading-state,.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:16px;color:#718096}.error-message{color:#e53e3e;flex-direction:row}.spinner{animation:spin 1s linear infinite;color:#4299e1}@media (max-width: 768px){.discovery-wrapper{height:calc(100vh - 80px)}.discovery-sidebar{position:absolute;height:100%;box-shadow:4px 0 24px #0000001a}.discovery-sidebar.closed{transform:translate(-100%)}.discovery-sidebar.closed~.sidebar-toggle-btn{left:0}}.roadmap-page{width:100%;max-width:900px;margin:0 auto;padding:0 20px 60px}.back-button{display:inline-flex;align-items:center;gap:8px;color:#4299e1;font-size:14px;font-weight:500;background:none;border:none;cursor:pointer;margin-bottom:32px;transition:all .3s ease;font-family:inherit;padding:0}.back-button:hover{gap:12px}.loading-state,.error-state{text-align:center;padding:60px 20px}.error-state h3{color:#2d3748;margin-bottom:16px}.error-state button{padding:12px 24px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.error-state button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.roadmap-header{text-align:center;margin-bottom:48px}.roadmap-title{font-size:32px;font-weight:700;color:#2d3748;margin-bottom:8px}.roadmap-subtitle{font-size:16px;color:#718096}.roadmap-track{position:relative;display:flex;flex-direction:column;gap:0}.roadmap-node-wrapper{display:flex;align-items:flex-start;gap:24px;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.roadmap-node-wrapper.visible{opacity:1;transform:translateY(0)}.roadmap-node-container{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.roadmap-node-circle{width:50px;height:50px;border-radius:50%;background:#e2e8f0cc;border:3px solid rgba(203,213,225,.7);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#94a3b8;transition:all .3s ease;z-index:2;position:relative}.roadmap-node-circle.milestone{background:#4299e1;border-color:transparent;color:#fff;box-shadow:0 6px 20px #4299e180;transform:scale(1.1)}.roadmap-node-circle.current{background:linear-gradient(135deg,#f59e0b,#f97316);border-color:transparent;color:#fff;box-shadow:0 6px 20px #f59e0b80;animation:pulse 2s infinite}.roadmap-node-circle.completed{background:#48bb78;border-color:transparent;color:#fff}@keyframes pulse{0%,to{transform:scale(1.1)}50%{transform:scale(1.15)}}.roadmap-node-connector{width:3px;height:80px;background:#cbd5e1b3;transition:background .4s ease;z-index:1}.roadmap-node-connector.filled{background:#4299e1}.roadmap-node-content{flex:1;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:20px 24px;margin-bottom:16px;box-shadow:0 4px 16px #0000000a;transition:all .3s ease}.roadmap-node-wrapper:hover .roadmap-node-content{box-shadow:0 6px 20px #00000014;transform:translate(4px)}.roadmap-node-day-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.roadmap-node-day{font-size:12px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.roadmap-difficulty-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;white-space:nowrap}.roadmap-node-milestone-badge{display:inline-block;padding:4px 12px;background:#4299e11a;color:#4299e1;border-radius:999px;font-size:12px;font-weight:600;margin-bottom:8px}.roadmap-node-title{font-size:18px;font-weight:600;color:#2d3748;margin-bottom:12px}.roadmap-node-subtopics{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.roadmap-node-subtopics li{font-size:14px;color:#4a5568;padding-left:16px;position:relative}.roadmap-node-subtopics li:before{content:"•";position:absolute;left:0;color:#4299e1;font-weight:700}.roadmap-continue-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #4299e14d;transition:all .3s ease;margin-top:16px}.roadmap-continue-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}@media (max-width: 768px){.roadmap-title{font-size:24px}.roadmap-subtitle{font-size:14px}.roadmap-node-wrapper{gap:16px}.roadmap-node-circle{width:40px;height:40px;font-size:12px}.roadmap-node-connector{height:60px}.roadmap-node-content{padding:16px 18px}.roadmap-node-title{font-size:16px}}.settings-page{padding:32px;min-height:100vh;background:#f5f7fa}.settings-container{max-width:1040px;margin:0 auto}.settings-page-header{display:flex;align-items:center;gap:14px;margin-bottom:28px;color:#4299e1}.settings-page-title{font-size:1.6rem;font-weight:700;color:#1a202c;margin:0}.settings-page-subtitle{font-size:.875rem;color:#718096;margin:0}.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}@media (max-width: 768px){.settings-page{padding:16px}.settings-layout{grid-template-columns:1fr}}.settings-nav{background:#fff;border-radius:16px;padding:8px;box-shadow:0 2px 8px #0000000d;position:sticky;top:24px}.settings-nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:none;border-radius:10px;cursor:pointer;font-size:.875rem;font-weight:500;color:#4a5568;text-align:left;transition:all .15s ease}.settings-nav-item:hover{background:#f7fafc;color:#2d3748}.settings-nav-item.active{background:#ebf8ff;color:#4299e1;font-weight:600}.settings-nav-arrow{margin-left:auto;opacity:0;transition:opacity .15s}.settings-notif-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.settings-nav-item:hover .settings-nav-arrow,.settings-nav-item.active .settings-nav-arrow{opacity:1}.settings-section{display:flex;flex-direction:column;gap:20px}.settings-section-title{font-size:1.25rem;font-weight:700;color:#1a202c;margin:0}.settings-section-sub{font-size:.875rem;color:#718096;margin:-12px 0 0}.settings-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d}.settings-card-title{font-size:.8125rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.05em;margin:0 0 16px}.settings-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 640px){.settings-form-grid{grid-template-columns:1fr}}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-field.full-width{grid-column:1 / -1}.settings-field label{font-size:.8125rem;font-weight:600;color:#4a5568}.settings-field input,.settings-field textarea{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.9rem;color:#2d3748;font-family:inherit;background:#fff;transition:border-color .15s;resize:vertical}.settings-field input:focus,.settings-field textarea:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.settings-field input.readonly{background:#f7fafc;color:#a0aec0;cursor:default}.settings-field-hint{font-size:.78rem;color:#a0aec0}.settings-pw-field{position:relative}.settings-pw-field input{width:100%;padding-right:40px}.settings-pw-eye{position:absolute;top:50%;right:10px;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px}.settings-pw-eye:hover{color:#4a5568}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-row-label{font-size:.9rem;font-weight:500;color:#2d3748;margin:0 0 2px}.settings-row-sub{font-size:.8125rem;color:#718096;margin:0}.settings-toggle{position:relative;width:44px;height:24px;border-radius:999px;border:none;background:#e2e8f0;cursor:pointer;transition:background .2s;flex-shrink:0}.settings-toggle.on{background:#4299e1}.settings-toggle.disabled{opacity:.5;cursor:not-allowed}.settings-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.settings-toggle.on .settings-toggle-thumb{transform:translate(20px)}.settings-radio-group{display:flex;flex-wrap:wrap;gap:10px}.settings-radio-opt{display:flex;flex-direction:column;align-items:flex-start;padding:10px 16px;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;font-size:.875rem;font-weight:500;color:#4a5568;transition:all .15s;text-align:left;min-width:120px}.settings-radio-opt:hover{border-color:#bee3f8;background:#f0f8ff}.settings-radio-opt.selected{border-color:#4299e1;background:#ebf8ff;color:#2b6cb0;font-weight:600}.settings-radio-desc{font-size:.75rem;font-weight:400;color:#a0aec0;margin-top:2px}.settings-radio-opt.selected .settings-radio-desc{color:#63b3ed}.settings-save-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:10px;background:#4299e1;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;margin-top:4px}.settings-save-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.settings-save-btn:disabled{opacity:.7;cursor:not-allowed}.settings-save-btn.saved{background:linear-gradient(135deg,#48bb78,#38a169)}.settings-error{font-size:.8125rem;color:#e53e3e;background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;padding:8px 12px;margin:0}.settings-avatar-row{display:flex;align-items:center;gap:20px}.settings-avatar{position:relative;width:80px;height:80px;border-radius:50%;background:#4299e1;display:flex;align-items:center;justify-content:center;color:#fff;overflow:hidden;flex-shrink:0}.settings-avatar img{width:100%;height:100%;object-fit:cover}.settings-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .2s;border-radius:50%}.settings-avatar:hover .settings-avatar-overlay{opacity:1}.settings-avatar-info p{font-size:.8125rem;color:#718096;margin:0;line-height:1.5}.settings-skills-loading{display:flex;align-items:center;gap:12px;color:#718096;padding:40px;justify-content:center}.settings-empty{background:#fff;border-radius:16px;padding:48px 24px;text-align:center;box-shadow:0 2px 8px #0000000d;color:#a0aec0;display:flex;flex-direction:column;align-items:center;gap:12px}.settings-empty p{font-size:.9rem;margin:0}.settings-cta-btn{padding:10px 20px;background:#4299e1;color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.settings-cta-btn:hover{opacity:.9}.settings-skills-list{display:flex;flex-direction:column;gap:12px}.settings-skill-card{background:#fff;border-radius:14px;padding:18px 20px;box-shadow:0 2px 8px #0000000d;display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-skill-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.settings-skill-img{width:48px;height:48px;border-radius:10px;background:#4299e114;display:flex;align-items:center;justify-content:center;color:#4299e1;overflow:hidden;flex-shrink:0}.settings-skill-img img{width:100%;height:100%;object-fit:cover;border-radius:10px}.settings-skill-name{font-size:.9rem;font-weight:600;color:#2d3748;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.settings-skill-cat{font-size:.78rem;color:#a0aec0;margin:0 0 6px}.settings-skill-status{text-transform:capitalize;font-weight:600}.settings-skill-status.active{color:#48bb78}.settings-skill-status.paused{color:#ed8936}.settings-skill-status.completed{color:#4299e1}.settings-skill-status.planning{color:#a0aec0}.settings-skill-bar{height:4px;background:#f0f4f8;border-radius:4px;overflow:hidden;width:100%}.settings-skill-bar-fill{height:100%;border-radius:4px;background:#4299e1;transition:width .4s ease}.settings-pause-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1.5px solid;font-size:.8125rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.settings-pause-btn.pause{border-color:#ed8936;color:#ed8936;background:transparent}.settings-pause-btn.pause:hover{background:#fffaf0}.settings-pause-btn.resume{border-color:#48bb78;color:#48bb78;background:transparent}.settings-pause-btn.resume:hover{background:#f0fff4}.settings-pause-btn:disabled{opacity:.6;cursor:not-allowed}.settings-export-btn{display:inline-flex;align-items:center;gap:8px;margin-top:12px;padding:10px 20px;border:1.5px solid #4299e1;border-radius:10px;background:transparent;color:#4299e1;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.settings-export-btn:hover:not(:disabled){background:#ebf8ff}.settings-export-btn.done{border-color:#48bb78;color:#48bb78}.settings-export-btn:disabled{opacity:.6;cursor:not-allowed}.settings-danger-zone{border:1.5px solid #fed7d7;border-radius:12px;padding:20px;background:#fff5f5;display:flex;flex-direction:column;gap:14px}.settings-danger-header{display:flex;align-items:flex-start;gap:10px;color:#e53e3e}.settings-danger-header p{font-size:.875rem;color:#742a2a;margin:0;line-height:1.5}.settings-delete-trigger{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border:1.5px solid #fc8181;border-radius:8px;background:transparent;color:#c53030;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;align-self:flex-start}.settings-delete-trigger:hover{background:#fff5f5;border-color:#e53e3e}.settings-delete-confirm{display:flex;flex-direction:column;gap:10px}.settings-delete-input{padding:10px 14px;border:1.5px solid #fc8181;border-radius:8px;font-size:.875rem;color:#c53030;background:#fff;font-family:monospace;width:200px}.settings-delete-input:focus{outline:none;border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e26}.settings-delete-actions{display:flex;gap:10px}.settings-delete-cancel{padding:9px 18px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.settings-delete-cancel:hover{background:#f7fafc}.settings-delete-confirm-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border:none;border-radius:8px;background:#e53e3e;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.settings-delete-confirm-btn:hover:not(:disabled){opacity:.9}.settings-delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin .8s linear infinite}.payment-current-plan{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border-radius:14px;padding:16px 20px;box-shadow:0 2px 8px #0000000d;border-left:4px solid #4299e1}.payment-current-left{display:flex;align-items:center;gap:12px;color:#4299e1}.payment-current-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#718096;margin:0 0 2px}.payment-current-name{font-size:1rem;font-weight:700;color:#1a202c;margin:0;display:flex;align-items:center;gap:8px}.payment-trial-badge{font-size:.7rem;font-weight:700;background:#fed7aa;color:#c05621;padding:2px 8px;border-radius:999px}.payment-manage-btn{padding:8px 16px;background:none;border:1.5px solid #4299e1;border-radius:9px;color:#4299e1;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.payment-manage-btn:hover{background:#ebf8ff}.payment-plans-list{display:flex;flex-direction:column;gap:10px}.payment-plan-card{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000d;border:1.5px solid #e2e8f0;overflow:hidden;transition:border-color .2s,box-shadow .2s}.payment-plan-card:hover{border-color:var(--plan-border, rgba(66, 153, 225, .4));box-shadow:0 4px 14px #00000014}.payment-plan-card.current{border-color:var(--plan-accent, #4299e1);box-shadow:0 0 0 3px var(--plan-bg, rgba(66, 153, 225, .1))}.payment-plan-header{display:flex;align-items:center;gap:14px;width:100%;padding:16px 20px;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.payment-plan-header:hover{background:#fafbfc}.payment-plan-card.expanded .payment-plan-header{background:var(--plan-bg, rgba(66, 153, 225, .05));border-bottom:1px solid #f0f0f0}.payment-plan-icon{width:38px;height:38px;border-radius:10px;background:var(--plan-bg, rgba(66, 153, 225, .1));color:var(--plan-accent, #4299e1);display:flex;align-items:center;justify-content:center;flex-shrink:0}.payment-plan-header-info{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.payment-plan-name-row{display:flex;align-items:center;gap:8px}.payment-plan-name{font-size:.9375rem;font-weight:700;color:#1a202c}.payment-popular-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff;padding:2px 8px;border-radius:999px}.payment-active-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#dcfce7;color:#16a34a;padding:2px 8px;border-radius:999px}.payment-plan-price{font-size:1.125rem;font-weight:800;color:var(--plan-accent, #4299e1);white-space:nowrap}.payment-plan-interval{font-size:.8rem;font-weight:500;color:#a0aec0}.payment-chevron{color:#a0aec0;flex-shrink:0;transition:transform .25s ease}.payment-chevron.open{transform:rotate(90deg)}.payment-plan-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:18px}.payment-features-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.payment-feature-item{display:flex;align-items:flex-start;gap:8px;font-size:.875rem;color:#4a5568}.payment-feature-check{color:var(--plan-accent, #4299e1);flex-shrink:0;margin-top:2px}.payment-plan-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 640px){.payment-plan-meta{grid-template-columns:1fr 1fr}}.payment-meta-item{background:#f7fafc;border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.payment-meta-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#a0aec0}.payment-meta-value{font-size:.9375rem;font-weight:700;color:#2d3748}.payment-select-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;background:var(--plan-accent, #4299e1);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;align-self:flex-start}.payment-select-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.payment-select-btn:disabled{opacity:.6;cursor:not-allowed}.payment-current-indicator{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:600;color:var(--plan-accent, #4299e1);background:var(--plan-bg, rgba(66, 153, 225, .1));padding:9px 16px;border-radius:10px;align-self:flex-start}.portfolio-page{width:100%}.portfolio-page .page-header{margin-bottom:32px}.portfolio-page .page-title{font-size:32px;font-weight:600;color:#2d3748;margin-bottom:8px;letter-spacing:-.5px}.portfolio-page .page-subtitle{font-size:15px;color:#718096;font-weight:400}.pf-success-banner{display:flex;align-items:center;gap:8px;background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;border-radius:12px;padding:12px 16px;font-size:14px;font-weight:500;margin-bottom:20px}.pf-error-banner{display:flex;align-items:center;gap:8px;background:#fff5f5;border:1px solid #fed7d7;color:#c53030;border-radius:12px;padding:12px 16px;font-size:14px;font-weight:500;margin-bottom:20px}.pf-banner-close{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;opacity:.6;display:flex;align-items:center;padding:2px;border-radius:4px}.pf-banner-close:hover{opacity:1}.pf-tabs{display:flex;gap:8px;margin-bottom:28px}.pf-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:12px;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:all .3s ease;font-family:inherit}.pf-tab:hover{background:#ffffffe6;border-color:#4299e14d}.pf-tab.active{background:#4299e1;color:#fff;border-color:transparent;box-shadow:0 4px 12px #4299e14d}.pf-tab-count{background:#ffffff40;border-radius:20px;padding:1px 8px;font-size:11px;font-weight:600}.pf-tab.active .pf-tab-count{background:#ffffff4d}.pf-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;color:#718096;font-size:14px}.loading-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#4299e1;border-radius:50%;animation:spin .7s linear infinite}.spinning{animation:spin .7s linear infinite}.pf-content{width:100%}.pf-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 20px;text-align:center;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 4px 16px #0000000a}.pf-empty-icon{width:80px;height:80px;background:#4299e1;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;opacity:.8}.pf-empty h3{font-size:22px;font-weight:600;color:#2d3748;margin:0}.pf-empty p{font-size:15px;color:#718096;max-width:400px;margin:0;line-height:1.6}.pf-cta-btn{display:flex;align-items:center;gap:8px;padding:12px 28px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit;box-shadow:0 4px 12px #4299e14d}.pf-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4299e166}.pf-cta-btn.secondary{background:#fff;color:#4299e1;border:1.5px solid #e2e8f0;box-shadow:0 2px 8px #0000000d}.pf-cta-btn.secondary:hover{background:#f7fafc;border-color:#bee3f8}.pf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.pf-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:20px;padding:24px;box-shadow:0 4px 16px #0000000a;transition:all .3s ease;display:flex;flex-direction:column;gap:14px}.pf-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.pf-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.pf-card-left{display:flex;align-items:center;gap:12px}.pf-card-emoji{font-size:28px;line-height:1}.pf-card-title{font-size:17px;font-weight:600;color:#2d3748;margin:0 0 3px}.pf-card-category{font-size:12px;color:#718096;margin:0;font-weight:500}.pf-visibility-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;white-space:nowrap}.pf-visibility-badge.public{background:#ebf8ff;color:#2b6cb0}.pf-visibility-badge.private{background:#f0fff4;color:#276749}.pf-card-headline{font-size:13px;color:#4a5568;font-style:italic;margin:0;line-height:1.5;padding:10px 12px;background:#f7fafc;border-radius:8px;border-left:3px solid #bee3f8}.pf-card-stats{display:flex;gap:8px;flex-wrap:wrap}.pf-card-stat{display:flex;align-items:center;gap:4px;font-size:12px;color:#718096;background:#f7fafc;padding:4px 10px;border-radius:20px}.pf-card-tags{display:flex;flex-wrap:wrap;gap:6px}.pf-card-footer{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}.pf-card-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;border:none;font-family:inherit;transition:all .2s}.pf-card-btn.primary{background:#4299e1;color:#fff;box-shadow:0 2px 8px #4299e140}.pf-card-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4299e159}.pf-card-btn.secondary{background:#fff;color:#4a5568;border:1px solid #e2e8f0}.pf-card-btn.secondary:hover{background:#f7fafc}.pf-card-btn.danger{background:#fff5f5;color:#c53030;border:1px solid #fed7d7}.pf-card-btn.danger:hover{background:#fff}.pf-card-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.pf-card-date{font-size:11px;color:#a0aec0;margin:0}.pf-tag{display:inline-block;padding:4px 12px;background:#ebf8ff;color:#2b6cb0;border-radius:20px;font-size:12px;font-weight:500}.pf-mini-tag{display:inline-block;padding:3px 8px;background:#f7fafc;color:#4a5568;border-radius:6px;font-size:11px;border:1px solid #e2e8f0}.pf-mini-tag.muted{color:#a0aec0}.pf-eligible-info{display:flex;align-items:center;gap:10px;background:#ebf8ff;border:1px solid #bee3f8;color:#2b6cb0;border-radius:12px;padding:12px 16px;font-size:14px;margin-bottom:20px}.pf-eligible-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.pf-eligible-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:20px;padding:20px;box-shadow:0 4px 16px #0000000a;display:flex;flex-direction:column;gap:14px;transition:all .3s ease}.pf-eligible-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000000f}.pf-eligible-top{display:flex;align-items:center;gap:12px}.pf-eligible-emoji{font-size:28px;line-height:1}.pf-eligible-info h3{font-size:16px;font-weight:600;color:#2d3748;margin:0 0 3px}.pf-eligible-info p{font-size:12px;color:#718096;margin:0}.pf-eligible-pct{margin-left:auto}.pf-pct-ring{width:48px;height:48px;background:conic-gradient(#4299e1 calc(var(--pct, 0) * 1%),#e2e8f0 calc(var(--pct, 0) * 1%));border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.pf-pct-ring:before{content:"";position:absolute;width:34px;height:34px;background:#fff;border-radius:50%}.pf-pct-ring span{position:relative;font-size:11px;font-weight:700;color:#2d3748;z-index:1}.pf-eligible-progress{display:flex;align-items:center;gap:10px}.pf-progress-bar-bg{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.pf-progress-bar-fill{height:100%;background:#4299e1;border-radius:3px;transition:width .5s ease}.pf-progress-label{font-size:11px;color:#a0aec0;white-space:nowrap}.pf-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s ease;box-shadow:0 4px 12px #4299e14d;width:100%}.pf-generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #4299e166}.pf-generate-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.pf-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.pf-modal{background:#fff;border-radius:20px;width:100%;max-width:700px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040}.pf-modal-header{padding:20px 24px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.pf-modal-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.pf-modal-skill-badge{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#2d3748}.pf-modal-actions{display:flex;align-items:center;gap:8px}.pf-save-status{font-size:12px;color:#718096;padding:4px 8px}.pf-save-status.saved{color:#10b981}.pf-visibility-btn{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .2s}.pf-visibility-btn.public{background:#ebf8ff;color:#2b6cb0}.pf-visibility-btn.private{background:#f0fff4;color:#276749}.pf-visibility-btn:hover{filter:brightness(.95)}.pf-visibility-btn:disabled{opacity:.5;cursor:not-allowed}.pf-icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#4a5568;transition:all .2s}.pf-icon-btn:hover{background:#edf2f7;color:#2d3748}.pf-url-bar{display:flex;align-items:center;gap:8px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:10px;padding:8px 12px;margin-top:12px}.pf-url-icon{color:#4299e1;flex-shrink:0}.pf-url-text{flex:1;font-size:13px;color:#4a5568;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pf-url-copy,.pf-url-open{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;color:#718096;transition:all .2s;text-decoration:none;flex-shrink:0}.pf-url-copy:hover,.pf-url-open:hover{background:#4299e1;color:#fff;border-color:#4299e1}.pf-modal-body{overflow-y:auto;flex:1;padding:0 24px 24px}.pf-section{padding:20px 0;border-bottom:1px solid #f0f0f0}.pf-section:last-child{border-bottom:none}.pf-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#a0aec0;margin:0 0 12px}.pf-hero{background:#4299e10a;border-radius:16px;padding:24px!important;border:none!important;margin-top:20px}.pf-hero-inner{display:flex;align-items:flex-start;gap:16px}.pf-avatar-circle{width:56px;height:56px;background:#4299e1;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:700;flex-shrink:0}.pf-hero-text{flex:1}.pf-headline{font-size:18px;font-weight:700;color:#2d3748;margin:0 0 8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pf-bio{font-size:14px;color:#4a5568;margin:0;line-height:1.7;display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap}.pf-inline-edit{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:none;border:1px solid #e2e8f0;border-radius:5px;cursor:pointer;color:#a0aec0;transition:all .2s;flex-shrink:0}.pf-inline-edit:hover{background:#ebf8ff;color:#4299e1;border-color:#bee3f8}.pf-edit-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}.pf-edit-row.bio-edit{flex-direction:column;align-items:flex-start}.pf-edit-input{flex:1;padding:6px 10px;border:1.5px solid #4299e1;border-radius:8px;font-size:15px;font-weight:600;color:#2d3748;font-family:inherit;outline:none;min-width:200px}.pf-edit-textarea{width:100%;padding:8px 10px;border:1.5px solid #4299e1;border-radius:8px;font-size:14px;color:#2d3748;font-family:inherit;outline:none;resize:vertical}.pf-edit-btns{display:flex;gap:8px}.pf-mini-save{padding:5px 14px;background:#4299e1;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.pf-mini-cancel{padding:5px 14px;background:#e2e8f0;color:#4a5568;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.pf-stats-row{display:flex;gap:10px;flex-wrap:wrap;padding:16px 0;border-bottom:1px solid #f0f0f0}.pf-stat-pill{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:20px;font-size:13px;color:#4a5568}.pf-stat-pill strong{color:#2d3748}.pf-tags{display:flex;flex-wrap:wrap;gap:8px}.pf-highlights{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.pf-highlights li{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:#4a5568;line-height:1.5}.pf-hl-icon{color:#4299e1;margin-top:2px;flex-shrink:0}.pf-projects{display:flex;flex-direction:column;gap:12px}.pf-project-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.pf-project-top{display:flex;align-items:flex-start;gap:10px}.pf-project-icon{width:30px;height:30px;background:#ebf8ff;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#4299e1;flex-shrink:0}.pf-project-info{flex:1}.pf-project-info h4{font-size:14px;font-weight:600;color:#2d3748;margin:0 0 4px}.pf-project-info p{font-size:13px;color:#718096;margin:0;line-height:1.5}.pf-project-score{font-size:15px;font-weight:700;flex-shrink:0}.pf-project-tags{display:flex;flex-wrap:wrap;gap:6px}.pf-achievements{display:flex;flex-wrap:wrap;gap:8px}.pf-ach-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#f7fafc;border:1px solid;border-radius:20px;font-size:12px}.pf-ach-icon{font-size:14px}.pf-ach-name{color:#4a5568;font-weight:500}.pf-exports{border-bottom:none!important}.pf-export-btns{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.pf-export-btn{display:flex;align-items:center;gap:7px;padding:9px 16px;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;color:#4a5568;font-family:inherit;transition:all .2s}.pf-export-btn:hover{border-color:#bee3f8;background:#f7fafc}.pf-export-btn.active{background:#ebf8ff;border-color:#bee3f8;color:#2b6cb0}.pf-export-panel{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.pf-export-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #e2e8f0;font-size:12px;font-weight:600;color:#718096}.pf-copy-text-btn{display:flex;align-items:center;gap:5px;padding:4px 10px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;color:#4a5568;font-family:inherit;transition:all .2s}.pf-copy-text-btn:hover{background:#4299e1;color:#fff;border-color:#4299e1}.pf-export-text{padding:14px 16px;font-family:Courier New,monospace;font-size:12px;color:#4a5568;margin:0;white-space:pre-wrap;word-break:break-word;max-height:250px;overflow-y:auto;line-height:1.6}@media (max-width: 768px){.pf-grid,.pf-eligible-grid{grid-template-columns:1fr}.pf-modal{max-width:100%;max-height:95vh;border-radius:16px}.pf-stats-row{gap:6px}.pf-stat-pill{font-size:12px;padding:6px 10px}.pf-hero-inner{flex-direction:column;align-items:center;text-align:center}}.pub-page{min-height:100vh;background:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.pub-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:#718096;font-size:15px}.pub-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#4299e1;border-radius:50%;animation:pubSpin .7s linear infinite}@keyframes pubSpin{to{transform:rotate(360deg)}}.pub-notfound{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;text-align:center;padding:40px}.pub-nf-icon{font-size:64px}.pub-notfound h2{font-size:26px;font-weight:700;color:#2d3748;margin:0}.pub-notfound p{font-size:15px;color:#718096;margin:0}.pub-back-btn{display:flex;align-items:center;gap:7px;padding:12px 24px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s;box-shadow:0 4px 12px #4299e14d}.pub-back-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4299e166}.pub-nav{background:#fff;border-bottom:1px solid #f0f0f0;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000000a}.pub-nav-inner{max-width:860px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between}.pub-logo{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:17px;font-weight:700;color:#2d3748}.pub-logo-icon{width:32px;height:32px;background:#4299e1;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.pub-nav-actions{display:flex;gap:8px}.pub-share-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;background:#f7fafc;border:1.5px solid #e2e8f0;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;color:#4a5568;font-family:inherit;transition:all .2s}.pub-share-btn:hover{background:#ebf8ff;border-color:#bee3f8;color:#2b6cb0}.pub-hero{background:#4299e1;padding:60px 24px;color:#fff}.pub-hero-inner{max-width:860px;margin:0 auto;display:flex;align-items:flex-start;gap:28px}.pub-avatar{width:80px;height:80px;background:#ffffff40;border:3px solid rgba(255,255,255,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;color:#fff;flex-shrink:0}.pub-hero-text{flex:1}.pub-skill-badge{display:inline-flex;align-items:center;gap:6px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:4px 14px;font-size:13px;font-weight:600;margin-bottom:16px}.pub-skill-level{font-weight:400;opacity:.7}.pub-headline{font-size:30px;font-weight:800;margin:0 0 8px;letter-spacing:-.5px;line-height:1.2}.pub-name{font-size:15px;opacity:.8;margin:0 0 16px}.pub-bio{font-size:15px;opacity:.9;margin:0;line-height:1.7;max-width:600px}.pub-content{max-width:860px;margin:0 auto;padding:0 24px 60px}.pub-stats-strip{display:flex;gap:16px;padding:24px 0;overflow-x:auto;flex-wrap:wrap}.pub-stat-box{display:flex;align-items:center;gap:12px;background:#fff;border-radius:14px;padding:16px 20px;box-shadow:0 2px 8px #0000000d;flex:1;min-width:120px;border:1px solid rgba(255,255,255,.8);transition:all .3s}.pub-stat-box:hover{transform:translateY(-2px);box-shadow:0 4px 14px #00000014}.pub-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.pub-stat-val{font-size:20px;font-weight:800;color:#2d3748;line-height:1.1}.pub-stat-label{font-size:11px;color:#a0aec0;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.pub-section{background:#fff;border-radius:20px;padding:28px;margin-bottom:20px;box-shadow:0 2px 8px #0000000d;border:1px solid rgba(255,255,255,.8)}.pub-section-title{font-size:18px;font-weight:700;color:#2d3748;margin:0 0 20px;letter-spacing:-.3px}.pub-tags{display:flex;flex-wrap:wrap;gap:8px}.pub-tag{display:inline-block;padding:6px 16px;background:#4299e114;color:#2b6cb0;border-radius:20px;font-size:13px;font-weight:500;border:1px solid #bee3f8}.pub-mini-tag{display:inline-block;padding:3px 10px;background:#f7fafc;color:#4a5568;border-radius:6px;font-size:12px;border:1px solid #e2e8f0}.pub-highlights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.pub-highlight-card{display:flex;align-items:flex-start;gap:10px;background:#4299e10d;border-radius:12px;padding:14px 16px;border:1px solid rgba(66,153,225,.15)}.pub-hl-icon{color:#667eea;margin-top:2px;flex-shrink:0}.pub-highlight-card p{font-size:14px;color:#4a5568;margin:0;line-height:1.5}.pub-projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.pub-project-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:10px;transition:all .3s}.pub-project-card:hover{transform:translateY(-2px);box-shadow:0 4px 14px #00000012;border-color:#bee3f8}.pub-project-header{display:flex;align-items:center;justify-content:space-between}.pub-project-icon-wrap{width:36px;height:36px;background:#4299e114;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#4299e1}.pub-project-meta{display:flex;align-items:center;gap:8px}.pub-project-day{font-size:11px;color:#a0aec0;background:#f0f0f0;padding:3px 8px;border-radius:6px}.pub-project-score{font-size:15px;font-weight:800}.pub-project-title{font-size:15px;font-weight:700;color:#2d3748;margin:0}.pub-project-desc{font-size:13px;color:#718096;margin:0;line-height:1.6}.pub-project-tags{display:flex;flex-wrap:wrap;gap:6px}.pub-achievements{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.pub-ach-card{display:flex;align-items:flex-start;gap:12px;background:#f7fafc;border:1.5px solid;border-radius:14px;padding:14px 16px;transition:all .2s}.pub-ach-card:hover{transform:translateY(-1px)}.pub-ach-icon-bg{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pub-ach-emoji{font-size:20px}.pub-ach-info{flex:1}.pub-ach-info h4{font-size:13px;font-weight:700;color:#2d3748;margin:0 0 3px}.pub-ach-info p{font-size:12px;color:#718096;margin:0 0 4px;line-height:1.4}.pub-rarity-badge{font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.3px}.pub-footer-cta{background:#fff;border-radius:20px;padding:28px;margin-top:20px;box-shadow:0 2px 8px #0000000d;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;border:1px solid rgba(255,255,255,.8)}.pub-footer-brand{display:flex;align-items:center;gap:14px}.pub-footer-logo{width:40px;height:40px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.pub-footer-tagline{font-size:14px;font-weight:700;color:#2d3748;margin:0 0 2px}.pub-footer-sub{font-size:12px;color:#718096;margin:0}.pub-footer-btn{padding:12px 28px;background:#4299e1;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s;box-shadow:0 4px 12px #4299e14d;white-space:nowrap}.pub-footer-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4299e166}@media (max-width: 768px){.pub-hero{padding:40px 20px}.pub-hero-inner{flex-direction:column;align-items:center;text-align:center}.pub-hero-text{display:flex;flex-direction:column;align-items:center}.pub-headline{font-size:22px}.pub-stats-strip{gap:10px}.pub-stat-box{min-width:100px;padding:12px 14px}.pub-stat-val{font-size:16px}.pub-projects,.pub-achievements,.pub-highlights-grid{grid-template-columns:1fr}.pub-footer-cta{flex-direction:column;text-align:center}.pub-footer-brand{flex-direction:column;align-items:center}}.about-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.about-header{display:flex;justify-content:space-between;align-items:center;padding:20px 60px;background:#fff;box-shadow:0 2px 10px #0000000d;flex-wrap:wrap;gap:20px}.about-header .logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#1a1a1a;letter-spacing:.5px;text-decoration:none}.about-header .logo-icon{width:40px;height:40px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.about-header nav{display:flex;gap:40px;align-items:center;flex-wrap:wrap}.about-header nav a,.about-header nav .about-nav-link{text-decoration:none;color:#1a1a1a;font-size:16px;font-weight:600;transition:color .3s;white-space:nowrap}.about-header nav a:hover{color:#4299e1}.about-header nav a.active{color:#4299e1}.about-header .signup-btn{background:#fff;padding:10px 24px;border-radius:25px;border:1px solid #e0e0e0;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit}.about-header .signup-btn:hover{background:#4299e1;color:#fff;border-color:#4299e1}.about-hero{text-align:center;padding:80px 40px 60px;max-width:1200px;margin:0 auto}.about-hero h1{font-size:56px;font-weight:700;margin-bottom:20px;color:#1a1a1a}.about-hero p{font-size:20px;color:#666;max-width:800px;margin:0 auto;line-height:1.6}.about-what{background:#fff;padding:80px 40px;margin:0 0 40px}.about-container{max-width:1200px;margin:0 auto}.about-what h2{font-size:42px;font-weight:700;margin-bottom:30px;color:#1a1a1a;text-align:center}.about-description{font-size:18px;line-height:1.8;color:#444;max-width:900px;margin:0 auto 60px;text-align:center}.about-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.about-feature-card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:40px 30px;transition:all .3s ease;box-shadow:0 4px 16px #0000000a}.about-feature-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #00000014}.about-feature-icon{width:60px;height:60px;background:#4299e1;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.about-feature-icon svg{width:32px;height:32px}.about-feature-card h3{font-size:22px;font-weight:700;margin-bottom:15px;color:#2d3748}.about-feature-card p{font-size:15px;color:#718096;line-height:1.6}.about-mission{padding:80px 40px}.about-mission h2{font-size:42px;font-weight:700;margin-bottom:40px;color:#1a1a1a;text-align:center}.mission-content{max-width:900px;margin:0 auto;background:#fff;padding:50px;border-radius:20px;box-shadow:0 10px 30px #00000014}.mission-content p{font-size:18px;line-height:1.8;color:#444;margin-bottom:20px}.mission-content p:last-child{margin-bottom:0}.about-footer{background:#1a1a1a;color:#fff;text-align:center;padding:40px 20px;margin-top:0}.about-footer p{font-size:16px}@media (max-width: 768px){.about-header{padding:20px 30px}.about-header nav{gap:20px;width:100%;justify-content:center}.about-hero h1{font-size:36px}.about-hero p{font-size:16px}.about-what h2,.about-mission h2{font-size:32px}.about-features-grid{grid-template-columns:1fr}.mission-content{padding:40px 30px}}@media (max-width: 480px){.about-hero{padding:60px 20px 40px}.about-what,.about-mission{padding:60px 20px}}.contact-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.contact-header{display:flex;justify-content:space-between;align-items:center;padding:20px 60px;background:#fff;box-shadow:0 2px 10px #0000000d;flex-wrap:wrap;gap:20px}.contact-header .logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#1a1a1a;letter-spacing:.5px;text-decoration:none}.contact-header .logo-icon{width:40px;height:40px;background:#4299e1;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.contact-header nav{display:flex;gap:40px;align-items:center;flex-wrap:wrap}.contact-header nav a{text-decoration:none;color:#1a1a1a;font-size:16px;font-weight:600;transition:color .3s;white-space:nowrap}.contact-header nav a:hover{color:#4299e1}.contact-header nav a.active{color:#4299e1}.contact-header .signup-btn{background:#fff;padding:10px 24px;border-radius:25px;border:1px solid #e0e0e0;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit}.contact-header .signup-btn:hover{background:#4299e1;color:#fff;border-color:#4299e1}.contact-hero{text-align:center;padding:80px 40px 40px;max-width:800px;margin:0 auto}.contact-hero h1{font-size:56px;font-weight:700;margin-bottom:20px;color:#1a1a1a}.contact-hero p{font-size:20px;color:#666;line-height:1.6}.contact-section{max-width:1000px;margin:60px auto;padding:0 40px}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;margin-bottom:60px}.contact-card{background:#fff;padding:50px 40px;border-radius:20px;box-shadow:0 10px 30px #00000014;text-align:center;transition:transform .3s,box-shadow .3s}.contact-card:hover{transform:translateY(-10px);box-shadow:0 15px 40px #0000001f}.contact-icon{width:80px;height:80px;background:linear-gradient(135deg,#4299e1,#3182ce);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 30px}.contact-icon svg{width:40px;height:40px}.contact-card h3{font-size:28px;font-weight:700;margin-bottom:15px;color:#1a1a1a}.contact-card p{font-size:16px;color:#666;margin-bottom:25px;line-height:1.6}.contact-link{display:inline-block;background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;padding:14px 32px;border-radius:25px;text-decoration:none;font-size:16px;font-weight:600;transition:all .3s}.contact-link:hover{transform:scale(1.05);box-shadow:0 5px 20px #4299e166}.email-text{color:#4299e1;font-size:17px;font-weight:600;word-break:break-all;margin-bottom:20px!important}.message-section{background:#fff;padding:60px 40px;border-radius:20px;box-shadow:0 10px 30px #00000014}.message-section h2{font-size:36px;font-weight:700;margin-bottom:15px;text-align:center;color:#1a1a1a}.message-section>p{font-size:17px;color:#666;text-align:center;margin-bottom:40px;line-height:1.6}.message-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:16px;font-weight:600;color:#1a1a1a}.form-group input,.form-group textarea{padding:14px 20px;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;font-family:inherit;transition:border-color .3s;color:#1a1a1a;background:#fafafa}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4299e1;background:#fff}.form-group textarea{min-height:150px;resize:vertical}.submit-btn{background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;padding:16px 40px;border-radius:25px;border:none;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:10px;font-family:inherit}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px #4299e166}.submitted-msg{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 0;text-align:center}.submitted-msg svg{width:64px;height:64px}.submitted-msg p{font-size:18px;color:#444}.contact-footer{background:#1a1a1a;color:#fff;text-align:center;padding:40px 20px;margin-top:80px}.contact-footer p{font-size:16px}@media (max-width: 768px){.contact-header{padding:20px 30px}.contact-header nav{gap:20px;width:100%;justify-content:center}.contact-hero h1{font-size:36px}.contact-hero p{font-size:16px}.contact-grid{grid-template-columns:1fr}.message-section{padding:40px 30px}.message-section h2{font-size:28px}}@media (max-width: 480px){.contact-hero{padding:60px 20px 40px}.contact-section{padding:0 20px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Jost,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);min-height:100vh;color:#2d3748}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#7180964d;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#71809680}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);gap:16px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;min-height:400px}.loading-spinner{width:48px;height:48px;border:4px solid rgba(66,153,225,.1);border-top-color:#4299e1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p,.app-loading p{font-size:15px;color:#718096}
