*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--navy: #0F1A2B;--navy-light: #1A2A42;--navy-lighter: #243550;--teal: #79C2B8;--teal-dark: #5BA99F;--teal-light: #E8F5F2;--lavender: #8F9FBE;--lavender-light: #E8ECF3;--mint: #B1DDCC;--mint-light: #E5F4ED;--mbb-start-bg: #29a79e;--off-white: #F8FAFB;--white: #FFFFFF;--gray-100: #F1F5F9;--gray-200: #E2E8F0;--gray-400: #94A3B8;--gray-500: #64748B;--gray-600: #475569;--font-display: "Plus Jakarta Sans", -apple-system, sans-serif;--font-body: "DM Sans", -apple-system, sans-serif;--radius: 12px;--radius-lg: 16px;--shadow: 0 4px 24px rgba(15,26,43,.1);--shadow-hover: 0 8px 32px rgba(15,26,43,.18);--transition: .25s ease}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--navy);background:var(--off-white);line-height:1.6;-webkit-font-smoothing:antialiased}.header{position:sticky;top:0;z-index:100;background:var(--navy);padding:0 32px;height:56px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.06)}.header-logo{height:32px;cursor:pointer;opacity:.9}.header-logo:hover{opacity:1}.header-right{display:flex;align-items:center;gap:16px}.header-progress{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--teal);letter-spacing:.05em}.header-admin-btn{font-family:var(--font-display);font-size:11px;font-weight:600;color:var(--white);background:#79c2b833;border:1px solid rgba(121,194,184,.3);padding:6px 14px;border-radius:8px;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition)}.header-admin-btn:hover{background:#79c2b859}.header-logout-btn{font-family:var(--font-display);font-size:11px;font-weight:600;color:#ffffff80;background:none;border:none;cursor:pointer;padding:6px 8px}.header-logout-btn:hover{color:#fffc}.hero{background:linear-gradient(160deg,#060e1f 0%,var(--navy) 40%,var(--navy-light) 100%);padding:80px 32px 64px;text-align:center;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 50% 100%,rgba(121,194,184,.06) 0%,transparent 70%)}.hero-content{position:relative;z-index:2;max-width:640px;margin:0 auto}.hero-logo{height:64px;margin-bottom:24px;opacity:.95}.hero-title{font-family:var(--font-display);font-size:40px;font-weight:800;color:var(--white);letter-spacing:-.03em;line-height:1.1;margin-bottom:8px}.hero-subtitle{font-size:16px;color:#ffffff80;margin-bottom:32px}.hero-progress-bar{width:200px;height:4px;background:#ffffff1a;border-radius:4px;margin:0 auto;overflow:hidden}.hero-progress-fill{height:100%;background:var(--teal);border-radius:4px;transition:width .5s ease}.hero-progress-label{font-family:var(--font-display);font-size:11px;font-weight:600;color:#ffffff59;margin-top:8px;letter-spacing:.08em}.module-grid-section{max-width:1200px;margin:0 auto;padding:48px 24px 80px}.module-grid-title{font-family:var(--font-display);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--gray-500);margin-bottom:24px}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.module-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:28px 24px;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition);display:flex;flex-direction:column}.module-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:var(--teal)}.module-card.mbb-start{background:var(--mbb-start-bg);border-color:transparent}.module-card.mbb-start .card-title,.module-card.mbb-start .card-desc,.module-card.mbb-start .card-meta{color:var(--white)}.module-card.mbb-start .card-desc{opacity:.8}.module-card.mbb-start .card-meta{opacity:.7}.module-card.mbb-start:hover{border-color:#ffffff4d}.card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.card-icon{width:44px;height:44px;border-radius:12px;background:var(--teal-light);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.mbb-start .card-icon{background:#ffffff26}.card-badge{font-family:var(--font-display);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal)}.mbb-start .card-badge{color:#fffc}.card-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--navy);line-height:1.3}.card-desc{font-size:13px;color:var(--gray-500);margin-top:8px;flex:1;line-height:1.5}.card-footer{margin-top:16px;display:flex;align-items:center;justify-content:space-between}.card-meta{font-family:var(--font-display);font-size:11px;font-weight:600;color:var(--gray-400)}.card-progress{width:60px;height:4px;background:var(--gray-200);border-radius:4px;overflow:hidden}.mbb-start .card-progress{background:#fff3}.card-progress-fill{height:100%;background:var(--teal);border-radius:4px;transition:width .3s ease}.mbb-start .card-progress-fill{background:var(--white)}.module-page{min-height:100vh;background:var(--off-white)}.module-topbar{background:var(--white);border-bottom:1px solid var(--gray-200);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:56px;z-index:50}.topbar-back{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--teal);background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:6px}.topbar-back:hover{color:var(--teal-dark)}.topbar-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--navy);text-align:center;flex:1}.topbar-pdf{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--white);background:var(--teal);border:none;padding:8px 16px;border-radius:8px;cursor:pointer;text-decoration:none;white-space:nowrap}.topbar-pdf:hover{background:var(--teal-dark)}.module-layout{max-width:1200px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 320px;gap:24px}@media(max-width:900px){.module-layout{grid-template-columns:1fr}}.video-wrapper{background:var(--navy);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}.video-frame{width:100%;aspect-ratio:16/9;border:none;display:block}.video-no-id{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;background:var(--navy-light);color:var(--gray-400);font-family:var(--font-display);font-size:14px}.video-info{padding:16px 20px;display:flex;align-items:center;justify-content:space-between}.video-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--white)}.btn-watched{font-family:var(--font-display);font-size:12px;font-weight:600;padding:8px 16px;border-radius:8px;cursor:pointer;border:none;transition:all var(--transition)}.btn-watched.done{background:var(--teal);color:var(--white)}.btn-watched.pending{background:transparent;color:var(--teal);border:1px solid rgba(121,194,184,.4)}.btn-watched.pending:hover{background:#79c2b81a}.video-list{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow:hidden}.video-list-header{padding:16px 20px;border-bottom:1px solid var(--gray-200);font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--navy)}.video-list-items{max-height:500px;overflow-y:auto}.video-item{padding:12px 20px;display:flex;align-items:center;gap:12px;cursor:pointer;border-bottom:1px solid var(--gray-100);transition:background var(--transition)}.video-item:hover{background:var(--gray-100)}.video-item.active{background:var(--teal-light);border-left:3px solid var(--teal)}.video-item-num{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--gray-400);min-width:24px}.video-item.active .video-item-num{color:var(--teal)}.video-item-title{font-size:13px;color:var(--navy);flex:1;line-height:1.4}.video-item-check{font-size:14px;color:var(--teal)}.footer{background:var(--navy);padding:32px;text-align:center}.footer-logo{height:36px;opacity:.6;margin-bottom:12px}.footer-text{font-family:var(--font-display);font-size:13px;font-weight:500;color:#ffffff80}.footer-copy{font-size:11px;color:#ffffff40;margin-top:4px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#060e1f 0%,var(--navy) 40%,var(--navy-light) 100%);padding:24px}.auth-card{background:var(--white);border-radius:var(--radius-lg);padding:48px 40px;max-width:420px;width:100%;box-shadow:0 8px 40px #0000004d;text-align:center}.auth-logo{height:48px;margin-bottom:24px}.auth-title{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--navy);margin-bottom:6px}.auth-subtitle{font-size:14px;color:var(--gray-500);margin-bottom:24px;line-height:1.5}.auth-error{background:#fef2f2;color:#dc2626;border:1px solid #FECACA;padding:10px 16px;border-radius:8px;font-size:13px;margin-bottom:16px;text-align:left}.auth-form{display:flex;flex-direction:column;gap:16px;text-align:left}.auth-label{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--navy);display:flex;flex-direction:column;gap:6px}.auth-input{font-family:var(--font-body);font-size:14px;padding:12px 16px;border:1px solid var(--gray-200);border-radius:8px;outline:none;transition:border-color var(--transition)}.auth-input:focus{border-color:var(--teal)}.auth-btn{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--white);background:var(--teal);border:none;padding:14px;border-radius:8px;cursor:pointer;transition:background var(--transition)}.auth-btn:hover{background:var(--teal-dark)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-links{margin-top:20px;display:flex;flex-direction:column;gap:8px}.auth-link{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--teal);background:none;border:none;cursor:pointer}.auth-link:hover{color:var(--teal-dark)}.admin-page{min-height:100vh;background:#f5f3ee}.admin-topbar{background:var(--navy);padding:14px 24px;display:flex;align-items:center;gap:16px}.admin-back{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--teal);background:none;border:none;cursor:pointer}.admin-back:hover{color:var(--teal-dark)}.admin-topbar-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--white);flex:1}.admin-tabs{background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;padding:0 24px;gap:0}.admin-tab{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--gray-500);background:none;border:none;padding:14px 20px;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition)}.admin-tab:hover{color:var(--navy)}.admin-tab.active{color:var(--teal);border-bottom-color:var(--teal)}.admin-content{max-width:1200px;margin:0 auto;padding:24px}.admin-loading{text-align:center;padding:48px;color:var(--gray-500)}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.admin-stat-card{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:0 1px 4px #0000000f;text-align:center}.admin-stat-value{font-family:var(--font-display);font-size:36px;font-weight:800;color:var(--teal)}.admin-stat-label{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.admin-section{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:0 1px 4px #0000000f;margin-bottom:20px}.admin-section-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--navy);margin-bottom:16px}.admin-form-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.admin-form-col{display:flex;flex-direction:column;gap:12px}.admin-input{font-family:var(--font-body);font-size:13px;padding:10px 14px;border:1px solid var(--gray-200);border-radius:8px;outline:none;flex:1;min-width:0}.admin-input:focus{border-color:var(--teal)}.admin-textarea{font-family:var(--font-body);font-size:13px;padding:10px 14px;border:1px solid var(--gray-200);border-radius:8px;outline:none;resize:vertical}.admin-textarea:focus{border-color:var(--teal)}.admin-btn{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--white);background:var(--teal);border:none;padding:10px 20px;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background var(--transition)}.admin-btn:hover{background:var(--teal-dark)}.admin-btn:disabled{opacity:.6;cursor:not-allowed}.admin-btn-secondary{background:var(--navy-lighter)}.admin-btn-secondary:hover{background:var(--navy-light)}.admin-btn-danger{background:#dc2626}.admin-btn-danger:hover{background:#b91c1c}.admin-btn-small{font-family:var(--font-display);font-size:11px;font-weight:600;padding:6px 12px;border-radius:6px;cursor:pointer;border:none;color:var(--white);background:var(--teal)}.admin-btn-small:hover{background:var(--teal-dark)}.admin-btn-small.danger{background:#dc2626}.admin-btn-small.danger:hover{background:#b91c1c}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em;text-align:left;padding:10px 12px;border-bottom:1px solid var(--gray-200)}.admin-table td{padding:10px 12px;border-bottom:1px solid var(--gray-100);color:var(--navy)}.admin-badge{font-family:var(--font-display);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:4px;white-space:nowrap}.admin-badge.active{background:#dcfce7;color:#166534}.admin-badge.inactive{background:#fee2e2;color:#991b1b}.admin-badge.admin{background:#ede9fe;color:#5b21b6}.admin-badge.student{background:var(--teal-light);color:var(--teal-dark)}.admin-badge.type-info{background:#dbeafe;color:#1e40af}.admin-badge.type-success{background:#dcfce7;color:#166534}.admin-badge.type-warning{background:#fef3c7;color:#92400e}.admin-badge.type-alert{background:#fee2e2;color:#991b1b}.admin-code-btn{font-family:Courier New,monospace;font-size:13px;font-weight:700;color:var(--teal);background:var(--teal-light);border:none;padding:4px 10px;border-radius:4px;cursor:pointer}.admin-code-btn:hover{background:var(--mint-light)}.admin-back-small{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--teal);background:none;border:none;cursor:pointer;margin-bottom:12px}.admin-user-detail p{font-size:14px;margin-bottom:6px;color:var(--gray-600)}.admin-user-detail p strong{color:var(--navy)}.admin-reset-link{margin-top:16px;padding:12px;background:var(--teal-light);border-radius:8px}.admin-reset-link p{font-size:12px;margin-bottom:8px;color:var(--gray-600)}.admin-reset-link small{font-size:11px;color:var(--gray-500)}@media(max-width:640px){.auth-card{padding:32px 24px}.admin-tabs{overflow-x:auto}.admin-form-row{flex-direction:column}.admin-input{width:100%!important}}
