@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@media (prefers-reduced-motion:reduce){*{transition:none!important}}@media (width<=900px){:root{--grid-cols:2}}.landing-container{background:var(--bg-1);width:100%;color:var(--text);min-height:100vh;overflow-x:hidden}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes glow{0%,to{box-shadow:0 0 20px #06f3}50%{box-shadow:0 0 40px #8b5cf64d}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.landing-header{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInDown .6s var(--ease);background:#ffffffd9;border-bottom:1px solid #0f172a0f;position:absolute;top:0;left:0;right:0}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.nav-container{max-width:var(--container-max);padding:16px var(--g-xx);justify-content:space-between;align-items:center;gap:var(--g-xx);margin:0 auto;display:flex}.logo-section{flex-shrink:0;align-items:center;display:flex}.logo-section img{width:auto;height:40px}.nav-links{gap:var(--g-xx);margin:0 auto;display:flex}.nav-link{color:var(--muted);font-size:var(--fs-sm);transition:color var(--trans) var(--ease);font-weight:600;text-decoration:none;position:relative}.nav-link:hover{color:var(--primary)}.nav-link:after{content:"";background:var(--primary);height:2px;transition:transform var(--trans) var(--ease);position:absolute;bottom:-4px;left:0;right:0;transform:scaleX(0)}.nav-link:hover:after{transform:scaleX(1)}.nav-auth{align-items:center;gap:var(--g);display:flex}.user-greeting{font-size:var(--fs-sm);color:var(--text);font-weight:600}.btn-text{color:var(--text);font-size:var(--fs-base);cursor:pointer;transition:color var(--trans) var(--ease);background:0 0;border:none;padding:8px 12px;font-weight:600}.btn-text:hover{color:var(--primary)}.btn-text:focus{box-shadow:none;outline:none}.btn-premium{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:var(--pill-radius);cursor:pointer;transition:all var(--trans) var(--ease);font-weight:700;font-size:var(--fs-sm);border:none;padding:10px 20px;box-shadow:0 8px 20px #0066ff4d}.btn-premium:hover{transform:translateY(-2px);box-shadow:0 12px 30px #06f6}.btn-premium:active{transform:translateY(0)}.btn-secondary{background:var(--surface);color:var(--primary);border:2px solid var(--primary);border-radius:var(--pill-radius);cursor:pointer;transition:all var(--trans) var(--ease);font-weight:700;font-size:var(--fs-base);padding:14px 30px}.btn-secondary:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.hero-section{max-width:var(--container-max);padding:80px var(--g-xx) 60px;animation:fadeInUp .8s var(--ease) .1s both;margin:0 auto}.hero-content{grid-template-columns:1fr 1fr;align-items:center;gap:60px;display:grid}.hero-text{animation:slideInLeft .8s var(--ease) .2s both}.hero-title{background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 20px;font-size:clamp(32px,5vw,56px);font-weight:800;line-height:1.2}.hero-subtitle{color:var(--muted);max-width:500px;margin:0 0 32px;font-size:clamp(18px,2vw,22px);line-height:1.6}.hero-cta{gap:var(--g-x);flex-wrap:wrap;display:flex}.hero-visual{height:500px;animation:slideInRight .8s var(--ease) .2s both;position:relative}.gradient-blob{opacity:.3;border-radius:40% 60% 70% 30%/40% 50% 60%;animation:6s ease-in-out infinite float;position:absolute}.blob-1{background:linear-gradient(135deg, var(--primary), var(--accent));width:300px;height:300px;animation-delay:0s;top:0;right:0}.blob-2{background:linear-gradient(135deg, var(--accent), #06b6d4);width:250px;height:250px;animation-delay:2s;bottom:0;left:0}.hero-card{background:var(--surface);border-radius:var(--card-radius);z-index:10;width:280px;padding:24px;animation:5s ease-in-out infinite float;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 60px #00000026}.card-header{font-size:var(--fs-sm);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-weight:700}.course-preview{flex-direction:column;gap:12px;display:flex}.course-item{background:var(--bg);border-radius:10px;align-items:center;gap:10px;padding:12px;display:flex}.course-badge{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:6px;padding:4px 8px;font-size:11px;font-weight:700;display:inline-block}.course-name{font-size:var(--fs-sm);color:var(--text);font-weight:600}.stats-section{max-width:var(--container-max);padding:60px var(--g-xx);animation:fadeInUp .8s var(--ease) .3s both;margin:0 auto}.stats-grid{gap:var(--g-x);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.stat-card{background:var(--surface);border-radius:var(--card-radius);text-align:center;box-shadow:var(--shadow-1);transition:all var(--trans) var(--ease);border:1px solid #0f172a0f;padding:32px 24px}.stat-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px #0066ff26}.stat-number{background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:40px;font-weight:800}.stat-label{color:var(--muted);font-size:var(--fs-sm);font-weight:600}.features-section{max-width:var(--container-max);padding:80px var(--g-xx) 60px;animation:fadeInUp .8s var(--ease) .4s both;margin:0 auto}.section-header{text-align:center;margin-bottom:60px}.section-header h2{color:var(--text);margin:0 0 16px;font-size:clamp(28px,4vw,44px);font-weight:800}.section-header p{font-size:var(--fs-lg);color:var(--muted);max-width:500px;margin:0 auto}.features-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;display:grid}.feature-card{background:var(--surface);border-radius:var(--card-radius);text-align:center;box-shadow:var(--shadow-1);transition:all var(--trans) var(--ease);animation:fadeInUp .6s var(--ease) both;border:1px solid #0f172a0f;padding:40px 32px}.feature-card:hover{border-color:#06f3;transform:translateY(-12px);box-shadow:0 24px 60px #06f3}.feature-icon{margin-bottom:20px;font-size:48px;animation:4s ease-in-out infinite float;display:block}.feature-card h3{font-size:var(--fs-xl);color:var(--text);margin:0 0 12px;font-weight:700}.feature-card p{font-size:var(--fs-base);color:var(--muted);margin:0;line-height:1.6}.courses-section{max-width:var(--container-max);padding:80px var(--g-xx) 60px;animation:fadeInUp .8s var(--ease) .5s both;margin:0 auto}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px;display:grid}.course-card{background:var(--surface);border-radius:var(--card-radius);box-shadow:var(--shadow-1);transition:all var(--trans) var(--ease);border:1px solid #0f172a0f;overflow:hidden}.course-card:hover{transform:translateY(-12px);box-shadow:0 24px 60px #06f3}.course-image{justify-content:center;align-items:center;height:200px;font-size:64px;display:flex;position:relative;overflow:hidden}.course-image:before{content:"";animation:3s infinite shimmer;animation-delay:var(--course-delay,0s);background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);position:absolute;inset:0}.course-icon{z-index:1;position:relative}.course-meta{padding:28px}.course-meta h3{font-size:var(--fs-lg);color:var(--text);margin:0 0 10px;font-weight:700}.course-meta p{font-size:var(--fs-sm);color:var(--muted);margin:0 0 20px;line-height:1.5}.course-footer{border-top:1px solid #0f172a0f;justify-content:space-between;align-items:center;padding-top:16px;display:flex}.duration{font-size:var(--fs-sm);color:var(--muted);font-weight:600}.final-cta{max-width:var(--container-max);padding:80px var(--g-xx) 60px;animation:fadeInUp .8s var(--ease) .6s both;margin:0 auto}.cta-content{background:linear-gradient(135deg, var(--primary), var(--accent));border-radius:var(--card-radius);padding:80px var(--g-xx) 60px;text-align:center;color:#fff;position:relative;overflow:hidden}.cta-content:before{content:"";background:#ffffff0d;border-radius:50%;width:600px;height:600px;position:absolute;top:-50%;right:-50%}.cta-content:after{content:"";background:#ffffff0d;border-radius:50%;width:400px;height:400px;position:absolute;bottom:-30%;left:-30%}.cta-content h2{z-index:1;margin:0 0 16px;font-size:clamp(28px,4vw,44px);font-weight:800;position:relative}.cta-content p{font-size:var(--fs-lg);opacity:.95;z-index:1;margin:0 0 32px;position:relative}.cta-content .btn-premium{color:var(--primary);z-index:1;background:#fff;position:relative;box-shadow:0 10px 30px #0003}.cta-content .btn-premium:hover{background:var(--bg);color:var(--primary)}.landing-footer{color:#fff;padding:60px var(--g-xx) 20px;animation:fadeInUp .8s var(--ease) .7s both;background:#0f1724}.footer-content{max-width:var(--container-max);border-bottom:1px solid #ffffff1a;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:40px;margin:0 auto 40px;padding-bottom:40px;display:grid}.footer-section h4{font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;font-weight:700}.footer-section a{color:#cbd5e1;font-size:var(--fs-sm);transition:color var(--trans) var(--ease);margin-bottom:10px;text-decoration:none;display:block}.footer-section a:hover{color:var(--primary)}.footer-bottom{max-width:var(--container-max);text-align:center;color:#64748b;font-size:var(--fs-sm);margin:0 auto}.error-message{color:#dc2626;border-radius:var(--card-radius);text-align:center;background:#ef44441a;margin:20px 0;padding:16px}.loading{text-align:center;color:var(--muted);font-size:var(--fs-lg);padding:40px}@media (width<=768px){.hero-content{grid-template-columns:1fr;gap:40px}.hero-visual,.nav-links{display:none}.features-grid{grid-template-columns:1fr}.hero-cta{flex-direction:column}.hero-cta .btn-premium,.hero-cta .btn-secondary{width:100%}.footer-content{grid-template-columns:repeat(2,1fr);gap:20px}.stats-grid{grid-template-columns:repeat(2,1fr)}}.banner h2{font-size:var(--fs-xl);margin-bottom:8px}.banner p{opacity:.95;max-width:60%}.banner .btn{margin-top:18px}.course-grid{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.course-card{background:var(--surface);box-shadow:var(--shadow-2);transition:transform var(--trans) var(--ease), box-shadow var(--trans) var(--ease);border-radius:14px;padding:18px;overflow:hidden}.course-card:hover{box-shadow:var(--shadow-1);transform:translateY(-8px)}.course-thumb{background:linear-gradient(135deg,#7dd3fc,#60a5fa);border-radius:12px;height:160px;margin-bottom:12px;display:block}.course-card h4{margin-bottom:8px;font-size:16px}.course-card p{color:var(--muted);max-height:44px;font-size:14px;overflow:hidden}.price{align-items:center;gap:10px;display:flex}.old{color:#9ca3af;text-decoration:none}.new{color:var(--primary);font-weight:700}.avatar{border-radius:10px;width:44px;height:44px}@media (width<=1100px){.course-grid{grid-template-columns:repeat(2,1fr)}.banner p{max-width:100%}}@media (width<=720px){.layout{flex-direction:column}.sidebar{border-bottom:1px solid #0f172a0a;flex-direction:row;width:100%;height:auto;padding:12px}.course-grid{grid-template-columns:1fr}.header{margin:12px 0;padding:8px}}.decription p{color:var(--muted);font-size:var(--fs-sm)}@media (prefers-reduced-motion:reduce){*{transition:none!important}}@media (width<=900px){:root{--grid-cols:2}}.auth-page{background:var(--bg-1);min-height:100vh;animation:fadeInUp .6s var(--ease);justify-content:center;align-items:center;padding:20px;display:flex}.auth-container{border-radius:var(--card-radius);width:100%;max-width:900px;min-height:500px;animation:slideInUp .6s var(--ease);grid-template-columns:1fr 1fr;gap:0;display:grid;overflow:hidden;box-shadow:0 20px 60px #00000026}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-form-side{background:var(--surface);flex-direction:column;justify-content:center;padding:60px 48px;display:flex}.auth-image-side{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex;position:relative;overflow:hidden}.auth-image-side:before{content:"";background:#ffffff1a;border-radius:50%;width:600px;height:600px;position:absolute;top:-50%;right:-50%}.auth-image-side:after{content:"";background:#ffffff0d;border-radius:50%;width:400px;height:400px;position:absolute;bottom:-30%;left:-30%}.image-content{z-index:1;text-align:center;position:relative}.image-icon{margin-bottom:24px;font-size:64px}.image-content h2{margin:0 0 16px;font-size:28px;font-weight:800}.image-content p{opacity:.9;margin:0;font-size:16px;line-height:1.6}.auth-box{background:var(--surface);border-radius:var(--card-radius);box-shadow:var(--shadow-1);width:100%;max-width:420px;animation:slideInUp .6s var(--ease);padding:40px 32px}.auth-box h1{color:var(--text);background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:28px;font-weight:800}.auth-box h2{color:var(--text);margin:0 0 8px;font-size:28px;font-weight:800}.auth-subtitle{color:var(--muted);font-size:var(--fs-base);margin:0 0 32px;line-height:1.6}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text);font-weight:600;font-size:var(--fs-sm)}.form-input{border-radius:var(--radius-sm);font-size:var(--fs-base);transition:all var(--trans) var(--ease);box-sizing:border-box;background:var(--bg);color:#000;border:1px solid #0f172a1a;padding:12px 16px;font-family:inherit}.form-input:focus{border-color:var(--primary);background:var(--surface);outline:none;box-shadow:0 0 0 3px #0066ff1a}.form-input::placeholder{color:var(--muted)}.auth-button{border-radius:var(--pill-radius);font-size:var(--fs-base);cursor:pointer;transition:all var(--trans) var(--ease);border:none;margin-top:8px;padding:12px 24px;font-weight:700}.auth-btn-primary{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;width:100%;box-shadow:0 8px 20px #0066ff4d}.auth-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px #06f6}.auth-btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-btn-secondary{background:var(--surface);color:var(--primary);border:2px solid var(--primary)}.auth-btn-secondary:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.auth-divider{align-items:center;gap:16px;margin:24px 0;display:flex}.divider-line{background:#0f172a1a;flex:1;height:1px}.divider-text{color:var(--muted);font-size:var(--fs-sm);font-weight:600}.auth-footer{text-align:center;color:var(--muted);font-size:var(--fs-sm);margin-top:24px}.auth-footer a{color:var(--primary);transition:color var(--trans) var(--ease);font-weight:600;text-decoration:none}.auth-footer a:hover{color:var(--accent)}.auth-message{border-radius:var(--radius-sm);font-size:var(--fs-sm);animation:slideInDown .3s var(--ease);margin-bottom:16px;padding:12px 16px}.message-error{color:#dc2626;background:#ef44441a;border:1px solid #ef44444d}.message-success{color:#16a34a;background:#16a34a1a;border:1px solid #16a34a4d}.button-loading{align-items:center;gap:8px;display:inline-flex}.spinner-small{border:2px solid;border-top-color:#0000;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.auth-container{grid-template-columns:1fr}.auth-image-side{display:none}.auth-form-side{padding:40px 24px}.auth-box{max-width:100%}.auth-form-side h1,.auth-box h1{font-size:24px}.form-input{font-size:16px}}@media (width<=420px){.auth-form-side{padding:32px 16px}.auth-box{padding:24px 16px}.auth-box h1,.auth-box h2{font-size:22px}.auth-subtitle{font-size:var(--fs-sm)}}@media (prefers-reduced-motion:reduce){*{transition:none!important}}@media (width<=900px){:root{--grid-cols:2}}:root{--f8-primary:#f05123;--f8-primary-hover:#d1411e;--f8-primary-light:#ffeee8;--f8-text-main:#292929;--f8-text-muted:#757575;--f8-border:#e8e8e8;--f8-bg-body:#f1f1f1;--f8-bg-card:#fff;--f8-success:#1dbfaf;--f8-success-light:#e4f7f5;--f8-warning:#f59e0b;--f8-warning-light:#fef3c7;--f8-danger:#f43f5e;--f8-danger-light:#ffe4e6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.dashboard-container{background:var(--f8-bg-body);max-width:1280px;min-height:100vh;color:var(--f8-text-main);flex-direction:column;gap:32px;margin:0 auto;padding:32px 24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;display:flex}.dashboard-layout{grid-template-columns:260px 1fr;gap:0;min-height:100vh;display:grid}.dashboard-header{background:0 0;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.heading-1{color:var(--f8-text-main);letter-spacing:-.5px;margin:0 0 8px;font-size:28px;font-weight:900}.heading-2{color:var(--f8-text-main);margin:0;font-size:20px;font-weight:700}.text-muted{color:var(--f8-text-muted);margin:0;font-size:15px;font-weight:500}.text-center{text-align:center}.font-bold{font-weight:700}.text-mono{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:14px}.mb-4{margin-bottom:16px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.p-4{padding:16px}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:999px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary:active,.btn-secondary:active,.btn-danger:active{transform:translateY(1px)}.btn-primary{background-color:var(--f8-primary);color:#fff}.btn-primary:hover{background-color:var(--f8-primary-hover);opacity:.9}.btn-secondary{color:var(--f8-text-main);background-color:#e8e8e8}.btn-secondary:hover{background-color:#d4d4d4}.btn-text{color:var(--f8-primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600;text-decoration:none}.btn-danger{background-color:var(--f8-danger);color:#fff}.btn-danger:hover{background-color:#c82a48}.btn-sm{padding:6px 12px;font-size:13px}.icon-emerald{background:var(--f8-success-light);color:var(--f8-success)}.btn-text:hover{text-decoration:none}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.activity-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}.chart-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;display:grid}.card,.stat-card{background:var(--f8-bg-card);border:1px solid #0000000a;border-radius:16px;padding:24px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #00000008}.card:hover,.stat-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px -4px #00000014}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.border-bottom{border-bottom:1px solid var(--f8-border);margin-bottom:0;padding-bottom:16px}.chart-container{width:100%;height:300px;margin-top:16px}.stat-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.stat-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;display:flex}.icon-indigo,.icon-primary{background:var(--f8-primary-light);color:var(--f8-primary)}.stat-title{color:var(--f8-text-muted);margin:0 0 8px;font-size:15px;font-weight:600}.stat-value{color:var(--f8-text-main);letter-spacing:-1px;margin:0;font-size:36px;font-weight:800}.trend-badge{border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:13px;font-weight:700;display:flex}.status-badge{text-transform:uppercase;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-block}.badge-emerald{background:var(--f8-success-light);color:var(--f8-success)}.badge-amber{background:var(--f8-warning-light);color:var(--f8-warning)}.badge-rose{background:var(--f8-danger-light);color:var(--f8-danger)}.table-container{margin:0 -24px;padding:0 24px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:500px}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--f8-border);vertical-align:middle;padding:16px}.data-table th{color:var(--f8-text-muted);text-transform:uppercase;letter-spacing:.5px;background-color:#fafafa;font-size:13px;font-weight:700}.data-table tbody tr{transition:background .2s}.data-table tbody tr:hover{background-color:#f9f9f9}.data-table tbody tr:last-child td{border-bottom:none}.user-info{align-items:center;gap:12px;display:flex}.avatar{background:var(--f8-primary-light);width:40px;height:40px;color:var(--f8-primary);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.user-name{color:var(--f8-text-main);font-weight:600}.action-list{flex-direction:column;gap:16px;display:flex}.action-item{border:1px solid var(--f8-border);cursor:pointer;text-align:left;background:0 0;border-radius:16px;align-items:center;gap:16px;padding:16px;transition:all .2s;display:flex}.action-item:hover{border-color:var(--f8-primary);background:var(--f8-primary-light);transform:translate(4px)}.action-icon{border:1px solid var(--f8-border);background:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.action-title{color:var(--f8-text-main);margin:0 0 4px;font-size:15px;font-weight:700}.action-desc{color:var(--f8-text-muted);margin:0;font-size:13px;font-weight:500}.loading-container{justify-content:center;align-items:center;height:60vh;display:flex}.spinner{border:4px solid var(--f8-border);border-top-color:var(--f8-primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.error-container{background-color:var(--f8-danger-light);border:2px dashed var(--f8-danger);height:256px;color:var(--f8-danger);text-align:center;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;padding:24px;box-shadow:0 10px 25px -5px #0000001a;opacity:1!important;visibility:visible!important;display:block!important;position:relative!important}.modal h3{margin-top:0;margin-bottom:24px;font-size:20px}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.badge-student{background:var(--f8-success-light);color:var(--f8-success)}.badge-teacher{background:var(--f8-warning-light);color:var(--f8-warning)}.badge-admin{background:var(--f8-danger-light);color:var(--f8-danger)}.error-icon{margin-bottom:12px;font-size:40px}@media (width<=1024px){.activity-grid{grid-template-columns:1fr}}@media (width<=768px){.dashboard-layout{grid-template-columns:1fr}.dashboard-header{flex-direction:column;grid-column:1;align-items:flex-start}.dashboard-container{padding:16px}}@media (width<=640px){.hidden-sm{display:none}.chart-grid{grid-template-columns:1fr}}.dashboard-sidebar{border-right:1px solid var(--f8-border);z-index:100;background:#fff;flex-direction:column;height:100vh;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid var(--f8-border);align-items:center;gap:12px;padding:24px;display:flex}.sidebar-logo h2{color:var(--f8-text-main);margin:0;font-size:20px;font-weight:800}.logo-icon{background:var(--f8-primary);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:700;display:flex}.sidebar-nav{flex:1;padding:24px 16px;overflow-y:auto}.sidebar-menu{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.sidebar-link{color:var(--f8-text-muted);border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.sidebar-link:hover{background:var(--f8-bg-body);color:var(--f8-text-main);text-decoration:none}.sidebar-link.active{background:var(--f8-primary-light);color:var(--f8-primary);position:relative}.sidebar-link.active:before{content:"";background:var(--f8-primary);border-radius:0 4px 4px 0;width:4px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-footer{border-top:1px solid var(--f8-border);padding:24px 16px}.user-info-sidebar{align-items:center;gap:12px;margin-bottom:16px;padding:0 8px;display:flex}.user-details p{margin:0}.user-role{color:var(--f8-text-muted);font-size:12px}.btn-logout{background:var(--f8-danger-light);width:100%;color:var(--f8-danger);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px;font-weight:600;transition:all .2s;display:flex}.btn-logout:hover{background:#fecdd3}.dashboard-content-wrapper{flex-direction:column;width:100%;min-width:0;display:flex}.dashboard-header{border-bottom:1px solid var(--f8-border);z-index:50;background:#fff;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.header-right{align-items:center;gap:20px;display:flex}.search-bar{align-items:center;display:flex;position:relative}.search-bar input{border:1px solid var(--f8-border);background:var(--f8-bg-body);border-radius:999px;outline:none;width:250px;padding:10px 16px 10px 40px;transition:all .2s}.search-bar input:focus{border-color:var(--f8-primary);box-shadow:0 0 0 3px var(--f8-primary-light);background:#fff}.search-icon{color:var(--f8-text-muted);position:absolute;left:14px}.notification-btn{cursor:pointer;background:0 0;border:none;font-size:20px;position:relative}.notification-dot{background:var(--f8-danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:0;right:0}.dashboard-main{flex:1;padding:0;animation:.4s ease-out fadeIn;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-label{color:var(--f8-text-main);margin-bottom:8px;font-size:14px;font-weight:700;display:block}.form-input,.form-textarea{border:1px solid var(--f8-border);box-sizing:border-box;border-radius:8px;width:100%;padding:12px 16px;font-family:inherit;font-size:15px;transition:all .2s;color:var(--f8-text-main)!important;background-color:#fff!important}.form-input option{color:var(--f8-text-main);background-color:#fff}.form-input:focus,.form-textarea:focus{border-color:var(--f8-primary);outline:none;box-shadow:0 0 0 3px #f0512326}.form-textarea{resize:vertical;min-height:120px}.form-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=768px){.form-row{grid-template-columns:1fr}}.preset-amounts{flex-wrap:wrap;gap:10px;display:flex}.preset-amounts .btn-secondary.active{background-color:var(--f8-primary);color:#fff;border-color:var(--f8-primary)}.settings-container{background:0 0;max-width:800px;margin:0 auto;padding-top:20px}.progress-track{background:#e8e8e8;border-radius:3px;flex:1;height:6px;overflow:hidden}.progress-fill-success{background:var(--f8-success);height:100%;transition:width .3s}.course-thumbnail-sm{object-fit:cover;background:var(--f8-primary-light);border-radius:8px;width:40px;height:40px}.course-thumbnail-md{object-fit:cover;background:var(--f8-border);border-radius:4px;width:80px;height:45px}.payment-container{max-width:520px;margin:40px auto}.payment-card{text-align:center;border:1px solid var(--f8-border);background:linear-gradient(145deg,#fff,#fafafa);border-radius:20px;padding:32px 24px;position:relative;box-shadow:0 12px 30px #00000014}.payment-title{font-size:22px;font-weight:800}.payment-desc{color:var(--f8-text-muted);margin-bottom:20px}.qr-wrapper{background:#fff;border-radius:20px;padding:16px;display:inline-block;box-shadow:0 8px 20px #0000000d}.qr-wrapper img{width:220px}.qr-wrapper:after{content:"";border:2px solid var(--f8-primary);pointer-events:none;border-radius:24px;animation:1.6s infinite pulse;position:absolute;inset:-10px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.payment-code{margin-top:16px}.payment-code strong{color:var(--f8-primary);background:var(--f8-primary-light);border-radius:8px;padding:6px 12px}.payment-status{color:var(--f8-primary);justify-content:center;gap:10px;margin-top:20px;font-weight:600;display:flex}.payment-status .spinner{border-width:3px;width:20px;height:20px}.btn-cancel-payment{border:1px solid var(--f8-border);color:var(--f8-danger);background:#fff;border-radius:999px;margin-top:20px;padding:10px 18px}.btn-cancel-payment:hover{background:var(--f8-danger-light)}.payment-success{text-align:center;padding:40px 20px}.checkmark{width:80px;height:80px;stroke:var(--f8-success);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;animation:.3s ease-in-out scaleIn}.checkmark circle{stroke-dasharray:166;stroke-dashoffset:166px;stroke:var(--f8-success);fill:none;animation:.6s ease-out forwards drawCircle}.checkmark path{stroke-dasharray:48;stroke-dashoffset:48px;stroke:var(--f8-success);animation:.4s ease-out .6s forwards drawCheck}@keyframes drawCircle{to{stroke-dashoffset:0}}@keyframes drawCheck{to{stroke-dashoffset:0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.component-header{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--f8-border);z-index:100;background:#ffffffd9;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.header-left,.header-right{flex:1;align-items:center;display:flex}.header-right{justify-content:flex-end}.header-center{text-align:center;flex-direction:column;flex:2;justify-content:center;align-items:center;display:flex}.header-subtitle{color:var(--f8-text-muted);margin:4px 0 0;font-size:14px;font-weight:500}.btn-back{color:var(--f8-text-muted);cursor:pointer;background:#00000005;border:1px solid #0000000d;border-radius:999px;align-items:center;gap:8px;padding:8px 16px 8px 12px;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.25,.8,.25,1);display:inline-flex;position:relative;overflow:hidden}.btn-back:before{content:"";background:var(--f8-primary-light);opacity:0;transform-origin:0;z-index:0;width:100%;height:100%;transition:all .3s cubic-bezier(.25,.8,.25,1);position:absolute;top:0;left:0;transform:scaleX(.5)}.btn-back:hover{color:var(--f8-primary);border-color:#f0512333;transform:translate(-4px);box-shadow:0 4px 12px #f0512314}.btn-back:hover:before{opacity:1;transform:scaleX(1)}.btn-back svg{z-index:1;transition:transform .3s,stroke .3s;position:relative}.btn-back span{z-index:1;position:relative}.btn-back:hover svg{stroke:var(--f8-primary);transform:translate(-2px)}@media (width<=768px){.component-header{padding:12px 16px}.header-title{font-size:18px}.btn-back span{display:none}.btn-back{padding:8px}}.enrollments-page{background-color:var(--bg-body);flex-direction:column;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.enrollments-header{text-align:center;margin-bottom:32px}.enrollments-header h1{color:var(--text-main);margin-bottom:8px;font-size:28px;font-weight:700}.enrollments-header p{color:var(--text-muted)}.btn-back,.btn-unenroll{border-radius:var(--radius-md);cursor:pointer;transition:var(--trans);font-weight:600;font-family:var(--font-family);border:none;align-items:center;gap:8px;display:inline-flex}.btn-back{color:var(--primary);background:0 0;padding:8px 16px;font-size:14px}.btn-back:hover{background:var(--primary-light);transform:translate(-4px)}.btn-unenroll{color:var(--danger);border:1px solid var(--danger);background:0 0;padding:8px 16px;font-size:14px}.btn-unenroll:hover:not(:disabled){background:var(--danger-light)}.enrollments-container{width:100%;max-width:1100px;box-shadow:none;background:0 0;padding:0}.filter-tabs{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:24px;margin-bottom:32px;display:flex}.filter-tab{color:var(--text-muted);cursor:pointer;transition:all var(--trans);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 4px;font-size:15px;font-weight:500}.filter-tab:hover{color:var(--text-main)}.filter-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.enrollments-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;display:grid}.enrollment-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all var(--trans);flex-direction:column;display:flex;overflow:hidden}.enrollment-card:hover{box-shadow:var(--shadow-md);border-color:#cbd5e1;transform:translateY(-4px)}.enrollment-image{background:#f1f5f9;width:100%;height:160px;position:relative}.enrollment-image img{object-fit:cover;width:100%;height:100%}.status-badge{border-radius:var(--radius-sm);text-transform:uppercase;color:#fff;padding:4px 10px;font-size:11px;font-weight:700;position:absolute;top:12px;right:12px}.status-badge.status-active{background:var(--warning)}.status-badge.status-completed{background:var(--success)}.enrollment-content{flex-direction:column;flex:1;padding:20px;display:flex}.enrollment-content h3{color:var(--text-main);margin:0 0 4px;font-size:16px;font-weight:700;line-height:1.4}.teacher-name{color:var(--text-muted);margin:0 0 16px;font-size:13px}.progress-section{margin:16px 0}.progress-header{color:var(--text-main);justify-content:space-between;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.progress-fill{background-color:var(--primary);border-radius:var(--radius-full);height:100%;transition:width .5s}.enrollment-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:auto;padding-top:16px;display:flex}.enrolled-date{color:var(--text-muted);font-size:12px}@media (prefers-reduced-motion:reduce){*{transition:none!important}}@media (width<=900px){:root{--grid-cols:2}}.user-profile-page{background:var(--bg-1);min-height:100vh;color:var(--text);justify-content:center;align-items:center;padding-bottom:60px}.profile-container{max-width:1200px;margin:0 auto;padding:40px 24px}.profile-section{animation:fadeInUp .6s var(--ease);background:#ffffff05;border:1px solid #ffffff14;border-radius:16px;margin-bottom:50px;padding:32px}.section-title{color:var(--text);align-items:center;gap:12px;margin-bottom:28px;font-size:24px;font-weight:600;display:flex}.section-title .icon{font-size:28px}.user-info-card{background:linear-gradient(135deg,#6366f11a 0%,#8b5cf61a 100%);border:1px solid #6366f133;border-radius:12px;align-items:center;gap:32px;padding:28px;display:flex}.user-avatar{flex-shrink:0}.user-avatar img{border:3px solid var(--primary);object-fit:cover;width:120px;height:120px;animation:scaleIn .5s var(--ease);border-radius:50%;box-shadow:0 8px 24px #6366f14d}.user-details{flex:1}.user-name{color:var(--text);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:700}.user-email{color:var(--text-secondary);margin-bottom:16px;font-size:15px}.user-role{gap:12px;display:flex}.role-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;display:inline-block}.role-admin{color:#ef4444;background:#ef444433}.role-teacher{color:#3b82f6;background:#3b82f633}.role-student{color:#22c55e;background:#22c55e33}.btn-edit-profile{background:var(--primary);color:#fff;cursor:pointer;transition:all .3s var(--ease);white-space:nowrap;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600}.btn-edit-profile:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 20px #6366f14d}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;padding:16px 0;display:grid}.course-card{transition:all .3s var(--ease);animation:fadeInUp .6s var(--ease);background:#ffffff0d;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;height:100%;display:flex;overflow:hidden}.course-card:hover{border-color:#6366f14d;transform:translateY(-4px);box-shadow:0 12px 32px #6366f126}.course-image{background:linear-gradient(135deg,#6366f133 0%,#8b5cf633 100%);width:100%;height:180px;position:relative;overflow:hidden}.course-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s var(--ease)}.course-card:hover .course-image img{transform:scale(1.05)}.status-badge{text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;position:absolute;top:12px;right:12px}.status-active{color:#fff;background:#22c55ee6}.status-completed{color:#fff;background:#6366f1e6}.status-cancelled{color:#fff;background:#9ca3afe6}.course-info{flex-direction:column;flex:1;padding:20px;display:flex}.course-title{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:16px;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.course-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.course-meta{border-top:1px solid #ffffff14;border-bottom:1px solid #ffffff14;flex-direction:column;gap:8px;margin-bottom:16px;padding:12px 0;display:flex}.meta-item{justify-content:space-between;align-items:center;font-size:12px;display:flex}.progress-container{margin-bottom:16px}.progress-label{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.progress-label span:first-child{color:var(--text-secondary)}.progress-percent{color:var(--primary)}.progress-bar{background:#ffffff14;border-radius:4px;width:100%;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary) 0%, var(--primary-light) 100%);height:100%;transition:width .5s var(--ease);border-radius:4px;box-shadow:0 0 12px #6366f166}.course-date{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:16px;font-size:12px;display:flex}.course-date .icon{font-size:14px}.btn-continue{background:linear-gradient(135deg, var(--primary) 0%, #8b5cf6 100%);color:#fff;cursor:pointer;transition:all .3s var(--ease);text-align:center;border:none;border-radius:8px;margin-top:auto;padding:10px 16px;font-size:13px;font-weight:600}.btn-continue:hover{transform:translateY(-2px);box-shadow:0 8px 16px #6366f14d}.btn-continue:active{transform:translateY(0)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 24px;display:flex}.empty-icon{animation:bounce 2s var(--ease) infinite;margin-bottom:16px;font-size:64px}.empty-title{color:var(--text);margin-bottom:8px;font-size:20px;font-weight:600}.empty-desc{color:var(--text-secondary);max-width:400px;margin-bottom:24px;font-size:14px}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;transition:all .3s var(--ease);border:none;border-radius:8px;padding:12px 28px;font-size:14px;font-weight:600}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 20px #6366f14d}.loading-state{text-align:center;color:var(--text-secondary);justify-content:center;align-items:center;min-height:300px;padding:60px 24px;display:flex}.loading-state p{animation:pulse 1.5s var(--ease) infinite}.error-banner{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-bottom:24px;padding:16px}.error-banner p{color:#ef4444;margin:0;font-size:14px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (width<=768px){.profile-container{padding:24px 16px}.profile-section{margin-bottom:30px;padding:20px}.user-info-card{text-align:center;flex-direction:column;gap:20px}.user-avatar img{width:100px;height:100px}.user-name{font-size:24px}.user-role{justify-content:center}.btn-edit-profile{width:100%}.courses-grid{grid-template-columns:1fr;gap:16px}.section-title{font-size:20px}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}50%{transform:translate(8px)}75%{transform:translate(-8px)}}@keyframes glowSuccess{0%{background:var(--success);box-shadow:0 0 20px #16a34a99}50%{background:var(--success);box-shadow:0 0 30px #16a34acc}to{background:var(--success);box-shadow:0 0 20px #16a34a66}}@keyframes glowError{0%,to{background:var(--danger)}50%{background:#ff6b6b}}@keyframes expandRipple{to{opacity:0;transform:scale(4)}}@keyframes buttonPress{0%{transform:translateY(0)}50%{transform:translateY(2px)}to{transform:translateY(0)}}.quiz-container{width:100%;max-width:900px;padding:var(--g-x);background:var(--bg);border-radius:var(--radius);animation:slideUp var(--trans) var(--ease);margin:0 auto}.quiz-container h2{text-align:center;margin:0 0 var(--g-xx) 0;font-size:var(--fs-xxl);color:var(--text-main);letter-spacing:-.5px;font-weight:800}.question-block{margin-bottom:var(--g-xx);padding:var(--g-xx);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:slideUp var(--trans) var(--ease);transition:all var(--trans) var(--ease);position:relative}.question-block:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #0066ff1a, var(--shadow-lg)}.question-block-number{background:var(--primary);color:#fff;width:32px;height:32px;font-weight:700;font-size:var(--fs-sm);margin-bottom:var(--g);border-radius:50%;justify-content:center;align-items:center;display:flex}.question-block h3{font-size:var(--fs-lg);color:var(--text-main);margin:0 0 var(--g-x) 0;letter-spacing:-.3px;font-weight:700;line-height:1.5}.question-block p{font-size:var(--fs-base);color:var(--text-main);margin:0 0 var(--g-x) 0;font-weight:500;line-height:1.6}.question-text{color:var(--text-main);text-align:center;margin:0 0 var(--g-xx) 0;font-size:18px;font-weight:700;line-height:1.7}.options-list{gap:var(--g-x);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.options-list li{margin:0;list-style:none}.options-list input[type=radio]{visibility:hidden;pointer-events:none;display:none;position:absolute}.options-list label{align-items:center;gap:var(--g-x);padding:var(--g-x);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--fs-base);color:var(--text-main);transition:all var(--trans) var(--ease);min-height:60px;font-weight:500;display:flex;position:relative;overflow:hidden}.options-list label:hover{border-color:var(--primary);background:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.options-list label:before{content:"";border:2px solid var(--border);background:var(--surface);width:24px;min-width:24px;height:24px;transition:all var(--trans) var(--ease);border-radius:50%;justify-content:center;align-items:center;display:flex}.options-list input[type=radio]:checked+label{border-color:var(--primary);background:linear-gradient(135deg, var(--primary-light) 0%, #0066ff0d 100%);animation:bounceIn var(--trans) var(--ease);font-weight:600;box-shadow:0 0 0 3px #0066ff26}.options-list input[type=radio]:checked+label:before{background:var(--primary);border-color:var(--primary);box-shadow:inset 0 0 0 3px var(--surface)}.options-list input[type=radio]:checked+label:after{content:"✓";color:var(--primary);font-size:14px;font-weight:700;position:absolute;top:50%;left:15px;transform:translateY(-50%)}.options-list input[type=radio]:checked+label.correct,.options-list label.correct{border-color:var(--success);background:var(--success-light);animation:.6s ease-out glowSuccess}.options-list label.correct:after{content:"✓";right:var(--g-x);color:var(--success);animation:bounceIn var(--trans) var(--ease);font-size:18px;font-weight:700;position:absolute}.options-list label.incorrect{border-color:var(--danger);background:var(--danger-light);animation:.5s ease-out shake}.options-list label.incorrect:after{content:"✗";right:var(--g-x);color:var(--danger);animation:bounceIn var(--trans) var(--ease);font-size:18px;font-weight:700;position:absolute}.options-list label.incorrect:before{border-color:var(--danger);background:var(--danger);animation:.5s ease-out shake}.options-list input:disabled+label{pointer-events:none;opacity:.8}.quiz-submit-btn{width:100%;max-width:400px;margin:var(--g-xx) auto 0;font-size:var(--fs-base);background:linear-gradient(135deg, var(--primary) 0%, var(--primary-600) 100%);color:#fff;border-radius:var(--pill-radius);cursor:pointer;transition:all var(--trans) var(--ease);text-transform:uppercase;letter-spacing:.5px;border:none;min-height:56px;padding:16px 32px;font-weight:700;display:block;position:relative;overflow:hidden;box-shadow:0 8px 24px #06f6,0 0 #06f3}.quiz-submit-btn:before{content:"";width:0;height:0;transition:width var(--trans) var(--ease), height var(--trans) var(--ease);background:#ffffff4d;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.quiz-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #06f9,0 0 #0066ff4d}.quiz-submit-btn:hover:not(:disabled):before{width:300px;height:300px}.quiz-submit-btn:active:not(:disabled){animation:buttonPress .3s var(--ease);transform:translateY(0);box-shadow:0 4px 12px #06f6,0 0 #0066ff26}.quiz-submit-btn:disabled{opacity:.6;cursor:not-allowed;background:var(--text-muted);box-shadow:none}.quiz-score{text-align:center;margin:var(--g-xx) 0;color:var(--success);animation:slideUp var(--trans) var(--ease);font-size:36px;font-weight:800}.quiz-score:before{content:"🎉 ";margin-right:var(--g)}.quiz-feedback{margin-top:var(--g-xx);padding:var(--g-xx);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.question-result{margin-bottom:var(--g-x);padding:var(--g-x);background:var(--bg);border-radius:var(--radius-md);border-left:4px solid var(--border)}.question-result.correct{border-left-color:var(--success);background:var(--success-light)}.question-result.incorrect{border-left-color:var(--danger);background:var(--danger-light)}.question-result h4{margin:0 0 var(--g) 0;font-size:var(--fs-base);color:var(--text-main);font-weight:700}.question-result p{font-size:var(--fs-sm);color:var(--text);margin:0 0 var(--g) 0;line-height:1.5}.question-result ul{margin:var(--g) 0 0 0;padding-left:0;list-style:none}.question-result li{border-radius:var(--radius-sm);font-size:var(--fs-sm);align-items:center;gap:var(--g-sm);margin-bottom:6px;padding:8px 12px;display:flex}.question-result .correct{color:var(--success);border-left:3px solid var(--success);background:#16a34a26;padding-left:12px;font-weight:600}.question-result .correct:before{content:"✓";font-weight:700}.question-result .incorrect{color:var(--danger);border-left:3px solid var(--danger);background:#ef444426;padding-left:12px;text-decoration:line-through}.question-result .incorrect:before{content:"✗";font-weight:700}.quiz-container p{text-align:center;font-size:var(--fs-lg);color:var(--text-muted);padding:var(--g-xx)}@media (width<=768px){.quiz-container{padding:var(--g)}.question-block{padding:var(--g-x)}.question-text{font-size:var(--fs-lg)}.options-list label{padding:var(--g);min-height:56px}.quiz-submit-btn{max-width:100%;font-size:var(--fs-sm)}.quiz-score{font-size:28px}}:root{--primary:#06f;--primary-600:#0052cc;--primary-light:#e6f0ff;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--text-main:#1f2937;--text-muted:#6b7280;--border:#e5e7eb;--surface:#fff;--background:#f9fafb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--trans:.3s;--ease:cubic-bezier(.4, 0, .2, 1);--g:16px;--g-x:24px;--g-sm:12px;--fs-sm:13px;--fs-base:14px;--fs-lg:18px;--fs-xl:24px;--fs-xxl:32px}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes hoverLift{0%{transform:translateY(0)}to{transform:translateY(-4px)}}@keyframes checkmarkAppear{0%{opacity:0;transform:scale(.5)rotate(-45deg)}50%{opacity:1}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes expandIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:200px}}.lesson-page-bg{background-color:var(--background);min-height:100vh;padding-bottom:60px}.lesson-page-layout{gap:var(--g-x);max-width:1440px;padding:0 var(--g-x);margin:0 auto;margin-top:var(--g-x);animation:slideUp var(--trans) var(--ease);grid-template-columns:1fr 360px;align-items:start;display:grid}.lesson-main{gap:var(--g-x);flex-direction:column;min-width:0;display:flex}.video-player-wrapper{aspect-ratio:16/9;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-lg);background:#0f172a;position:relative;overflow:hidden}.video-iframe{border:none;width:100%;height:100%}.no-video-fallback{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.fallback-icon{opacity:.5;margin-bottom:16px;font-size:48px}.lesson-details-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--g-x);box-shadow:var(--shadow-md);border:1px solid var(--border)}.lesson-header-flex{justify-content:space-between;align-items:flex-start;gap:var(--g-x);margin-bottom:var(--g-x);flex-wrap:wrap;display:flex}.lesson-title-large{color:var(--text-main);margin:0 0 12px;font-size:24px;font-weight:800;line-height:1.3}.lesson-meta-info{gap:8px;display:flex}.meta-badge{border-radius:4px;padding:4px 10px;font-size:12px;font-weight:600}.meta-badge.quiz{background:var(--warning-light);color:#d97706}.meta-badge.completed{background:var(--success-light);color:var(--success)}.lesson-primary-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.btn-mark-complete{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #06f3}.btn-mark-complete:hover{background:var(--primary-600);transform:translateY(-2px);box-shadow:0 6px 16px #0066ff4d}.btn-next-lesson{background:var(--surface);color:var(--primary);border:2px solid var(--primary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-next-lesson:hover:not(.disabled){background:var(--primary-light);transform:translateY(-2px)}.btn-next-lesson.disabled{opacity:.5;cursor:not-allowed;border-color:var(--border);color:var(--text-muted)}.btn-quiz{border-radius:var(--radius-md);cursor:pointer;color:#fff;border:none;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-quiz.pending{background:#f59e0b;box-shadow:0 4px 12px #f59e0b33}.btn-quiz.passed{background:#0ea5e9;box-shadow:0 4px 12px #0ea5e933}.btn-quiz:hover{filter:brightness(1.1);transform:translateY(-2px)}.btn-finish-course{background:var(--success);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s}.btn-finish-course:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b9814d}.btn-finish-course:disabled{opacity:.5;cursor:not-allowed}.quiz-warning-banner{color:#b45309;margin-bottom:var(--g-x);background:#fffbeb;border-left:4px solid #f59e0b;border-radius:4px;padding:12px 16px;font-size:14px;font-weight:500}.lesson-tabs{border-bottom:1px solid var(--border);gap:24px;margin-bottom:24px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:12px 0;font-size:15px;font-weight:600;transition:color .2s;position:relative}.tab-btn:hover{color:var(--text-main)}.tab-btn.active{color:var(--primary)}.tab-btn.active:after{content:"";background:var(--primary);border-radius:3px 3px 0 0;width:100%;height:3px;position:absolute;bottom:-1px;left:0}.lesson-tab-content{min-height:150px}.content-overview h3{margin:0 0 12px;font-size:18px;font-weight:700}.content-text{color:var(--text-main);font-size:15px;line-height:1.6}.content-empty{color:var(--text-muted);background:var(--background);border-radius:var(--radius-md);border:1px dashed var(--border);flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.content-empty .empty-icon{margin-bottom:12px;font-size:32px}.lesson-sidebar{gap:var(--g-x);flex-direction:column;display:flex;position:sticky;top:24px}.sidebar-playlist-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border);flex-direction:column;max-height:calc(100vh - 200px);display:flex;overflow:hidden}.playlist-title{border-bottom:1px solid var(--border);background:var(--background);margin:0;padding:20px;font-size:16px;font-weight:700}.playlist-scroll{flex-direction:column;gap:8px;padding:12px;display:flex;overflow-y:auto}.playlist-scroll::-webkit-scrollbar{width:6px}.playlist-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.playlist-item{border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;align-items:flex-start;gap:12px;padding:12px;transition:all .2s;display:flex}.playlist-item:hover:not(.locked):not(.current){background:var(--background);border-color:var(--border)}.playlist-item.current{background:var(--primary-light);border-color:#06f3}.playlist-item.locked{opacity:.6;cursor:not-allowed}.playlist-item.completed .item-icon{background:var(--success-light);color:var(--success)}.item-icon{width:28px;height:28px;color:var(--text-muted);background:#f1f5f9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.playlist-item.current .item-icon{background:var(--primary);color:#fff}.item-content{flex:1}.item-title{color:var(--text-main);margin-bottom:4px;font-size:14px;font-weight:600;line-height:1.4}.playlist-item.current .item-title{color:var(--primary)}.item-duration{color:var(--text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.item-badge{background:var(--warning-light);color:#d97706;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.toast-notification{border-left:4px solid var(--success);z-index:1000;background:#fff;border-radius:8px;align-items:center;gap:16px;padding:16px 20px;animation:.3s slideInRight,.3s 2.7s forwards fadeOut;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 10px 25px #00000026}@keyframes fadeOut{to{opacity:0;visibility:hidden}}.toast-icon{font-size:24px}.toast-content h4{color:var(--text-main);margin:0 0 4px;font-size:16px}.toast-content p{color:var(--text-muted);margin:0;font-size:14px}@media (width<=1024px){.lesson-page-layout{grid-template-columns:1fr}.lesson-sidebar{position:static}}@media (width<=768px){.lesson-header-flex{flex-direction:column}.lesson-primary-actions{width:100%}.btn-mark-complete,.btn-next-lesson,.btn-quiz{flex:1;justify-content:center}}.course-learning-wrapper{background:var(--background);min-height:100vh;padding:var(--g-x) 0}.course-learning-container{gap:var(--g-x);max-width:1400px;padding:0 var(--g-x);animation:slideUp var(--trans) var(--ease);grid-template-columns:1fr 320px;margin:0 auto;display:grid}.course-learning-main{gap:var(--g-x);flex-direction:column;display:flex}.course-learning-header{background:var(--surface);border-radius:var(--radius-lg);padding:var(--g-x);box-shadow:var(--shadow-md);border:1px solid var(--border)}.header-top{justify-content:space-between;align-items:flex-start;gap:var(--g-x);display:flex}.course-title{font-size:var(--fs-xxl);color:var(--text-main);margin:0 0 var(--g) 0;background:linear-gradient(135deg, var(--primary) 0%, var(--primary-600) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800;line-height:1.2}.course-description{color:var(--text-muted);font-size:var(--fs-base);margin:0;line-height:1.6}.header-stats{gap:var(--g);align-items:center;display:flex}.stat-badge{background:var(--primary-light);color:var(--primary);border-radius:var(--radius-md);font-size:var(--fs-sm);border:1px solid var(--primary);padding:8px 16px;font-weight:600}.lessons-list{gap:var(--g);flex-direction:column;display:flex}.lessons-list-header{margin-bottom:var(--g);justify-content:space-between;align-items:center;display:flex}.lessons-list h2{font-size:var(--fs-lg);color:var(--text-main);align-items:center;gap:var(--g);margin:0;font-weight:700;display:flex}.lessons-list h2:before{content:"";background:linear-gradient(180deg, var(--primary) 0%, var(--primary-600) 100%);border-radius:2px;width:4px;height:24px}.lessons-count-info{font-size:var(--fs-sm);color:var(--primary);background:var(--primary-light);border-radius:var(--radius-md);padding:4px 12px;font-weight:600}.lessons-list-content{gap:var(--g);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.empty-state{padding:60px var(--g-x);background:var(--surface);border-radius:var(--radius-lg);border:2px dashed var(--border);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-icon{margin-bottom:var(--g-x);opacity:.5;font-size:64px}.empty-state p{color:var(--text-muted);font-size:var(--fs-base);margin:0}.lesson-item{gap:var(--g) var(--g-x);padding:var(--g-x);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--trans) var(--ease);animation:slideUp var(--trans) var(--ease);border-left:4px solid #0000;grid-template-rows:auto auto auto;grid-template-columns:auto 1fr auto;align-items:start;display:grid;position:relative;overflow:hidden}.lesson-item:before{content:"";pointer-events:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#0066ff05 0%,#0000 100%);position:absolute;inset:0}.lesson-item-icon{background:var(--primary-light);border-radius:var(--radius-md);width:52px;height:52px;color:var(--primary);transition:all var(--trans) var(--ease);z-index:2;border:2px solid #0000;grid-area:1/1/3/2;justify-content:center;align-items:center;font-size:20px;display:flex;position:relative}.icon-inner{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.lesson-header-info{justify-content:space-between;align-items:flex-start;gap:var(--g);margin-bottom:var(--g-sm);display:flex}.lesson-item-content{z-index:2;flex-direction:column;grid-area:1/2/3/3;gap:8px;display:flex;position:relative}.lesson-item-content a{text-decoration:none!important}.lesson-item-title{font-size:var(--fs-base);color:var(--text-main);transition:color var(--trans) var(--ease);margin:0;font-weight:600;line-height:1.4}.lesson-item-duration{font-size:var(--fs-sm);color:var(--text-muted);transition:color var(--trans) var(--ease);margin:0}.lesson-badges{gap:var(--g-sm);flex-wrap:wrap;display:flex}.difficulty-badge{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;background:0 0;border:1.5px solid;padding:4px 10px;font-size:11px;font-weight:600}.quiz-badge{border-radius:var(--radius-sm);background:var(--warning-light);color:#d97706;border:1px solid #fbbf24;padding:4px 10px;font-size:11px;font-weight:600}.lesson-expanded-info{animation:expandIn var(--trans) var(--ease);grid-area:3/2/4/3}.lesson-status{font-size:var(--fs-sm);color:var(--text-muted);margin:var(--g-sm) 0 0 0;padding:var(--g-sm);border-left:3px solid var(--success);background:#10b9810d;border-radius:4px}.lesson-item-meta{color:var(--text-muted);align-items:center;gap:var(--g-sm);grid-area:2/2/3/3;font-size:12px;display:flex}.lesson-actions{align-items:center;gap:var(--g-sm);z-index:2;grid-area:1/3/3/4;display:flex;position:relative}.lesson-item:hover:not(.locked):not(.active){border-color:var(--primary);border-left-color:var(--primary);background:linear-gradient(135deg, var(--surface) 0%, #0066ff08 100%);transform:translateY(-4px);box-shadow:0 12px 24px #0066ff26}.lesson-item:hover:not(.locked):not(.active) .lesson-item-icon{background:linear-gradient(135deg, var(--primary-light) 0%, #0066ff1a 100%);border-color:var(--primary);transform:scale(1.08);box-shadow:0 0 20px #06f3}.lesson-item:hover:not(.locked):not(.active) .lesson-item-title{color:var(--primary)}.lesson-item.expanded{border-left-color:var(--primary);border-color:var(--primary);background:linear-gradient(135deg, var(--primary-light) 0%, #0066ff0d 100%);box-shadow:0 0 0 3px #0066ff1a}.lesson-item.expanded .lesson-item-title{color:var(--primary);font-weight:700}.lesson-item.expanded .lesson-item-icon{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 0 20px #0066ff4d}.lesson-item.completed{border-left-color:var(--success);border-color:var(--border);background:var(--surface)}.lesson-item.completed .lesson-item-icon{background:var(--success-light);color:var(--success);animation:slideIn var(--trans) var(--ease);position:relative}.lesson-item.completed .lesson-item-title{color:var(--success);font-weight:600}.lesson-item.locked{border-color:var(--border);opacity:.6;pointer-events:none;cursor:not-allowed;background:#fff9}.lesson-item.locked .lesson-item-icon{color:var(--text-muted);background:#e2e8f0cc}.lesson-item.locked .lesson-item-title{color:var(--text-muted)}.complete-btn,.quiz-link{background:var(--surface);color:var(--text-main);border:2px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer;transition:all var(--trans) var(--ease);white-space:nowrap;box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:8px 16px;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn-icon{justify-content:center;align-items:center;font-size:16px;display:flex}.complete-btn:before,.quiz-link:before{content:"";width:0;height:0;transition:width var(--trans) var(--ease), height var(--trans) var(--ease);z-index:-1;background:#0066ff26;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.complete-btn:hover:not(:disabled),.quiz-link:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);transform:translateY(-2px);box-shadow:0 4px 12px #06f3}.complete-btn:hover:not(:disabled):before,.quiz-link:hover:before{width:120px;height:120px}.complete-btn:active,.quiz-link:active{transform:translateY(0)}.complete-btn:disabled{opacity:.5;cursor:not-allowed}.lessons-sidebar{gap:var(--g);top:var(--g-x);flex-direction:column;display:flex;position:sticky}.progress-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--g-x);box-shadow:var(--shadow-md);border:1px solid var(--border);animation:slideIn var(--trans) var(--ease)}.progress-card h3{font-size:var(--fs-base);color:var(--text-main);margin:0 0 var(--g-x) 0;font-weight:700}.progress-stat-group{margin-bottom:var(--g-x);padding:var(--g);background:var(--background);border-radius:var(--radius-md);justify-content:space-around;align-items:center;display:flex}.progress-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.stat-value{font-size:var(--fs-xl);color:var(--primary);font-weight:800}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.stat-divider{background:var(--border);width:1px;height:40px}.progress-bar-container{margin-bottom:var(--g-x)}.progress-label{margin-bottom:var(--g-sm);justify-content:space-between;align-items:center;display:flex}.progress-percentage{font-size:var(--fs-lg);color:var(--primary);font-weight:800}.progress-bar-track{background:var(--border);border-radius:6px;width:100%;height:12px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary) 0%, var(--primary-600) 100%);border-radius:6px;height:100%;transition:width .4s;position:relative;box-shadow:0 0 8px #0066ff4d}.progress-bar-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff4d 50%,#0000 100%);animation:2s ease-in-out infinite pulse;position:absolute;inset:0}.achievement-section{padding:var(--g);border-radius:var(--radius-md);background:linear-gradient(135deg,#0066ff0d 0%,#0066ff05 100%);border:1px solid #0066ff1a}.achievement-section h4{font-size:var(--fs-sm);color:var(--text-main);margin:0 0 var(--g-sm) 0;font-weight:700}.achievement-text{font-size:var(--fs-sm);color:var(--primary);margin:0;line-height:1.5}.achievement-text.success{color:var(--success);font-weight:600}@media (width<=1280px){.course-learning-container{grid-template-columns:1fr}.lessons-sidebar{position:static}}@media (width<=768px){.course-learning-wrapper{padding:var(--g) 0}.course-learning-container{gap:var(--g);padding:0 var(--g)}.course-learning-header{padding:var(--g)}.header-top{flex-direction:column}.course-title{font-size:var(--fs-xl)}.lesson-item{padding:var(--g);grid-template-rows:auto auto auto auto;grid-template-columns:auto 1fr}.lesson-item-icon{grid-area:1/1/4/2;width:44px;height:44px}.lesson-item-content{grid-area:1/2/3/3}.lesson-item-meta{grid-area:3/2/4/3}.lesson-actions{justify-content:flex-start;gap:var(--g-sm);grid-area:4/2/5/3}.lesson-expanded-info{grid-area:5/2/6/3}.header-stats{justify-content:flex-start;width:100%}.lessons-list-header{flex-direction:column;align-items:flex-start}.progress-card{margin-top:var(--g)}}@media (width<=480px){.course-learning-wrapper{padding:var(--g-sm) 0}.course-learning-container{gap:var(--g-sm);padding:0 var(--g-sm)}.course-learning-header{padding:var(--g-sm)}.course-title{font-size:24px}.lesson-item{padding:var(--g-sm);gap:var(--g-sm) var(--g)}.complete-btn,.quiz-link{padding:6px 12px;font-size:11px}.progress-stat-group{gap:var(--g-sm);flex-direction:column}.stat-divider{width:30px;height:1px}.lesson-badges{gap:4px}}.video-completion-hint{padding:var(--g);background:var(--primary-light);border-left:4px solid var(--primary);border-radius:var(--radius-md);margin-top:var(--g);animation:slideUp var(--trans) var(--ease)}.video-completion-hint p{font-size:var(--fs-sm);color:var(--primary);margin:0;font-weight:600;line-height:1.5}.video{width:100%;height:85%;position:relative}.auto-complete-status{align-items:center;gap:var(--g);padding:var(--g) var(--g-x);background:linear-gradient(135deg, var(--warning-light) 0%, #f59e0b0d 100%);border-radius:var(--radius-md);border:2px solid var(--warning);animation:slideUp var(--trans) var(--ease);display:flex}.status-icon{justify-content:center;align-items:center;font-size:24px;display:flex}.status-text{font-size:var(--fs-sm);color:#b45309;font-weight:600;line-height:1.5}.recommendation-card{background:#fff;border-left:4px solid #2196f3;border-radius:12px;margin-bottom:20px;padding:24px;transition:all .3s;position:relative;box-shadow:0 2px 8px #0000001a}.recommendation-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.recommendation-card.dismissed{opacity:.6;background:#f5f5f5}.rank-badge{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;position:absolute;top:12px;right:12px}.dismissed-message{text-align:center;color:#4caf50;padding:20px;font-weight:500}.card-content{flex-direction:column;gap:16px;display:flex}.card-header{justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.course-info{flex:1;min-width:0}.course-title{color:#1a1a1a;cursor:pointer;margin:0 0 8px;font-size:18px;font-weight:600;transition:color .2s}.course-title:hover{color:#2196f3;text-decoration:underline}.course-description{color:#666;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.main-score{justify-content:center;align-items:center;display:flex}.score-circle{background:linear-gradient(135deg,#2196f30d 0%,#2196f305 100%);border:3px solid;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:80px;height:80px;transition:transform .3s;display:flex}.score-circle:hover{transform:scale(1.05)}.score-value{color:#1a1a1a;font-size:24px;font-weight:700}.score-label{color:#666;margin-top:2px;font-size:12px}.metadata-row{background:#f9f9f9;border-radius:8px;flex-wrap:wrap;gap:16px;padding:12px;display:flex}.meta-item{align-items:center;gap:8px;font-size:13px;display:flex}.meta-label{color:#666;font-weight:500}.meta-value{color:#1a1a1a;font-weight:600}.meta-value.difficulty{background:#0000000d;border-radius:4px;padding:2px 8px}.reason-section{background:linear-gradient(135deg,#4caf500d 0%,#4caf5005 100%);border-left:3px solid #4caf50;border-radius:8px;padding:12px}.reason-label{color:#4caf50;margin:0 0 6px;font-size:13px;font-weight:600}.reason-text{color:#555;margin:0;font-size:13px;line-height:1.5}.score-breakdown{background:#f5f5f5;border-radius:8px;padding:16px}.breakdown-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.breakdown-title{color:#1a1a1a;margin:0;font-size:14px;font-weight:600}.breakdown-hint{color:#999;margin:0;font-size:12px}.score-bars{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.score-bar-item{flex-direction:column;gap:6px;display:flex}.bar-label{color:#333;align-items:center;gap:4px;font-size:12px;font-weight:500;display:flex}.bar-icon{font-size:14px}.bar-name{white-space:nowrap}.bar-container{background:#0000001a;border-radius:3px;height:6px;overflow:hidden}.bar-fill{border-radius:3px;height:100%;transition:all .3s}.bar-value{color:#666;text-align:right;font-size:11px}.card-actions{gap:10px;margin-top:12px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s}.btn-dismiss{color:#ff9800;background:#fff3cd;border:1px solid #ff9800;flex:0 auto}.btn-dismiss:hover:not(:disabled){color:#fff;background:#ff9800}@media (width<=768px){.recommendation-card{padding:16px}.card-header{flex-direction:column}.score-circle{border-width:2px;width:70px;height:70px}.score-value{font-size:20px}.metadata-row{gap:10px}.meta-item{font-size:12px}.score-bars{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.card-actions{flex-wrap:wrap}.btn{flex:calc(50% - 5px)}.btn-dismiss{flex:100%}}@media (width<=480px){.recommendation-card{margin-bottom:16px;padding:12px}.course-title{font-size:16px}.course-description{font-size:12px}.metadata-row{flex-direction:column;gap:8px}.score-bars{grid-template-columns:1fr}.card-actions{flex-direction:column}.btn{width:100%}}.recommendations-page{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);min-height:100vh}.page-container{max-width:1200px;margin:0 auto;padding:40px 20px}.page-header{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;gap:24px;margin-bottom:32px;padding:32px;display:flex;box-shadow:0 2px 8px #0000001a}.header-content{flex:1}.page-header h1{color:#1a1a1a;margin:0 0 12px;font-size:28px;font-weight:700}.header-subtitle{color:#666;margin:0;font-size:14px;line-height:1.5}.header-actions{flex-shrink:0;gap:12px;display:flex}.segment-section,.analytics-section{margin-bottom:24px}.analytics-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.analytics-card h3{color:#1a1a1a;margin:0 0 20px;font-size:18px;font-weight:600}.analytics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.analytics-item{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);border-radius:8px;justify-content:space-between;align-items:center;padding:16px;display:flex}.analytics-label{color:#666;font-size:13px;font-weight:500}.analytics-value{color:#667eea;font-size:18px;font-weight:700}.top-courses{border-top:1px solid #eee;margin-top:24px;padding-top:24px}.top-courses h4{color:#1a1a1a;margin:0 0 12px;font-size:14px;font-weight:600}.top-courses-list{flex-direction:column;gap:8px;display:flex}.top-course-item{background:#f9f9f9;border-radius:6px;align-items:center;gap:12px;padding:8px;font-size:13px;display:flex}.rank{color:#667eea;min-width:30px;font-weight:600}.title{color:#1a1a1a;flex:1;font-weight:500}.stats{color:#999;font-size:12px}.controls-section{background:#fff;border-radius:12px;flex-wrap:wrap;align-items:center;gap:24px;margin-bottom:24px;padding:16px 20px;display:flex;box-shadow:0 2px 8px #0000001a}.sort-control,.filter-control{align-items:center;gap:8px;display:flex}.sort-control label,.filter-control label{color:#666;white-space:nowrap;font-size:13px;font-weight:500}.sort-select,.difficulty-select{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:6px;padding:8px 12px;font-size:13px;transition:border-color .2s}.sort-select:focus,.difficulty-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 2px #667eea1a}.result-info{color:#999;white-space:nowrap;margin-left:auto;font-size:12px}.recommendations-grid{grid-template-columns:1fr;gap:20px;margin-bottom:24px;display:grid}.empty-icon{margin:0 0 12px;font-size:48px;display:block}.empty-state h3{color:#1a1a1a;margin:0 0 8px;font-size:18px;font-weight:600}.empty-state p{color:#666;margin:0 0 24px;font-size:14px;line-height:1.5}.footer-info{text-align:center;color:#999;margin-top:20px;font-size:12px}@media (width<=1024px){.page-container{padding:24px 16px}.page-header{flex-direction:column;align-items:flex-start;padding:20px}.header-actions{width:100%}.header-actions .btn{flex:1}.analytics-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.page-container{padding:16px}.page-header{margin-bottom:20px;padding:16px}.page-header h1{font-size:22px}.header-subtitle{font-size:13px}.header-actions{flex-direction:column;width:100%}.header-actions .btn{width:100%}.controls-section{flex-direction:column;align-items:flex-start;gap:12px}.sort-control,.filter-control,.sort-select,.difficulty-select{width:100%}.result-info{width:100%;margin-left:0}.analytics-grid{grid-template-columns:1fr}.analytics-item{text-align:center;flex-direction:column}}@media (width<=480px){.page-container{padding:12px}.page-header{margin-bottom:16px;padding:12px}.page-header h1{font-size:18px}.header-subtitle{font-size:12px}.header-actions{width:100%}.controls-section{padding:12px}.analytics-card{padding:16px}.analytics-card h3{font-size:16px}.empty-state{padding:40px 16px}.empty-icon{font-size:36px}.empty-state h3{font-size:16px}}.learning-pathway-page{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);min-height:100vh;padding:20px 0}.pathway-header{animation:.4s ease-out slideDown}.pathway-courses{animation:.4s ease-out slideUp}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.learning-pathway-page{padding:10px 0}.pathway-header{padding:20px!important}.pathway-header h1{font-size:1.25rem!important}.pathway-courses{padding:0!important}.pathway-courses h2{padding:0 20px;font-size:1rem!important}.pathway-courses>div>div{grid-template-columns:1fr!important;gap:12px!important;margin:0 10px!important}.pathway-courses button{width:100%!important}}@media (width<=480px){.pathway-header{padding:16px!important}.pathway-header h1{font-size:1rem!important}.pathway-header button{padding:8px 12px!important;font-size:.75rem!important}}.pathway-courses>div>div{transition:all .3s cubic-bezier(.4,0,.2,1)}.pathway-courses>div>div:hover{transform:translateY(-2px)}.pathway-courses>div>div[style*="opacity: 0.7"]:hover{transform:none}.pathway-courses>div>div>div:first-child{flex-shrink:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;box-shadow:0 2px 8px #0000001a}.pathway-courses h3{transition:color .3s}.pathway-courses>div>div:hover h3{color:#3b82f6}.pathway-courses>div>div>div>div:last-child>div{animation:.6s ease-out fillProgress}@keyframes fillProgress{0%{width:0!important}}.pathway-courses button{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:all .3s}.pathway-courses button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.pathway-courses button:active:not(:disabled){transform:translateY(0)}.pathway-courses button:disabled{cursor:not-allowed;-webkit-user-select:none;user-select:none}.admin-rules-container{max-width:1200px;margin:0 auto;padding:24px}.rules-header{justify-content:space-between;align-items:center;gap:20px;margin-bottom:32px;display:flex}.rules-header h1{color:#1a1a1a;margin:0 0 8px;font-size:28px;font-weight:700}.rules-header .subtitle{color:#666;margin:0;font-size:14px}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:10px 20px;font-size:13px;font-weight:500;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.btn-secondary{color:#2196f3;background:#e3f2fd;border:1px solid #2196f3}.btn-secondary:hover:not(:disabled){color:#fff;background:#2196f3}.error-message{color:#d32f2f;background:#ffebee;border-left:4px solid #f44336;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:12px 16px;font-size:14px;display:flex}.error-message button{color:#d32f2f;cursor:pointer;background:0 0;border:none;padding:0;font-size:18px}.rule-form-card{background:#fff;border:2px solid #e3f2fd;border-radius:12px;margin-bottom:24px;padding:24px;box-shadow:0 2px 8px #0000001a}.form-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.form-header h3{color:#1a1a1a;margin:0;font-size:16px;font-weight:600}.close-btn{cursor:pointer;color:#999;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:20px;transition:all .2s;display:flex}.close-btn:hover{color:#333;background:#f5f5f5}.form-group{margin-bottom:16px}.form-group label{color:#333;margin-bottom:8px;font-size:13px;font-weight:500;display:block}.form-group input[type=text],.form-group select{border:1px solid #ddd;border-radius:6px;width:100%;padding:10px 12px;font-family:inherit;font-size:13px;transition:border-color .2s}.form-group input[type=text]:focus,.form-group select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 2px #667eea1a}.form-group input[type=text]:disabled{color:#999;background:#f5f5f5}.segments-checkbox{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.checkbox-label{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:8px;font-size:13px;transition:background .2s;display:flex}.checkbox-label:hover{background:#f5f5f5}.checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#667eea}.form-actions{border-top:1px solid #eee;gap:12px;margin-top:20px;padding-top:16px;display:flex}.form-actions .btn{flex:1}.rules-list{flex-direction:column;gap:16px;display:flex}.loading{text-align:center;color:#999;padding:40px}.empty-state{text-align:center;background:#fff;border-radius:12px;padding:60px 20px;box-shadow:0 2px 8px #0000001a}.empty-state p{color:#999;margin:0 0 20px}.rule-card{background:#fff;border-left:4px solid #2196f3;border-radius:12px;padding:20px;transition:all .2s;box-shadow:0 2px 8px #0000001a}.rule-card:hover{box-shadow:0 4px 12px #00000026}.rule-card.inactive{opacity:.7;background:#fafafa;border-left-color:#999}.rule-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.rule-header h3{color:#1a1a1a;margin:0 0 4px;font-size:16px;font-weight:600}.rule-type{color:#999;margin:0;font-size:12px}.rule-status{gap:8px;display:flex}.badge{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.badge.active{color:#2e7d32;background:#c8e6c9}.badge.inactive{color:#c62828;background:#fcc}.rule-body{background:#f9f9f9;border-radius:8px;margin-bottom:16px;padding:12px}.segments-list{margin-bottom:12px}.segments-list strong{color:#666;margin-bottom:8px;font-size:12px;display:block}.segment-tags{flex-wrap:wrap;gap:8px;display:flex}.segment-tag{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.rule-logic{margin-bottom:12px}.rule-logic strong{color:#666;margin-bottom:8px;font-size:12px;display:block}.rule-logic pre{color:#333;background:#fff;border:1px solid #eee;border-radius:4px;margin:0;padding:8px;font-size:11px;overflow-x:auto}.timestamps{color:#999;gap:16px;font-size:11px;display:flex}.rule-actions{gap:10px;display:flex}.rule-actions .btn{flex:1}@media (width<=768px){.admin-rules-container{padding:16px}.rules-header{flex-direction:column;align-items:flex-start}.rules-header h1{font-size:22px}.rule-form-card{padding:16px}.rule-header{flex-direction:column;align-items:flex-start}.rule-status{margin-top:8px}.segments-checkbox{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}@media (width<=480px){.admin-rules-container{padding:12px}.rules-header{margin-bottom:20px}.rules-header h1{font-size:18px}.rule-form-card{padding:12px}.segments-checkbox{grid-template-columns:1fr}.segment-tags{flex-direction:column}.segment-tag{text-align:center;display:block}.timestamps{flex-direction:column;gap:4px}}@media (prefers-reduced-motion:reduce){*{transition:none!important}}@media (width<=900px){:root{--grid-cols:2}}:root{--bg-1:linear-gradient(180deg, #f6fbff 0%, #f3f7fb 100%);--bg:#f6f9fc;--surface:#fff;--text:#0f1724;--muted:#6b7280;--primary:#06f;--primary-600:#0053e6;--accent:#8b5cf6;--success:#16a34a;--danger:#ef4444;--radius:14px;--radius-sm:10px;--pill-radius:9999px;--card-radius:14px;--shadow-1:0 6px 30px #0f172a14;--shadow-2:0 2px 8px #0f172a0f;--container-max:1200px;--g-xx:28px;--g-x:20px;--g:16px;--g-sm:10px;--fs-xxl:32px;--fs-xl:22px;--fs-lg:18px;--fs-base:16px;--fs-sm:14px;--ease:cubic-bezier(.2, .9, .2, 1);--trans-fast:.14s;--trans:.26s;--bg-body:#f8fafc;--text-main:#0f172a;--text-muted:#64748b;--border:#e2e8f0;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--primary-dark:#1e40af;--success-light:#d1fae5;--danger-light:#fee2e2;--warning:#f59e0b;--warning-light:#fef3c7;--shadow-sm:0 1px 2px 0 #0f172a0d;--shadow-md:0 4px 6px -1px #0f172a0d, 0 2px 4px -2px #0f172a08;--shadow-lg:0 10px 15px -3px #0f172a0d, 0 4px 6px -4px #0f172a08;--radius-md:8px;--radius-lg:12px;--font-family:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}html,body{height:100%}body{min-height:100%;font-family:var(--font-family);font-size:var(--fs-base);color:var(--text);background:var(--bg-1);-webkit-font-smoothing:antialiased;margin:0;line-height:1.45}.container{width:100%;max-width:var(--container-max);padding:0 var(--g-x);box-sizing:border-box;margin:0 auto;text-decoration:none}.center{justify-content:center;align-items:center;display:flex}.btn{border-radius:var(--pill-radius);cursor:pointer;transition:transform var(--trans-fast) var(--ease), box-shadow var(--trans-fast) var(--ease), opacity var(--trans-fast) var(--ease);border:none;justify-content:center;align-items:center;gap:10px;padding:10px 16px;font-weight:600;display:inline-flex}.btn-primary:hover{box-shadow:var(--shadow-1);transform:translateY(-3px)}.btn-ghost{color:var(--text);background:0 0;border:1px solid #0f172a0f;padding:8px 12px}.btn-small{border-radius:10px;padding:6px 10px}.card{background:var(--surface);border-radius:var(--card-radius);box-shadow:var(--shadow-2);padding:18px}.muted{color:var(--muted)}.avatar{object-fit:cover;cursor:pointer;border-radius:50%;width:44px;height:44px}.grid-auto-fit{gap:var(--g-x);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.mb-10{margin-bottom:10px}.ml-10{margin-left:10px}.mt-20{margin-top:20px}.text-error{color:var(--danger);margin-bottom:10px}@media (prefers-reduced-motion:reduce){*{transition:none!important}}@media (width<=900px){:root{--grid-cols:2}}a,a:hover,a:focus,a:active{text-decoration:none!important}button:focus,button:active,a:focus,a:active,input:focus,textarea:focus,select:focus,.btn:focus,.btn:active{box-shadow:none!important;outline:none!important}button{-webkit-tap-highlight-color:transparent}.component-header{border-bottom:1px solid var(--border,#e2e8f0);grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:32px;padding:24px 0;display:grid}.header-left{justify-content:flex-start;display:flex}.header-center{text-align:center}.header-title{color:var(--text-main);letter-spacing:-.5px;margin:0;font-size:24px;font-weight:800}.header-subtitle{margin:4px 0 0;font-size:14px}.header-right{justify-content:flex-end;gap:var(--g);display:flex}@media (width<=768px){.component-header{grid-template-columns:1fr;gap:16px}.header-left,.header-right{justify-content:center}}.btn-back{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--trans);background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn-back:hover{color:var(--text-main);background:var(--border);transform:translate(-2px)}.component-card{background:var(--surface);border-radius:var(--card-radius);box-shadow:var(--shadow-1);border:1px solid var(--border,#e2e8f0);transition:all var(--trans) var(--ease);cursor:default;padding:24px}.card-default{background:var(--surface)}.card-elevated:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-outlined{border:2px solid var(--border,#e2e8f0);background:0 0}.component-card:hover.component-card{border-color:var(--primary)}.card-header{font-size:var(--fs-lg);color:var(--text);border-bottom:1px solid var(--border,#e2e8f0);margin-bottom:16px;padding-bottom:12px;font-weight:700}.card-body{padding:16px 0}.card-footer{border-top:1px solid var(--border,#e2e8f0);justify-content:flex-end;gap:var(--g);padding-top:16px;display:flex}.component-button{border-radius:var(--pill-radius);cursor:pointer;transition:all var(--trans) var(--ease);border:none;justify-content:center;align-items:center;gap:8px;font-family:inherit;font-weight:700;display:inline-flex}.component-button:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;box-shadow:0 8px 20px #0066ff4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px #06f6}.btn-secondary{background:var(--surface);color:var(--primary);border:2px solid var(--primary)}.btn-secondary:hover:not(:disabled){background:var(--primary);color:#fff;transform:translateY(-2px)}.btn-danger{background:var(--danger,#ef4444);color:#fff;box-shadow:0 4px 14px #ef444433}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-2px)}.btn-ghost{color:var(--text);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--bg);border-color:var(--border)}.btn-text{color:var(--primary);background:0 0;padding:4px 8px}.btn-text:hover:not(:disabled){color:var(--accent)}.btn-small{font-size:var(--fs-sm);padding:6px 12px}.btn-medium{font-size:var(--fs-base);padding:10px 20px}.btn-large{font-size:var(--fs-lg);padding:14px 32px}.button-spinner{animation:.6s linear infinite spin;display:inline-block}@media (width<=768px){.btn-large{width:100%}}.component-loading{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 32px;display:flex}.loading-spinner{border:4px solid #0066ff1a;border-top:4px solid var(--primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.component-loading p{color:var(--muted);font-size:var(--fs-base);margin:0}.component-error{background:var(--danger-light,#ef44441a);border:1px solid var(--danger,#ef44444d);border-radius:var(--card-radius);animation:slideInUp .4s var(--ease);align-items:flex-start;gap:16px;margin:16px 0;padding:16px 20px;display:flex}.error-icon{flex-shrink:0;font-size:24px}.error-content{flex:1}.component-error p{color:var(--danger,#dc2626);font-size:var(--fs-base);margin:0}.error-dismiss{color:var(--danger,#dc2626);cursor:pointer;transition:transform var(--trans) var(--ease);background:0 0;border:none;flex-shrink:0;padding:0;font-size:20px}.error-dismiss:hover{transform:scale(1.1)}.component-modal-overlay{z-index:1000;animation:fadeIn .3s var(--ease);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.component-modal{background:var(--surface);border-radius:var(--card-radius);max-height:90vh;animation:slideInUp .4s var(--ease);overflow-y:auto;box-shadow:0 25px 60px #0000004d}.modal-small{width:90%;max-width:400px}.modal-medium{width:90%;max-width:600px}.modal-large{width:90%;max-width:900px}.modal-header{border-bottom:1px solid var(--border,#e2e8f0);justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.modal-header h2{font-size:var(--fs-xl);color:var(--text);margin:0;font-weight:700}.modal-close{color:var(--muted);cursor:pointer;transition:color var(--trans) var(--ease);background:0 0;border:none;padding:0;font-size:24px}.modal-close:hover{color:var(--text)}.modal-body{padding:32px}@media (width<=768px){.modal-header{padding:16px 20px}.modal-body{padding:20px}}.user-segment-card{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;margin-bottom:24px;padding:24px;box-shadow:0 4px 12px #667eea4d}.user-segment-card.loading{color:#999;background:#f5f5f5}.user-segment-card.empty{color:#856404;text-align:center;background:#fff3cd}.skeleton-line{background:linear-gradient(90deg,#fff3 25%,#ffffff1a 50%,#fff3 75%) 0 0/200% 100%;border-radius:6px;height:12px;animation:1.5s infinite loading}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.segment-header{border-bottom:1px solid #fff3;align-items:flex-start;gap:16px;margin-bottom:20px;padding-bottom:20px;display:flex}.segment-icon{flex-shrink:0;font-size:48px;line-height:1}.segment-info{flex:1}.segment-title{margin:0 0 8px;font-size:24px;font-weight:700}.segment-description{opacity:.95;margin:0;font-size:14px;line-height:1.4}.segment-weights{margin-bottom:20px}.weights-title{opacity:.9;margin:0 0 12px;font-size:14px;font-weight:600}.weights-container{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;display:grid}.weight-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;padding:12px}.weight-label{white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:12px;font-weight:600;overflow:hidden}.weight-bar-container{background:#fff3;border-radius:2px;height:4px;margin-bottom:6px;overflow:hidden}.weight-bar-fill{border-radius:2px;height:100%;transition:width .3s}.weight-value{opacity:.9;font-size:11px;font-weight:500}.segment-info-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-left:3px solid #ffffff80;border-radius:8px;padding:12px}.info-text{opacity:.95;margin:0;font-size:12px;line-height:1.5}@media (width<=768px){.user-segment-card{margin-bottom:16px;padding:16px}.segment-header{gap:12px;margin-bottom:16px;padding-bottom:16px}.segment-icon{font-size:40px}.segment-title{font-size:20px}.segment-description{font-size:13px}.weights-container{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}.weight-item{padding:10px}.weight-label{font-size:11px}}@media (width<=480px){.user-segment-card{padding:12px}.segment-header{gap:10px}.segment-icon{font-size:32px}.segment-title{font-size:18px}.segment-description{font-size:12px}.weights-container{grid-template-columns:repeat(2,1fr)}.info-text{font-size:11px}}.course-detail{background:linear-gradient(135deg,#f8fafc 0%,#f0f9ff 100%);min-height:100vh;padding:60px 20px;font-family:Inter,sans-serif;animation:.5s ease-out fadeInPage}@keyframes fadeInPage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.course-detail-back{cursor:pointer;color:#475569;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:8px;margin-bottom:24px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.course-detail-back:hover{color:#1e293b;background:#fff;border-color:#cbd5e1;transform:translate(-6px);box-shadow:0 4px 12px #00000014}.course-detail-container{background:#fff;border:1px solid #e2e8f0;border-radius:20px;grid-template-columns:1fr 1fr;max-width:1200px;margin:0 auto;animation:.6s ease-out .1s both slideUp;display:grid;overflow:hidden;box-shadow:0 25px 50px -12px #0000000f}.course-detail-image{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;height:100%;min-height:600px;display:flex;position:relative;overflow:hidden}.course-detail-image:before{content:"";background:url("data:image/svg+xml,<svg width=\"60\" height=\"60\" viewBox=\"0 0 60 60\" xmlns=\"http://www.w3.org/2000/svg\"><g fill=\"none\" fill-rule=\"evenodd\"><g fill=\"%23ffffff\" fill-opacity=\"0.05\"><path d=\"M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z\"/></g></g></svg>");animation:10s linear infinite drift;position:absolute;inset:0}@keyframes drift{0%{transform:translate(0)}to{transform:translate(60px,60px)}}.course-detail-image img{object-fit:cover;z-index:1;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.course-detail-image:hover img{transform:scale(1.05)}.course-detail-content{background:linear-gradient(#fff 0%,#f8fafc 100%);flex-direction:column;padding:48px;display:flex}.course-detail-title{color:#1e293b;letter-spacing:-.5px;margin:0 0 24px;font-size:36px;font-weight:800;line-height:1.2}.course-detail-meta{border-bottom:1px solid #e2e8f0;flex-direction:column;gap:20px;margin-bottom:28px;padding-bottom:28px;display:flex}.meta-instructor{background:#f8fafc;border-radius:12px;align-items:center;gap:16px;padding:16px;transition:all .3s;display:flex}.meta-instructor:hover{background:#f1f5f9;transform:translate(4px)}.instructor-avatar{object-fit:cover;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:3px solid #fff;border-radius:50%;flex-shrink:0;width:64px;height:64px;box-shadow:0 8px 16px #667eea33}.instructor-info{flex-direction:column;gap:4px;display:flex}.instructor-label{color:#64748b;text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.instructor-name{color:#1e293b;font-size:17px;font-weight:700}.meta-price-section{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #fcd34d;border-radius:12px;align-items:center;gap:16px;padding:16px;display:flex}.price-label{color:#92400e;text-transform:uppercase;letter-spacing:.5px;font-size:14px;font-weight:700}.meta-price{color:#b45309;font-family:Courier New,monospace;font-size:32px;font-weight:900}.course-detail-description{color:#475569;flex:1;margin-bottom:32px;font-size:15px;line-height:1.8}.course-detail-description h3{color:#94a3b8;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:16px;font-size:13px;font-weight:800}.course-detail-description p{margin-bottom:12px;padding-left:28px;transition:all .3s;position:relative}.course-detail-description p:before{content:"✓";color:#10b981;font-size:16px;font-weight:900;position:absolute;left:0}.course-detail-description p:hover{color:#1e293b;padding-left:32px}.enrollment-error{background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border:1px solid #fca5a5;border-radius:12px;margin-bottom:24px;padding:16px;animation:.3s ease-out slideDown}.enrollment-error p{color:#991b1b;margin:0;padding:0;font-weight:500}.enrollment-error .btn-primary{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;margin-top:12px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .3s}.enrollment-error .btn-primary:hover{background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.course-actions{gap:12px;margin-top:auto;animation:.6s ease-out .3s both fadeIn;display:flex}.course-detail-btn{cursor:pointer;text-align:center;text-transform:uppercase;letter-spacing:.5px;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 32px;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.course-detail-btn:before{content:"";background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);transition:transform .6s;position:absolute;inset:0;transform:translate(-100%)}.course-detail-btn:hover:not(:disabled):before{transform:translate(100%)}.primary-btn{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);box-shadow:0 8px 20px #2563eb4d}.primary-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 28px #2563eb66}.primary-btn:active:not(:disabled){transform:translateY(-1px)}.primary-btn:disabled{cursor:not-allowed;box-shadow:none;opacity:.6;background:#cbd5e1}.secondary-btn{color:#dc2626;background-color:#fee2e2;border:2px solid #fca5a5;font-weight:700}.secondary-btn:hover:not(:disabled){background-color:#fecaca;border-color:#ef4444;transform:translateY(-3px);box-shadow:0 8px 16px #ef444433}.secondary-btn:active:not(:disabled){transform:translateY(-1px)}.secondary-btn:disabled{color:#9ca3af;cursor:not-allowed;background-color:#f9fafb;border-color:#e5e7eb}.btn-icon{justify-content:center;align-items:center;font-size:16px;transition:transform .3s;display:flex}.course-detail-btn:hover:not(:disabled) .btn-icon{transform:scale(1.2)}.course-stats{background:#f8fafc;border-radius:12px;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0;padding:20px;display:grid}.stat-item{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;transition:all .3s}.stat-item:hover{border-color:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb1a}.stat-value{color:#2563eb;font-size:20px;font-weight:800;display:block}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:11px;font-weight:700}.course-detail-error{text-align:center;background:#fff;border-radius:16px;padding:60px 20px;box-shadow:0 4px 12px #00000014}.course-detail-error h2{color:#1e293b;margin-bottom:12px;font-size:28px}.course-detail-error p{color:#475569;margin-bottom:24px;font-size:16px}.course-detail-error button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:12px 32px;font-weight:600;transition:all .3s}.course-detail-error button:hover{background:#1d4ed8;transform:translateY(-2px)}.review-form-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;box-shadow:0 4px 6px #00000005}.star-rating{cursor:pointer;gap:8px;margin-bottom:12px;font-size:32px;display:flex}.star-rating .star{color:#e2e8f0;transition:color .2s,transform .1s}.star-rating .star:hover{transform:scale(1.1)}.star-rating .star.active{color:#f59e0b}@media (width<=1024px){.course-detail-container{grid-template-columns:1fr}.course-detail-image{min-height:400px}.course-detail-content{padding:40px}}@media (width<=768px){.course-detail{padding:40px 16px}.course-detail-content{padding:32px}.course-detail-title{font-size:28px}.course-actions{flex-direction:column}.course-detail-btn{padding:12px 24px;font-size:14px}.meta-price{font-size:26px}.course-stats{grid-template-columns:repeat(2,1fr);gap:8px;padding:16px}}@media (width<=480px){.course-detail{padding:24px 12px}.course-detail-container{border-radius:16px}.course-detail-image{min-height:250px}.course-detail-content{padding:20px}.course-detail-title{margin-bottom:16px;font-size:22px}.course-detail-meta{gap:12px;margin-bottom:16px;padding-bottom:16px}.meta-instructor{padding:12px}.instructor-avatar{width:48px;height:48px}.meta-price-section{padding:12px}.meta-price{font-size:22px}.course-detail-description{margin-bottom:20px;font-size:14px}.course-detail-description p{margin-bottom:10px;padding-left:24px}.course-actions{gap:8px}.course-detail-btn{gap:6px;padding:10px 16px;font-size:13px}.btn-icon{font-size:14px}.course-stats{grid-template-columns:1fr;gap:6px;margin:16px 0;padding:12px}.stat-item{padding:10px}.stat-value{font-size:18px}.stat-label{font-size:10px}}
