:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary: #f472b6;--accent: #06b6d4;--bg-dark: #0f0f1a;--bg-card: #1a1a2e;--bg-card-hover: #252542;--text-primary: #ffffff;--text-secondary: #a1a1aa;--text-muted: #71717a;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--gradient-accent: linear-gradient(135deg, #06b6d4 0%, #6366f1 100%);--gradient-hero: linear-gradient(180deg, #0f0f1a 0%, #1a1a2e 100%);--glass-bg: rgba(26, 26, 46, .8);--glass-border: rgba(255, 255, 255, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(99, 102, 241, .3);--container-max: 1200px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-dark);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--primary-light);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary)}img{max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:1rem}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,3vw,2.5rem)}h3{font-size:clamp(1.25rem,2vw,1.75rem)}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .3s ease;text-decoration:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm),0 0 20px #6366f14d}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 30px #6366f180}.btn-secondary{background:transparent;color:var(--text-primary);border:2px solid var(--glass-border)}.btn-secondary:hover{background:var(--glass-bg);border-color:var(--primary)}.btn-outline{background:transparent;color:var(--primary-light);border:2px solid var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--glass-border);overflow:hidden;transition:all .3s ease}.card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-glow)}.card-body{padding:1.5rem}.glass{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border)}.form-group{margin-bottom:1.25rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.form-input{width:100%;padding:.875rem 1rem;font-size:1rem;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--glass-border);border-radius:var(--radius-md);outline:none;transition:border-color .2s ease}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}.form-input::placeholder{color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fadeIn{animation:fadeIn .6s ease forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.text-center{text-align:center}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.grid{display:grid;gap:1.5rem}.grid-cols-1{grid-template-columns:1fr}@media(min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.badge-primary{background:var(--primary);color:#fff}.badge-free{background:#10b981;color:#fff}.badge-premium{background:var(--gradient-primary);color:#fff}.video-container{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius-lg);overflow:hidden}.video-watermark{position:absolute;inset:0;pointer-events:none;z-index:10;display:flex;align-items:center;justify-content:center}.video-watermark-text{color:#ffffff26;font-size:clamp(.75rem,2vw,1.5rem);font-weight:600;text-align:center;transform:rotate(-30deg);-webkit-user-select:none;user-select:none}.video-logo{position:absolute;bottom:60px;right:20px;width:80px;height:auto;opacity:.7;z-index:10;pointer-events:none}.loading-spinner{width:40px;height:40px;border:3px solid var(--glass-border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:9999;animation:slideIn .3s ease}.toast-error{border-color:#ef4444}.toast-success{border-color:#10b981}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.session-warning-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000}.session-warning-modal{background:var(--bg-card);border:2px solid #ef4444;border-radius:var(--radius-lg);padding:2rem;text-align:center;max-width:400px}.session-warning-modal h3{color:#ef4444;margin-bottom:1rem}.header{position:sticky;top:0;z-index:100;padding:1rem 0}.header-content{display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);text-decoration:none}.logo-icon{font-size:1.75rem}.logo-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-image{height:40px;width:auto;max-width:150px;object-fit:contain}.nav{display:flex;align-items:center;gap:1.5rem}.nav-link{color:var(--text-secondary);font-weight:500;transition:color .2s;text-decoration:none}.nav-link:hover{color:var(--text-primary)}.nav-admin{color:var(--primary-light)}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:background .2s}.user-button:hover{background:var(--glass-bg)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff}.user-name{color:var(--text-primary);font-weight:500}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s}.user-menu:hover .user-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-header{padding:1rem;display:flex;flex-direction:column;gap:.25rem}.dropdown-header strong{color:var(--text-primary)}.dropdown-header span{font-size:.875rem;color:var(--text-muted)}.dropdown-divider{height:1px;background:var(--glass-border)}.dropdown-item{display:block;width:100%;padding:.75rem 1rem;text-align:left;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:all .2s}.dropdown-item:hover{background:var(--glass-bg);color:var(--text-primary)}.dropdown-item.logout{color:#ef4444}.dropdown-item.logout:hover{background:#ef44441a}@media(max-width:768px){.nav{gap:1rem}.user-name{display:none}}.footer{background:var(--bg-card);border-top:1px solid var(--glass-border);padding:3rem 0 1.5rem;margin-top:auto}.footer-content{display:flex;justify-content:space-between;gap:3rem;flex-wrap:wrap}.footer-brand{max-width:300px}.footer-logo{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);text-decoration:none;margin-bottom:.75rem}.footer-logo-image{height:36px;width:auto;max-width:120px;object-fit:contain}.footer-logo-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-tagline{color:var(--text-muted);font-size:.9rem}.footer-links{display:flex;gap:3rem;flex-wrap:wrap}.footer-column{display:flex;flex-direction:column;gap:.5rem}.footer-column h4{color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:.5rem}.footer-column a{color:var(--text-muted);font-size:.9rem;text-decoration:none;transition:color .2s}.footer-column a:hover{color:var(--primary-light)}.footer-bottom{border-top:1px solid var(--glass-border);margin-top:2rem;padding-top:1.5rem;text-align:center}.footer-bottom p{color:var(--text-muted);font-size:.85rem}@media(max-width:768px){.footer-content{flex-direction:column}.footer-links{gap:2rem}}.home{overflow:hidden}.hero{position:relative;min-height:80vh;display:flex;align-items:center;padding:4rem 0}.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.hero-badge{display:inline-flex;padding:.5rem 1rem;background:var(--glass-bg);border-radius:var(--radius-full);border:1px solid var(--glass-border);margin-bottom:1.5rem;font-size:.9rem;color:var(--primary-light)}.hero-content h1{font-size:clamp(2.5rem,5vw,4rem);line-height:1.1;margin-bottom:1.5rem}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2rem;max-width:500px}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.hero-visual{position:relative;height:400px}.floating-card{position:absolute;padding:1.5rem 2rem;animation:float 6s ease-in-out infinite}.floating-card:nth-child(1){top:20%;left:10%}.floating-card:nth-child(2){top:50%;right:10%}.floating-card:nth-child(3){bottom:10%;left:30%}.card-preview{display:flex;align-items:center;gap:.75rem;font-weight:500}.preview-icon{font-size:1.5rem}.hero-bg-glow{position:absolute;top:50%;left:50%;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);transform:translate(-50%,-50%);pointer-events:none;z-index:-1}.features{padding:6rem 0}.features h2{margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.feature-card{padding:2rem;text-align:center}.feature-icon{font-size:2.5rem;margin-bottom:1rem}.feature-card h3{margin-bottom:.75rem;font-size:1.125rem}.feature-card p{color:var(--text-muted);font-size:.9rem}.cta-section{padding:4rem 0 6rem}.cta-card{padding:4rem;text-align:center;border-radius:var(--radius-lg);background:var(--gradient-primary);border:none}.cta-card h2{color:#fff;margin-bottom:1rem}.cta-card p{color:#fffc;margin-bottom:2rem;font-size:1.125rem}.cta-card .btn{background:#fff;color:var(--primary-dark)}.cta-card .btn:hover{background:#ffffffe6}@media(max-width:768px){.hero .container{grid-template-columns:1fr;text-align:center}.hero-subtitle{margin:0 auto 2rem}.hero-cta{justify-content:center}.hero-visual{display:none}.cta-card{padding:2rem}}.course-card{display:block;text-decoration:none;color:inherit}.course-thumbnail{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg-dark)}.course-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.course-card:hover .course-thumbnail img{transform:scale(1.05)}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-dark) 100%);font-size:3rem}.course-badge{position:absolute;top:1rem;left:1rem}.course-title{font-size:1.125rem;margin-bottom:.5rem;color:var(--text-primary)}.course-description{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.5}.course-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--glass-border)}.course-price{font-size:1.25rem;font-weight:700;color:var(--primary-light)}.course-price.free{color:#10b981}.course-cta{font-size:.875rem;color:var(--text-muted);transition:color .2s}.course-card:hover .course-cta{color:var(--primary-light)}.courses-page{padding:3rem 0;min-height:60vh}.courses-header{text-align:center;margin-bottom:3rem}.courses-header h1{margin-bottom:.5rem}.courses-header p{color:var(--text-muted);font-size:1.125rem}.courses-filters{display:flex;justify-content:center;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1.25rem;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--primary);color:var(--text-primary)}.filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem}.loading-state p{margin-top:1rem;color:var(--text-muted)}.error-state{background:var(--bg-card);border-radius:var(--radius-lg)}.error-state p{color:#ef4444;margin-bottom:1rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{margin-bottom:.5rem}.empty-state p{color:var(--text-muted)}.video-player-container{position:relative;width:100%;max-width:100%;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius-lg);overflow:hidden;user-select:none;-webkit-user-select:none}.video-element{width:100%;height:100%;object-fit:contain;pointer-events:auto;-webkit-touch-callout:none;-webkit-user-drag:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.video-element::-webkit-media-controls-enclosure{display:none!important}.video-watermark{position:absolute;pointer-events:none;z-index:10}.video-watermark-text{color:#ffffff1f;font-size:clamp(.6rem,1.5vw,1rem);font-weight:600;text-align:center;transform:rotate(-25deg);white-space:nowrap;text-shadow:0 0 2px rgba(0,0,0,.5)}.video-logo{position:absolute;bottom:60px;right:20px;width:clamp(60px,8vw,100px);height:auto;opacity:.6;z-index:10;pointer-events:none}.video-controls{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(transparent,#000000e6);display:flex;align-items:center;gap:1rem;opacity:0;transition:opacity .3s}.video-player-container:hover .video-controls{opacity:1}.control-btn{background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:background .2s}.control-btn:hover{background:#fff3}.play-btn{font-size:1.75rem}.progress-container{flex:1}.progress-bar{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:#ffffff4d;border-radius:3px;cursor:pointer}.progress-bar::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--primary);border-radius:50%;cursor:pointer}.progress-bar::-moz-range-thumb{width:14px;height:14px;background:var(--primary);border-radius:50%;cursor:pointer;border:none}.time-display{font-size:.875rem;color:#fffc;min-width:80px;text-align:center}.video-title-overlay{position:absolute;top:0;left:0;right:0;padding:1rem;background:linear-gradient(rgba(0,0,0,.8),transparent);color:#fff;font-weight:600;opacity:0;transition:opacity .3s}.video-player-container:hover .video-title-overlay{opacity:1}.video-protection-overlay{position:absolute;inset:0;pointer-events:none;z-index:5}.video-player-container:fullscreen .video-controls{padding:1.5rem 2rem}.video-player-container:fullscreen .video-watermark-text{font-size:1.25rem}.video-player-container:fullscreen .video-logo{width:120px}.playback-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;padding:2rem;background:#000c;border-radius:var(--radius-lg);max-width:400px}.playback-error-icon{font-size:3rem;margin-bottom:1rem}.playback-error h3{margin-bottom:.5rem;color:#fbbf24}.playback-error p{margin-bottom:1.5rem;color:#fffc;font-size:.9rem}.playback-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff}.playback-loading p{margin-top:1rem;color:#ffffffb3}.course-detail{padding:2rem 0}.course-page-title{font-size:1.4rem;font-weight:600;margin-bottom:1.5rem;color:#000}.course-layout{display:grid;grid-template-columns:1fr 380px;gap:2rem;align-items:start}.course-main{display:flex;flex-direction:column;gap:1.5rem}.course-preview{position:relative;aspect-ratio:16 / 9;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-dark)}.course-preview img{width:100%;height:100%;object-fit:cover}.preview-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-dark) 100%)}.preview-overlay{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.lock-icon{font-size:3rem;margin-bottom:1rem}.preview-overlay p{color:var(--text-secondary);font-size:1.125rem}.course-info h1{margin-bottom:1rem}.course-description{color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem}.course-meta{display:flex;gap:2rem}.meta-item{display:flex;align-items:center;gap:.5rem;color:var(--text-muted)}.meta-icon{font-size:1.25rem}.course-sidebar{display:flex;flex-direction:column;gap:1.5rem;top:2rem;align-self:start;width:100%}@media(min-width:1025px){.course-sidebar{width:380px}}.purchase-card{padding:1.5rem}.price-display{text-align:center;margin-bottom:2rem}.price{font-size:2.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.price.free{background:#10b981;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.purchase-features{list-style:none;margin-top:1.5rem}.purchase-features li{padding:.5rem 0;color:var(--text-secondary);font-size:.9rem}.access-card{padding:1.5rem;background:linear-gradient(135deg,#10b9811a,#10b9810d);border-color:#10b9814d}.access-status{display:flex;align-items:center;gap:.5rem;color:#10b981;font-weight:600;font-size:1.125rem}.status-icon{width:24px;height:24px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem}.expiry{margin-top:.75rem;color:var(--text-muted);font-size:.875rem}.lessons-card{padding:1.5rem}.lessons-card h3{margin-bottom:1rem;font-size:1rem}.lessons-list{display:flex;flex-direction:column;gap:.5rem}.lesson-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all .2s;width:100%}.lesson-item:hover:not(:disabled){background:var(--glass-bg);border-color:var(--primary)}.lesson-item.active{background:var(--primary);border-color:var(--primary)}.lesson-item:disabled{opacity:.6;cursor:not-allowed}.lesson-number{width:24px;height:24px;background:var(--glass-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text-secondary);flex-shrink:0}.lesson-item.active .lesson-number{background:#fff3;color:#fff}.lesson-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.lesson-title{font-weight:500;color:var(--text-primary);font-size:.9rem}.lesson-item.active .lesson-title{color:#fff}.lesson-duration{font-size:.75rem;color:var(--text-muted)}.lesson-lock{font-size:.875rem}.terms-acceptance{margin-bottom:1rem;padding:1rem;background:var(--glass-bg);border-radius:var(--radius-md);border:1px solid var(--glass-border);background:#1d1d2099}.terms-checkbox{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:.85rem;line-height:1.5;color:var(--text-secondary)}.terms-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:2px;flex-shrink:0;cursor:pointer;accent-color:var(--primary)}.terms-checkbox a{color:var(--primary);text-decoration:underline}.terms-checkbox a:hover{color:var(--primary-hover)}.terms-hint{font-size:.8rem;color:#f59e0b;margin-top:.5rem;text-align:center}.materials-card{padding:1.5rem}.materials-card h3{margin-bottom:1rem;font-size:1rem}.materials-list{display:flex;flex-direction:column;gap:.5rem}.material-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:all .2s}.material-item:hover{background:var(--primary);border-color:var(--primary);color:#fff}.material-icon{font-size:1.25rem}.material-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.material-name{font-weight:500;font-size:.9rem}.material-size{font-size:.75rem;color:var(--text-muted)}.material-item:hover .material-size{color:#ffffffb3}.material-download{font-size:1rem;opacity:.6}.material-item:hover .material-download{opacity:1}@media(max-width:1024px){.course-layout{grid-template-columns:1fr}.course-sidebar{position:static}}.video-container{position:relative}.video-user-watermark{position:absolute;top:12px;left:16px;font-size:.85rem;font-weight:500;color:#000;opacity:.5;pointer-events:none;z-index:5;text-shadow:0 0 4px rgba(255,255,255,.8)}.video-logo-watermark{position:absolute;bottom:50px;right:16px;width:48px;height:48px;object-fit:contain;opacity:.5;pointer-events:none;z-index:5}.lesson-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem}.lesson-nav-btn{background:transparent;border:none;color:#000;font-size:.95rem;font-weight:600;cursor:pointer;padding:.5rem 0;transition:opacity .2s;letter-spacing:.5px}.lesson-nav-btn:hover:not(:disabled){opacity:.6}.lesson-nav-btn:disabled{opacity:.25;cursor:not-allowed}.auth-page{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-container{width:100%;max-width:440px;padding:2.5rem;border-radius:var(--radius-lg)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;margin-bottom:.5rem}.auth-header p{color:var(--text-muted)}.auth-warning{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);color:#fbbf24;padding:.875rem 1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;font-size:.9rem;text-align:center}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:.875rem 1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;font-size:.9rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:.25rem}.auth-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--glass-border)}.auth-footer p{color:var(--text-muted)}.auth-footer a{color:var(--primary-light);font-weight:500}.dashboard{padding:2rem 0}.dashboard-header{margin-bottom:3rem}.user-welcome{display:flex;align-items:center;gap:1.5rem}.user-avatar-large{width:80px;height:80px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff}.user-welcome h1{margin-bottom:.25rem}.user-welcome p{color:var(--text-muted)}.dashboard-section{margin-bottom:3rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0}.empty-purchases{padding:4rem 2rem;text-align:center}.empty-purchases .empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.empty-purchases h3{margin-bottom:.5rem}.empty-purchases p{color:var(--text-muted);margin-bottom:1.5rem}.purchases-grid{display:grid;gap:1rem}.purchase-card{display:flex;justify-content:space-between;align-items:center;padding:1.5rem}.purchase-card.expired{opacity:.6}.purchase-info h3{margin-bottom:.5rem;font-size:1.125rem}.purchase-meta{display:flex;align-items:center;gap:1rem}.purchase-date{color:var(--text-muted);font-size:.875rem}.status-badge{display:inline-flex;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.status-badge.active{background:#10b98126;color:#10b981}.status-badge.expired{background:#ef444426;color:#ef4444}@media(max-width:640px){.purchase-card{flex-direction:column;align-items:flex-start;gap:1rem}}.payment-success{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:2rem}.success-card{max-width:480px;width:100%;padding:3rem;text-align:center;border-radius:var(--radius-lg)}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;margin:0 auto 1.5rem}.error-icon{width:80px;height:80px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;margin:0 auto 1.5rem}.success-card h2{margin-bottom:.5rem}.success-card p{color:var(--text-muted);margin-bottom:2rem}.admin-page{padding:2rem 0}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{padding:1.5rem;text-align:center}.stat-icon{font-size:2rem;margin-bottom:.5rem}.stat-value{font-size:2.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.admin-section{margin-bottom:3rem}.admin-section h2{margin-bottom:1.5rem}.courses-table-container{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--glass-border);overflow:hidden}.courses-table{width:100%;border-collapse:collapse}.courses-table th,.courses-table td{padding:1rem 1.25rem;text-align:left}.courses-table th{background:#0003;font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.courses-table tbody tr{border-top:1px solid var(--glass-border);transition:background .2s}.courses-table tbody tr:hover{background:var(--glass-bg)}.courses-table tbody tr.dragging{opacity:.5;background:var(--glass-bg)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.5rem}.status-dot.published{background:#10b981}.status-dot.draft{background:#fbbf24}.course-manager{max-width:800px;margin:0 auto}.course-manager h1{margin-bottom:2rem}.manager-form{display:flex;flex-direction:column;gap:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-check{display:flex;align-items:center;gap:.75rem}.form-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary)}.form-actions{display:flex;gap:1rem;margin-top:1rem}.form-textarea{width:100%;min-height:120px;padding:.875rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--glass-border);border-radius:var(--radius-md);outline:none;resize:vertical;transition:border-color .2s ease}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}.lessons-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--glass-border)}.lessons-list{margin-bottom:1.5rem}.lesson-form-item{display:flex;gap:1rem;align-items:center;padding:1rem;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);margin-bottom:.75rem}.lesson-form-item .form-input{flex:1}.add-lesson-form{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:var(--glass-bg);border-radius:var(--radius-md)}.file-input-wrapper{position:relative}.file-input-wrapper input[type=file]{width:100%}@media(max-width:640px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}}.admin-actions{display:flex;gap:1rem}.settings-section{padding:2rem;max-width:600px}.settings-section h2{margin-bottom:.5rem}.settings-description{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.logo-preview-container{margin-bottom:1.5rem}.logo-preview{width:200px;height:100px;background:var(--bg-dark);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;overflow:hidden}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.logo-placeholder{width:200px;height:100px;background:var(--bg-dark);border:2px dashed var(--glass-border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.form-hint{display:block;margin-top:.5rem;font-size:.8rem;color:var(--text-muted)}.upload-progress{display:flex;align-items:center;gap:.75rem;margin-top:1rem;color:var(--text-muted)}.alert{padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem}.alert-success{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.alert-error{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.stripe-status{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem}.stripe-status.configured{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.stripe-status.not-configured{background:#fbbf2426;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.stripe-status .status-icon{font-size:1.25rem}.settings-form{display:flex;flex-direction:column;gap:1rem}.settings-form .btn{align-self:flex-start;margin-top:.5rem}.search-input-group{display:flex;gap:.75rem}.courses-table tr.selected{background:#6366f126}.badge-admin{background:#6366f133;color:var(--primary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.badge-user{background:#9ca3af33;color:var(--text-secondary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.session-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;border-radius:12px;font-size:.75rem;font-weight:600;background:var(--glass-bg);color:var(--text-muted)}.session-count.active{background:#10b98133;color:#10b981}.sessions-panel{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem}.sessions-list{display:flex;flex-direction:column;gap:.75rem}.session-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;gap:1rem}.session-info{flex:1}.session-browser{font-weight:600;margin-bottom:.25rem}.session-details{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text-muted)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.legal-page{padding:2rem 0 4rem;min-height:80vh;background:var(--gray-50)}.legal-content{max-width:800px;margin:0 auto;padding:3rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014}.legal-content h1{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem;text-align:center}.legal-content .last-updated{text-align:center;color:var(--gray-500);font-size:.9rem;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--gray-200)}.legal-content section{margin-bottom:2rem}.legal-content h2{font-size:1.25rem;font-weight:600;color:var(--primary);margin-bottom:1rem}.legal-content p{color:var(--gray-700);line-height:1.8;margin-bottom:1rem}.legal-content ul{list-style:disc;padding-left:1.5rem;margin-bottom:1rem}.legal-content li{color:var(--gray-700);line-height:1.8;margin-bottom:.5rem}.legal-content li strong{color:var(--gray-900)}@media(prefers-color-scheme:dark){.legal-page{background:var(--gray-900)}.legal-content{background:var(--gray-800);box-shadow:0 4px 20px #0000004d}.legal-content h1{color:var(--gray-50)}.legal-content .last-updated{color:var(--gray-400);border-bottom-color:var(--gray-700)}.legal-content p,.legal-content li{color:var(--gray-300)}.legal-content li strong{color:var(--gray-100)}}@media(max-width:768px){.legal-content{padding:1.5rem;margin:0 1rem}.legal-content h1{font-size:1.75rem}.legal-content h2{font-size:1.1rem}}
