@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,600;0,700;1,600&display=swap";:root{--bg-color:#fafaf8;--bg-secondary:#fff;--text-primary:#1a2e1a;--text-secondary:#4b5e4b;--primary-color:#1b4332;--primary-gradient:#1b4332;--accent-color:#2d6a4f;--nav-bg:#fffffff2;--glass-border:#d4ddd4;--glass-bg:#fff;--transition-fast:.2s ease-in-out;--transition-medium:.4s cubic-bezier(.4, 0, .2, 1);--font-body:"Inter", sans-serif;--font-heading:"Playfair Display", serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;flex-direction:column;min-height:100vh;line-height:1.6;display:flex}#root{flex-direction:column;min-height:100vh;display:flex}main{flex-grow:1;padding-top:80px}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:1rem;font-weight:700}a{color:inherit;transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-color)}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.glass-panel{background:var(--bg-secondary);border:1px solid var(--glass-border);transition:box-shadow var(--transition-medium), transform var(--transition-medium);border-radius:4px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.btn-primary{background:var(--primary-color);font-weight:500;font-family:var(--font-body);letter-spacing:.02em;border:1px solid var(--primary-color);cursor:pointer;transition:all var(--transition-medium);border-radius:2px;justify-content:center;align-items:center;padding:.75rem 2rem;display:inline-flex;color:#fff!important}.btn-primary:hover{background:#000;border-color:#000}.btn-secondary{border:1px solid var(--primary-color);cursor:pointer;transition:all var(--transition-medium);background:0 0;border-radius:2px;justify-content:center;align-items:center;padding:.75rem 2rem;font-weight:500;display:inline-flex;color:var(--primary-color)!important}.btn-secondary:hover{background:var(--bg-color);color:var(--text-primary)!important}.gradient-text{color:var(--accent-color);-webkit-text-fill-color:initial;background:0 0}.page-header{text-align:center;background:var(--bg-secondary);border-bottom:1px solid var(--glass-border);padding:5rem 0 3rem}.page-title{letter-spacing:-.02em;margin-bottom:1rem;font-size:3.5rem}.page-subtitle{color:var(--text-secondary);max-width:600px;font-size:1.125rem;font-family:var(--font-body);margin:0 auto;font-weight:400}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.6s ease-out forwards fadeIn}.header{z-index:1000;transition:all var(--transition-medium);background:0 0;padding:1.25rem 0;position:fixed;top:0;left:0;right:0}.header.scrolled{background:var(--nav-bg);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--glass-border);padding:.75rem 0;box-shadow:0 1px 3px #0000000a}.header-container{justify-content:space-between;align-items:center;display:flex}.logo{object-fit:contain;height:44px;transition:opacity var(--transition-fast)}.logo:hover{opacity:.8}.nav{align-items:center;gap:2rem;display:flex}.nav-link{color:var(--text-secondary);letter-spacing:.01em;transition:color var(--transition-fast);padding-bottom:.25rem;font-size:.9rem;font-weight:500;position:relative}.nav-link:hover,.nav-link.active{color:var(--text-primary)}.nav-link:after{content:"";background:var(--accent-color);width:0;height:2px;transition:width var(--transition-fast);position:absolute;bottom:0;left:0}.nav-link:hover:after,.nav-link.active:after{width:100%}.login-btn{margin-left:.5rem;padding:.5rem 1.5rem;font-size:.9rem}.mobile-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;display:none}@media (width<=768px){.mobile-toggle{display:block}.nav{background:var(--bg-secondary);opacity:0;transition:all var(--transition-medium);border-bottom:1px solid var(--glass-border);visibility:hidden;flex-direction:column;gap:1.5rem;padding:2rem;position:fixed;top:60px;left:0;right:0;transform:translateY(-150%);box-shadow:0 4px 12px #0000000f}.nav.open{opacity:1;visibility:visible;transform:translateY(0)}.login-btn{text-align:center;width:100%;margin-top:.5rem;margin-left:0}}.footer{background:var(--bg-secondary);border-top:1px solid var(--glass-border);margin-top:auto;padding-top:4rem}.footer-container{grid-template-columns:2fr 1fr 1.5fr;gap:3rem;margin-bottom:3rem;display:grid}.footer-brand{flex-direction:column;align-items:flex-start;display:flex}.footer-logo{object-fit:contain;height:44px;margin-bottom:1.5rem}.footer-bio{color:var(--text-secondary);max-width:400px;margin-bottom:1.5rem;font-size:.95rem;line-height:1.7}.social-links{gap:.75rem;display:flex}.social-link{border:1px solid var(--glass-border);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);background:#0f172a0a;border-radius:4px;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex}.social-link:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.footer-heading{color:var(--text-primary);font-size:1.1rem;font-family:var(--font-heading);margin-bottom:1.25rem}.footer-links{flex-direction:column;gap:.6rem;list-style:none;display:flex}.footer-links a{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.95rem}.footer-links a:hover{color:var(--accent-color)}.contact-info{flex-direction:column;gap:.85rem;list-style:none;display:flex}.contact-info li{color:var(--text-secondary);align-items:flex-start;gap:.75rem;font-size:.95rem;display:flex}.contact-icon{color:var(--accent-color);flex-shrink:0;margin-top:2px}.contact-info a{color:var(--text-secondary);transition:color var(--transition-fast)}.contact-info a:hover{color:var(--accent-color)}.footer-bottom{border-top:1px solid var(--glass-border);text-align:center;color:var(--text-secondary);padding:1.25rem 0;font-size:.85rem}@media (width<=768px){.footer-container{grid-template-columns:1fr;gap:2.5rem}}.hero-section{align-items:center;min-height:90vh;padding:6rem 0 4rem;display:flex;position:relative;overflow:hidden}.hero-bg-accent{z-index:-1;background:radial-gradient(circle,#ca8a040f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;right:-10%;transform:translateY(-50%)}.hero-content{z-index:1;max-width:620px;position:relative}.hero-title{letter-spacing:-.03em;margin-bottom:1.5rem;font-size:4rem;line-height:1.12}.hero-subtitle{color:var(--text-secondary);max-width:520px;margin-bottom:2.5rem;font-size:1.125rem;line-height:1.8}.hero-cta{gap:1rem;display:flex}.features-section{background:var(--bg-secondary);border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);padding:6rem 0}.section-header{text-align:center;margin-bottom:3.5rem}.section-title{letter-spacing:-.02em;margin-bottom:.75rem;font-size:2.5rem}.features-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.feature-card{transition:transform var(--transition-medium), box-shadow var(--transition-medium);flex-direction:column;height:100%;padding:2.5rem 2rem;display:flex}.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000014}.feature-icon-wrapper{width:56px;height:56px;color:var(--primary-color);background:#0f172a0d;border-radius:8px;justify-content:center;align-items:center;margin-bottom:1.5rem;display:flex}.feature-title{color:var(--text-primary);font-size:1.25rem;font-family:var(--font-heading);margin-bottom:.75rem}.feature-description{color:var(--text-secondary);font-size:.95rem;line-height:1.7}.about-section{padding:6rem 0;scroll-margin-top:80px}.mv-grid{grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:4rem;display:grid}.mv-card{transition:transform var(--transition-medium), box-shadow var(--transition-medium);padding:3rem 2.5rem;position:relative;overflow:hidden}.mv-card:before{content:"";background:var(--accent-color);height:3px;position:absolute;top:0;left:0;right:0}.mv-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000014}.mv-icon{color:var(--accent-color);margin-bottom:1.5rem}.mv-card h3{margin-bottom:1rem;font-size:1.5rem}.mv-card p{color:var(--text-secondary);line-height:1.8}.values-row{justify-content:center;gap:4rem;display:flex}.value-item{text-align:center;max-width:280px}.value-icon{border:1px solid var(--glass-border);width:64px;height:64px;color:var(--primary-color);transition:all var(--transition-medium);background:#0f172a0a;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.25rem;display:flex}.value-item:hover .value-icon{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.value-item h4{margin-bottom:.5rem;font-size:1.25rem}.value-item p{color:var(--text-secondary);font-size:.95rem}.contact-section{background:var(--bg-secondary);border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);padding:6rem 0;scroll-margin-top:80px}.contact-grid{grid-template-columns:1fr 1.5fr;align-items:start;gap:3rem;display:grid}.contact-info-cards{flex-direction:column;gap:1rem;display:flex}.contact-card{padding:1.5rem}.contact-card-link{color:inherit;cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast);text-decoration:none;display:block}.contact-card-link:hover{color:inherit;transform:translateY(-3px);box-shadow:0 8px 20px #00000014}.contact-card-link:hover .contact-icon-wrapper{background:var(--primary-color);color:#fff}.contact-card-link.whatsapp-card:hover .contact-icon-wrapper{color:#fff;background:#25d366}.contact-item{align-items:center;gap:1.25rem;display:flex}.contact-icon-wrapper{width:44px;height:44px;color:var(--primary-color);background:#0f172a0d;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.whatsapp-icon{color:#25d366;background:#25d36614}.contact-item h4{font-size:.95rem;font-family:var(--font-body);margin-bottom:.15rem;font-weight:600}.contact-link{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.95rem}.contact-link:hover{color:var(--accent-color)}.contact-address{color:var(--text-secondary);font-size:.95rem}.map-wrapper{height:100%;min-height:380px;padding:.35rem;overflow:hidden}.map-wrapper iframe{border-radius:3px;width:100%;height:100%}.gallery-section{padding:6rem 0;scroll-margin-top:80px}@media (width<=992px){.contact-grid{grid-template-columns:1fr}.map-wrapper{min-height:350px}}@media (width<=768px){.hero-title{font-size:2.75rem}.hero-cta{flex-direction:column}.hero-cta .btn-primary,.hero-cta .btn-secondary{text-align:center;justify-content:center;width:100%}.features-grid,.mv-grid{grid-template-columns:1fr}.values-row{flex-direction:column;align-items:center;gap:2.5rem}.gallery-grid{grid-template-columns:1fr}}.gallery-page{padding-bottom:6rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.gallery-item{aspect-ratio:4/3;cursor:pointer;border-radius:4px;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014}.gallery-image-placeholder{background:linear-gradient(135deg,#f1f5f9 0%,#e2e8f0 100%);justify-content:center;align-items:center;width:100%;height:100%;transition:transform .5s;display:flex}.placeholder-text{color:var(--text-secondary);font-family:var(--font-heading);opacity:.15;font-size:1.75rem;font-weight:700}.gallery-overlay{opacity:0;background:linear-gradient(#0000 0%,#0f172a4d 50%,#0f172ae6 100%);flex-direction:column;justify-content:flex-end;padding:1.75rem;transition:all .35s;display:flex;position:absolute;inset:0;transform:translateY(10px)}.gallery-item:hover .gallery-image-placeholder{transform:scale(1.05)}.gallery-item:hover .gallery-overlay{opacity:1;transform:translateY(0)}.gallery-item-title{color:#fff;margin-bottom:.35rem;font-size:1.1rem}.gallery-item-subtitle{color:#ffffffb3;font-size:.9rem}@media (width<=768px){.gallery-grid{grid-template-columns:1fr}}.login-page{justify-content:center;align-items:center;min-height:calc(100vh - 280px);padding:4rem 0;display:flex}.login-container{justify-content:center;width:100%;display:flex}.login-card{border-top:3px solid var(--accent-color);width:100%;max-width:460px;padding:3rem;box-shadow:0 4px 12px #0000000f}.login-header{text-align:center;margin-bottom:2.5rem}.login-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-primary);font-size:.9rem;font-weight:500}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-secondary);pointer-events:none;position:absolute;left:1rem}.input-with-icon input{background:var(--bg-color);border:1px solid var(--glass-border);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition-fast);border-radius:4px;padding:.85rem 1rem .85rem 3rem;font-size:1rem}.input-with-icon input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #0f172a14}.input-with-icon input::placeholder{color:#9ca3af}.form-options{justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.9rem;display:flex}.checkbox-container{color:var(--text-secondary);cursor:pointer;align-items:center;gap:.5rem;display:flex}.forgot-password{color:var(--accent-color);transition:color var(--transition-fast);text-decoration:none}.forgot-password:hover{text-decoration:underline}.login-submit-btn{width:100%;margin-top:1rem;padding:.85rem;font-size:1rem}.login-error{color:#dc2626;background:#ef444414;border:1px solid #ef44444d;border-radius:4px;padding:.75rem 1rem;font-size:.9rem}.login-footer{text-align:center;color:var(--text-secondary);margin-top:2rem;font-size:.95rem}.login-footer a{font-weight:600}@media (width<=480px){.login-card{padding:2rem 1.5rem}}.programme-hero{text-align:center;padding:8rem 0 4rem;position:relative;overflow:hidden}.programme-hero .hero-subtitle{margin-left:auto;margin-right:auto}.badge{color:var(--primary-color);background:#2d6a4f1a;border:1px solid #2d6a4f33;border-radius:50px;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;display:inline-block}.quote-block{background:var(--bg-secondary);border-left:4px solid var(--accent-color);max-width:700px;font-family:var(--font-heading);color:var(--text-primary);border-radius:0 8px 8px 0;margin:2rem auto;padding:2rem;font-size:1.25rem;font-style:italic;box-shadow:0 4px 15px #0000000d}.programme-overview,.modules-section,.certificate-cta,.promise-section{padding:4rem 0}.overview-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;display:grid}@media (width>=768px) and (width<=1024px){.overview-grid{grid-template-columns:1fr 1fr}.overview-card:nth-child(3){grid-column:1/-1;max-width:50%;margin:0 auto}}@media (width<=767px){.overview-grid{grid-template-columns:1fr}}.overview-card{text-align:center;padding:2rem}.overview-icon{width:60px;height:60px;color:var(--primary-color);background:#2d6a4f1a;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.promise-container{padding:3rem}.promise-grid{grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem;display:grid}@media (width<=768px){.promise-grid{grid-template-columns:1fr}}.promise-item{align-items:flex-start;gap:1rem;display:flex}.promise-icon{color:var(--accent-color);flex-shrink:0;margin-top:.25rem}.modules-list{flex-direction:column;gap:1.5rem;max-width:900px;margin:0 auto;display:flex}.module-card{transition:transform var(--transition-fast);padding:2rem;position:relative;overflow:hidden}.module-card:hover{transform:translateY(-2px)}.module-card:before{content:"";background:var(--accent-color);border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.module-header{align-items:flex-start;gap:1.5rem;margin-bottom:1rem;display:flex}.module-number{font-family:var(--font-heading);color:#2d6a4f26;font-size:2.5rem;font-weight:700;line-height:1}.module-title-group{flex-grow:1}.module-title{margin-bottom:.25rem}.module-subtitle{color:var(--accent-color);font-size:.9rem;font-weight:500}.locked-badge{color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f1f5f9;border-radius:50px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.module-locked .module-card:before{background:#cbd5e1}.module-description{margin-bottom:1.5rem}.module-meta{gap:1rem;font-size:.85rem;display:flex}.duration-badge,.credit-badge{background:var(--bg-color);color:var(--text-secondary);border-radius:4px;align-items:center;gap:.5rem;padding:.25rem .75rem;font-weight:500;display:inline-flex}.cert-box{padding:4rem 2rem}.cert-icon{color:var(--accent-color);margin-bottom:1.5rem}.text-center{text-align:center}@media (width<=768px){.module-header{flex-direction:column;gap:.5rem}.locked-badge{position:absolute;top:1rem;right:1rem}}.dashboard-page{background:var(--bg-color);min-height:calc(100vh - 80px);padding:8rem 0 4rem}.dashboard-container{grid-template-columns:320px 1fr;align-items:flex-start;gap:2.5rem;display:grid}@media (width<=991px){.dashboard-container{grid-template-columns:1fr}}.dashboard-sidebar{padding:2rem}.profile-widget{text-align:center;border-bottom:1px solid var(--glass-border);padding-bottom:2rem}.profile-avatar{background:var(--primary-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;display:flex}.profile-name{margin-bottom:.25rem;font-size:1.5rem}.profile-course{color:var(--accent-color);font-size:.9rem;font-weight:500}.progress-header{justify-content:space-between;margin-bottom:.5rem;font-size:.95rem;font-weight:600;display:flex}.progress-bar-bg{background:#2d6a4f1a;border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{background:var(--accent-color);border-radius:4px;height:100%}.progress-text{color:var(--text-secondary);font-size:.85rem}.widget-title{align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;display:flex}.upcoming-card{background:var(--bg-color);border:1px solid var(--glass-border);border-radius:6px;padding:1.25rem}.upcoming-card h4{margin-bottom:.25rem;font-size:1rem}.upcoming-card p{color:var(--text-secondary);font-size:.85rem}.btn-small{padding:.5rem 1rem;font-size:.85rem}.dashboard-header .section-title{margin-top:0}.dashboard-header .page-subtitle{max-width:100%;margin-left:0}.active-module-highlight{border-left:4px solid var(--accent-color);padding:2.5rem}.pending-module-highlight{background:#d977060a;border-left:4px solid #d97706;padding:2.5rem}.badge-active{color:var(--accent-color);text-transform:uppercase;letter-spacing:.05em;background:#2d6a4f1a;border-radius:50px;margin-bottom:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-block}.badge-pending{color:#d97706;text-transform:uppercase;letter-spacing:.05em;background:#d977061a;border-radius:50px;align-items:center;gap:.35rem;margin-bottom:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-flex}.active-module-info h2,.pending-module-info h2{margin-bottom:.75rem;font-size:1.75rem}.pending-text{color:#d97706;align-items:center;gap:.35rem;font-size:.82rem;font-weight:500;display:flex}.dashboard-module-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;display:grid}.dashboard-module-card{background:var(--glass-bg);border:1px solid var(--glass-border);transition:transform var(--transition-fast), border-color var(--transition-fast);border-radius:8px;padding:1.5rem}.dashboard-module-card:hover{border-color:var(--accent-color);transform:translateY(-2px)}.dashboard-module-card.locked{opacity:.6}.dashboard-module-card.locked:hover{border-color:var(--glass-border);cursor:not-allowed;transform:none}.dash-mod-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.dash-mod-number{font-family:var(--font-heading);color:#2d6a4f26;font-size:2rem;font-weight:700;line-height:1}.dash-mod-title{font-size:1.1rem;line-height:1.4}.status-icon.completed-icon{color:var(--accent-color)}.status-icon.active-icon{color:#f59e0b}.status-icon.pending-icon{color:#d97706}.status-icon.locked-icon{color:#94a3b8}.dashboard-module-card.pending{border-color:#d9770666}.dash-mod-action{font-size:.85rem;font-weight:600}.action-text{color:var(--text-primary)}.text-active{color:#f59e0b}.text-pending{color:#d97706}.text-locked{color:#94a3b8}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:2rem}.module-page{background:var(--bg-color);min-height:100vh;padding:8rem 0 4rem}.module-container{max-width:820px}.module-breadcrumb{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.9rem;display:flex}.breadcrumb-link{color:var(--accent-color);transition:opacity var(--transition-fast);align-items:center;gap:.4rem;font-weight:500;text-decoration:none;display:flex}.breadcrumb-link:hover{opacity:.75}.breadcrumb-sep{color:var(--text-secondary)}.module-hero{border-top:4px solid var(--accent-color);margin-bottom:2rem;padding:2.5rem}.module-hero-meta{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.module-number-badge{background:var(--primary-color);color:#fff;text-transform:uppercase;letter-spacing:.08em;border-radius:50px;padding:.3rem .8rem;font-size:.8rem;font-weight:700}.module-meta-pills{flex-wrap:wrap;gap:.5rem;display:flex}.meta-pill{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-secondary);border-radius:50px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.8rem;display:flex}.module-title{font-family:var(--font-heading);margin-bottom:.4rem;font-size:2.5rem;line-height:1.15}.module-subtitle{color:var(--accent-color);margin-bottom:1.5rem;font-size:1.1rem;font-weight:500}.module-quote{border-left:3px solid var(--accent-color);color:var(--text-secondary);margin:0;padding-left:1.25rem;font-size:1.05rem;font-style:italic;line-height:1.6}.module-body{flex-direction:column;gap:1.5rem;display:flex}.module-intro,.module-section{padding:2rem 2.5rem}.module-intro p,.module-section p{color:var(--text-primary);margin-bottom:1rem;line-height:1.8}.module-intro p:last-child,.module-section p:last-child{margin-bottom:0}.section-heading{font-family:var(--font-heading);color:var(--primary-color);margin-bottom:1rem;font-size:1.3rem}.module-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.module-list li{color:var(--text-primary);padding-left:1.5rem;line-height:1.7;position:relative}.module-list li:before{content:"";background:var(--accent-color);border-radius:50%;width:6px;height:6px;position:absolute;top:.65em;left:0}.module-closing-line{border-left:4px solid var(--accent-color);background:#2d6a4f0a;padding:1.5rem 2.5rem}.module-closing-line p{font-family:var(--font-heading);color:var(--primary-color);margin:0;font-size:1.2rem;font-style:italic}.module-complete-row{justify-content:flex-end;padding-top:.5rem;display:flex}.module-complete-badge{color:var(--accent-color);background:#2d6a4f1a;border-radius:50px;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;display:inline-flex}.module-pending-badge{color:#d97706;background:#d9770614;border:1px solid #d9770640;border-radius:8px;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;display:flex}.module-pending-badge strong{margin-bottom:.2rem;font-size:.9rem;display:block}.module-pending-badge p{opacity:.85;margin:0;font-size:.82rem}@keyframes spin{to{transform:rotate(360deg)}}.module-pagination{justify-content:space-between;gap:1rem;margin-top:2.5rem;display:flex}.pagination-btn{align-items:center;gap:.75rem;text-decoration:none;display:flex}.pagination-btn span{text-align:left;flex-direction:column;font-size:.95rem;display:flex}.pagination-btn span small{opacity:.7;font-size:.75rem;font-weight:400}.module-not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:60vh;display:flex}@media (width<=600px){.module-hero,.module-intro,.module-section,.module-closing-line{padding:1.5rem}.module-title{font-size:1.75rem}.module-pagination{flex-direction:column}.pagination-btn span{text-align:center}}.admin-page{background:var(--bg-color);min-height:100vh;padding:8rem 0 4rem}.admin-container{max-width:960px}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;display:flex}.admin-header .section-title{margin-top:0}.admin-header .page-subtitle{max-width:100%;margin-left:0}.admin-stat{color:var(--accent-color);align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.stat-number{font-family:var(--font-heading);color:var(--primary-color);font-size:1.75rem;font-weight:700;line-height:1;display:block}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.8rem;display:block}.admin-tabs{gap:.5rem;margin-bottom:1.5rem;display:flex}.admin-tab{border:1px solid var(--glass-border);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:50px;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:500;display:flex}.admin-tab:hover{border-color:var(--accent-color);color:var(--accent-color)}.admin-tab.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.admin-card{padding:0;overflow:hidden}.table-wrapper{overflow-x:auto}.users-table{border-collapse:collapse;width:100%;font-size:.9rem}.users-table th{text-align:left;border-bottom:1px solid var(--glass-border);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:#1b43320a;padding:1rem 1.25rem;font-size:.78rem;font-weight:600}.users-table td{border-bottom:1px solid var(--glass-border);color:var(--text-primary);vertical-align:middle;padding:1rem 1.25rem}.users-table tr:last-child td{border-bottom:none}.users-table tr.row-admin td{background:#1b433208}.table-empty{text-align:center;color:var(--text-secondary);padding:2.5rem!important}.text-muted{color:var(--text-secondary);font-size:.85rem}.role-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:50px;padding:.2rem .7rem;font-size:.75rem;font-weight:700;display:inline-block}.role-badge.student{color:var(--accent-color);background:#2d6a4f1a}.role-badge.admin{color:var(--primary-color);background:#1b43321f}.student-progress{align-items:center;gap:.5rem;display:flex}.progress-module{color:var(--primary-color);white-space:nowrap;font-size:.82rem;font-weight:600}.progress-mini-bar{background:#1b43321a;border-radius:50px;flex-shrink:0;width:60px;height:5px;overflow:hidden}.progress-mini-fill{background:var(--accent-color);border-radius:50px;height:100%;transition:width .3s}.progress-fraction{color:var(--text-secondary);white-space:nowrap;font-size:.78rem}.progress-complete{color:var(--accent-color);font-size:.82rem;font-weight:600}.pending-badge-small{color:#d97706;white-space:nowrap;background:#d977061a;border-radius:50px;padding:.15rem .5rem;font-size:.72rem;font-weight:700;display:inline-block}.row-clickable{cursor:pointer;transition:background var(--transition-fast)}.row-clickable:hover td{background:#1b43320a}.user-detail{padding:0}.user-detail-header{border-bottom:1px solid var(--glass-border);flex-wrap:wrap;align-items:center;gap:1.25rem;padding:1.75rem 2rem;display:flex}.btn-back{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;font-family:var(--font-body);transition:all var(--transition-fast);background:0 0;border-radius:50px;flex-shrink:0;align-items:center;gap:.4rem;padding:.4rem .9rem;display:inline-flex}.btn-back:hover{border-color:var(--accent-color);color:var(--accent-color)}.user-detail-identity{flex-wrap:wrap;flex:1;align-items:center;gap:.6rem;display:flex}.user-detail-identity h2{margin:0;font-size:1.2rem}.user-detail-email{color:var(--text-secondary);font-size:.85rem}.user-detail-stats{gap:1.5rem;display:flex}.detail-stat{text-align:center}.detail-stat-num{font-family:var(--font-heading);color:var(--primary-color);font-size:1.5rem;font-weight:700;line-height:1;display:block}.detail-stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-top:.2rem;font-size:.72rem;display:block}.detail-stat.pending .detail-stat-num{color:#d97706}.module-progress-list{padding:.5rem 0}.module-progress-row{border-bottom:1px solid var(--glass-border);transition:background var(--transition-fast);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 2rem;display:flex}.module-progress-row:last-child{border-bottom:none}.module-progress-row.pending{background:#d9770608}.mpr-left{align-items:center;gap:1rem;min-width:0;display:flex}.mpr-number{font-family:var(--font-heading);color:#1b433226;flex-shrink:0;font-size:1.5rem;font-weight:700;line-height:1}.module-progress-row.approved .mpr-number{color:#2d6a4f4d}.module-progress-row.pending .mpr-number{color:#d9770666}.mpr-info{flex-direction:column;gap:.15rem;min-width:0;display:flex}.mpr-title{color:var(--text-primary);font-size:.92rem;font-weight:600}.mpr-date{color:var(--text-secondary);font-size:.78rem}.mpr-right{flex-shrink:0}.mpr-status{align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;display:inline-flex}.mpr-status.approved{color:var(--accent-color)}.mpr-status.not-started{color:#94a3b8}.btn-approve{color:var(--accent-color);cursor:pointer;font-size:.82rem;font-weight:600;font-family:var(--font-body);transition:all var(--transition-fast);background:#2d6a4f1a;border:1px solid #2d6a4f40;border-radius:4px;align-items:center;gap:.4rem;padding:.45rem 1rem;display:inline-flex}.btn-approve:hover:not(:disabled){background:var(--accent-color);border-color:var(--accent-color);color:#fff}.btn-approve:disabled{opacity:.5;cursor:not-allowed}.btn-icon{cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:600;font-family:var(--font-body);border:1px solid #0000;border-radius:4px;align-items:center;gap:.35rem;padding:.35rem .75rem;display:inline-flex}.btn-promote{color:var(--primary-color);background:#1b433214;border-color:#1b433233}.btn-promote:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-demote{color:#dc2626;background:#ef44440f;border-color:#ef444433}.btn-demote:hover:not(:disabled){color:#fff;background:#dc2626;border-color:#dc2626}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.create-card{padding:2.5rem}.create-title{font-family:var(--font-heading);margin-bottom:.4rem;font-size:1.4rem}.create-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.create-form{flex-direction:column;gap:1.25rem;max-width:480px;display:flex}.create-form .form-group{flex-direction:column;gap:.4rem;display:flex}.create-form label{color:var(--text-primary);font-size:.875rem;font-weight:500}.create-form input,.create-form select{background:var(--bg-color);border:1px solid var(--glass-border);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:border-color var(--transition-fast);box-sizing:border-box;border-radius:4px;padding:.75rem 1rem;font-size:.95rem}.create-form input:focus,.create-form select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #0f172a14}.password-field{align-items:center;display:flex;position:relative}.password-field input{padding-right:3rem}.toggle-password{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:0;display:flex;position:absolute;right:.75rem}.toggle-password:hover{color:var(--primary-color)}.create-submit{align-self:flex-start;align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.admin-loading{color:var(--text-secondary);align-items:center;gap:.75rem;padding:2rem 1.5rem;display:flex}.admin-error{color:#dc2626;background:#ef444414;border:1px solid #ef444440;border-radius:4px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.admin-success{color:var(--accent-color);background:#2d6a4f14;border:1px solid #2d6a4f40;border-radius:4px;padding:.75rem 1rem;font-size:.875rem}.spin{animation:.8s linear infinite spin}.signout-btn{justify-content:center;align-items:center;gap:.5rem;width:100%;display:flex}@media (width<=600px){.admin-header{flex-direction:column}.create-card{padding:1.5rem}.users-table th:nth-child(5),.users-table td:nth-child(5){display:none}}
