:root{--white: #ffffff;--bg: #f5f5f0;--bg2: #fafaf8;--surface: #ffffff;--surface2: #f8f8f6;--ink: #111111;--ink2: #444444;--ink3: #888888;--ink4: #bbbbbb;--accent: #1a6b3a;--accent-light: #eef6f1;--accent-mid: #2d8a50;--border: #e8e8e4;--border2: #d4d4ce;--shadow-xs: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 2px 8px rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.05);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.05);--shadow-lg: 0 8px 32px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.06);--r-sm: 6px;--r: 10px;--r-lg: 14px;--r-xl: 20px;--font-serif: "Instrument Serif", Georgia, serif;--font-sans: "Outfit", system-ui, sans-serif;--nav-h: 64px;--transition: .18s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none}input,textarea,select{font-family:var(--font-sans)}img{display:block;max-width:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}.container{max-width:1160px;margin:0 auto;padding:0 24px}.container-sm{max-width:780px;margin:0 auto;padding:0 24px}.serif{font-family:var(--font-serif)}h1,h2,h3,h4{color:var(--ink);font-weight:600;line-height:1.2;letter-spacing:-.3px}.text-sm{font-size:13px}.text-xs{font-size:11px;letter-spacing:.3px}.text-muted{color:var(--ink3)}.text-accent{color:var(--accent)}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.flex{display:flex;align-items:center}.flex-col{display:flex;flex-direction:column}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-center{display:flex;align-items:center;justify-content:center}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-32{gap:32px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 20px;border-radius:var(--r);font-size:14px;font-weight:500;transition:all var(--transition);cursor:pointer;border:none;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-mid);box-shadow:0 2px 8px #1a6b3a40;transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--ink);border:1px solid var(--border2);box-shadow:var(--shadow-xs)}.btn-secondary:hover{border-color:var(--border2);background:var(--surface2);box-shadow:var(--shadow-sm)}.btn-ghost{background:transparent;color:var(--ink2)}.btn-ghost:hover{background:var(--surface2);color:var(--ink)}.btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}.btn-outline:hover{background:var(--accent);color:#fff}.btn-danger{background:#fef2f2;color:#c0392b;border:1px solid #fecaca}.btn-danger:hover{background:#fee2e2}.btn-sm{padding:7px 14px;font-size:13px;border-radius:var(--r-sm)}.btn-lg{padding:13px 28px;font-size:15px;border-radius:var(--r-lg)}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-hover{transition:box-shadow var(--transition),transform var(--transition);cursor:pointer}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.3px}.badge-green{background:#dcfce7;color:#166534}.badge-amber{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:var(--surface2);color:var(--ink3);border:1px solid var(--border)}.pill{padding:6px 14px;border-radius:99px;font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--ink3);cursor:pointer;transition:all var(--transition)}.pill:hover{border-color:var(--border2);color:var(--ink2)}.pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--ink2);margin-bottom:6px}.form-input{width:100%;background:var(--white);border:1px solid var(--border2);border-radius:var(--r);padding:10px 14px;color:var(--ink);font-size:14px;transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a6b3a14}.form-input::placeholder{color:var(--ink4)}.form-error{font-size:12px;color:#c0392b;margin-top:5px}.form-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--ink4);font-size:13px}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeOverlay .2s ease}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.modal{background:var(--white);border-radius:var(--r-xl);box-shadow:var(--shadow-lg),0 0 0 1px #0000000d;width:100%;max-width:420px;padding:36px;animation:slideModal .22s cubic-bezier(.34,1.56,.64,1);position:relative}@keyframes slideModal{0%{transform:translateY(12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-title{font-size:22px;font-weight:600;letter-spacing:-.5px;margin-bottom:6px}.modal-sub{font-size:14px;color:var(--ink3);margin-bottom:24px}.modal-close{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:var(--r-sm);background:var(--surface2);border:1px solid var(--border);color:var(--ink3);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition)}.modal-close:hover{background:var(--border);color:var(--ink)}.progress-track{height:4px;background:var(--bg);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .5s ease}.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 18px;border-radius:var(--r);font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;background:var(--white);box-shadow:var(--shadow-md);border:1px solid var(--border);animation:toastIn .25s ease}@keyframes toastIn{0%{transform:translate(16px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left:3px solid #22c55e}.toast-error{border-left:3px solid #ef4444}.toast-info{border-left:3px solid var(--accent)}.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,#ebebeb 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);box-shadow:0 1px #0000000a}.nav-inner{max-width:1160px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-size:17px;font-weight:700;color:var(--accent);cursor:pointer;display:flex;align-items:center;gap:9px;letter-spacing:-.3px}.nav-logo-mark{width:30px;height:30px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center}.nav-links{display:flex;align-items:center;gap:2px}.nav-link{padding:7px 13px;border-radius:var(--r-sm);font-size:14px;font-weight:500;color:var(--ink3);cursor:pointer;transition:all var(--transition)}.nav-link:hover,.nav-link.active{color:var(--ink);background:var(--surface2)}.nav-actions{display:flex;align-items:center;gap:8px}.avatar-btn{width:34px;height:34px;border-radius:50%;background:var(--accent-light);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--accent);cursor:pointer;transition:all var(--transition)}.avatar-btn:hover{border-color:var(--accent)}.page{padding-top:var(--nav-h);min-height:100vh}.section{padding:72px 0}.section-sm{padding:48px 0}.section-header{margin-bottom:40px}.section-eyebrow{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.section-title{font-size:28px;font-weight:700;letter-spacing:-.5px}.section-sub{font-size:15px;color:var(--ink3);margin-top:6px}.hero-section{padding:88px 0 80px;background:var(--white);border-bottom:1px solid var(--border)}.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;padding:5px 13px;border-radius:99px;background:var(--accent-light);border:1px solid rgba(26,107,58,.15);font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.5px;margin-bottom:22px}.hero-dot{width:5px;height:5px;border-radius:50%;background:var(--accent)}.hero-title{font-size:clamp(40px,5.5vw,62px);font-weight:700;letter-spacing:-2px;line-height:1.06;max-width:700px;color:var(--ink)}.hero-title em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--accent)}.hero-desc{font-size:17px;color:var(--ink3);max-width:500px;margin-top:18px;line-height:1.65}.hero-cta{margin-top:36px;display:flex;gap:12px;flex-wrap:wrap}.hero-stats{display:flex;gap:40px;margin-top:60px;padding-top:40px;border-top:1px solid var(--border);flex-wrap:wrap}.hero-stat-val{font-size:26px;font-weight:700;color:var(--ink)}.hero-stat-label{font-size:13px;color:var(--ink3);margin-top:3px}.course-card{cursor:pointer}.course-card-img{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--surface2)}.course-card-body{padding:18px 20px}.course-card-meta{display:flex;align-items:center;gap:6px;margin-bottom:10px}.course-card-title{font-size:15px;font-weight:600;letter-spacing:-.2px;line-height:1.35;margin-bottom:7px}.course-card-desc{font-size:13px;color:var(--ink3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-card-footer{padding:13px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface2)}.course-meta-item{font-size:12px;color:var(--ink3);display:flex;align-items:center;gap:4px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.hero-title{font-size:36px;letter-spacing:-1px}.hero-stats{gap:24px}.nav-links{display:none}}.dash-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}.dash-sidebar{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;position:sticky;top:calc(var(--nav-h) + 16px)}.dash-nav{padding:8px}.dash-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);font-size:14px;font-weight:500;color:var(--ink3);cursor:pointer;transition:all var(--transition);margin-bottom:2px}.dash-nav-item:hover{background:var(--surface2);color:var(--ink)}.dash-nav-item.active{background:var(--accent-light);color:var(--accent)}.dash-nav-item svg{width:16px;height:16px;flex-shrink:0}.dash-nav-section{padding:8px 12px 4px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink4)}@media (max-width: 768px){.dash-layout{grid-template-columns:1fr}.dash-sidebar{position:static}}.xp-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:20px 24px}.xp-rank-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:4px}.xp-val{font-size:22px;font-weight:700;color:var(--ink)}.xp-sub{font-size:12px;color:var(--ink3);margin-top:2px}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:18px 20px}.stat-val{font-size:28px;font-weight:700;color:var(--ink)}.stat-label{font-size:12px;color:var(--ink3);margin-top:4px;font-weight:500}.stat-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.module-item{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition)}.module-item:last-child{border-bottom:none}.module-item:hover{background:var(--surface2)}.module-item.active{background:var(--accent-light)}.module-num{width:26px;height:26px;border-radius:50%;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--ink3)}.module-num.done{background:var(--accent);border-color:var(--accent);color:#fff;font-size:12px}.module-title{font-size:13px;font-weight:500;flex:1;color:var(--ink2)}.module-title.active{color:var(--ink);font-weight:600}.module-xp-tag{font-size:11px;color:var(--accent);font-weight:600}.viewer-wrap{display:grid;grid-template-columns:1fr 300px;height:calc(100vh - var(--nav-h))}.viewer-main{overflow-y:auto;background:var(--bg2)}.viewer-sidebar{background:var(--white);border-left:1px solid var(--border);overflow-y:auto}.viewer-sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink3);background:var(--surface2)}.video-area{width:100%;aspect-ratio:16/9;background:#0f0f0f;display:flex;align-items:center;justify-content:center}.video-area video{width:100%;height:100%}.viewer-content{padding:28px}.viewer-mod-title{font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}@media (max-width: 768px){.viewer-wrap{grid-template-columns:1fr;height:auto}.viewer-sidebar{display:none}}.lb-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.lb-item:last-child{border-bottom:none}.lb-rank{width:30px;text-align:center;font-size:17px;font-weight:700;color:var(--ink3);flex-shrink:0}.lb-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent-light);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--accent);flex-shrink:0}.lb-name{font-size:14px;font-weight:600;flex:1}.lb-xp-val{font-size:13px;font-weight:700;color:var(--accent)}.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.ach-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs);padding:18px 14px;text-align:center;transition:all var(--transition)}.ach-card.earned{border-color:#1a6b3a33;background:#f0faf4;box-shadow:0 2px 8px #1a6b3a14}.ach-card.locked{opacity:.45;filter:grayscale(.6)}.ach-icon{font-size:32px;margin-bottom:8px}.ach-name{font-size:12px;font-weight:600;color:var(--ink2)}.ach-xp{font-size:11px;color:var(--accent);margin-top:3px;font-weight:600}.footer{background:var(--white);border-top:1px solid var(--border);padding:56px 0 32px;margin-top:80px}.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}.footer-brand{font-size:16px;font-weight:700;color:var(--accent);margin-bottom:10px;display:flex;align-items:center;gap:8px}.footer-tagline{font-size:13px;color:var(--ink3);line-height:1.7;max-width:240px}.footer-col-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink4);margin-bottom:14px}.footer-link{display:block;font-size:13px;color:var(--ink3);padding:4px 0;cursor:pointer;transition:color var(--transition)}.footer-link:hover{color:var(--accent)}.footer-bottom{padding-top:24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--ink4)}@media (max-width: 768px){.footer-grid{grid-template-columns:1fr 1fr;gap:28px}}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink4);pointer-events:none}.search-input{padding-left:36px}.course-detail-hero{background:var(--white);border-bottom:1px solid var(--border);padding:48px 0}.course-detail-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}@media (max-width: 900px){.course-detail-grid{grid-template-columns:1fr}}.course-sticky-card{position:sticky;top:calc(var(--nav-h) + 16px);background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden}.breadcrumb{font-size:13px;color:var(--ink3);cursor:pointer;margin-bottom:16px;display:flex;align-items:center;gap:5px}.breadcrumb:hover{color:var(--accent)}.course-title-lg{font-size:clamp(22px,3.5vw,32px);font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:14px}.course-info-row{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:24px}.course-info-item{font-size:13px;color:var(--ink3);display:flex;align-items:center;gap:5px}.empty-state{text-align:center;padding:60px 20px}.empty-icon{font-size:44px;margin-bottom:14px}.empty-title{font-size:16px;font-weight:600;color:var(--ink2);margin-bottom:7px}.empty-desc{font-size:14px;color:var(--ink3);margin-bottom:20px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .35s ease forwards}.fade-up-1{animation-delay:.05s}.fade-up-2{animation-delay:.1s}.fade-up-3{animation-delay:.15s}.fade-up-4{animation-delay:.2s}.fade-up-5{animation-delay:.25s}.fade-up-6{animation-delay:.3s}.markdown-body{font-size:15px;color:var(--ink);line-height:1.7}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{margin-top:1.5em;margin-bottom:.5em;font-weight:600;line-height:1.25}.markdown-body h1{font-size:2em;border-bottom:1px solid var(--border);padding-bottom:.3em}.markdown-body h2{font-size:1.5em;border-bottom:1px solid var(--border);padding-bottom:.3em}.markdown-body p,.markdown-body blockquote,.markdown-body ul,.markdown-body ol,.markdown-body dl,.markdown-body table,.markdown-body pre,.markdown-body details{margin-top:0;margin-bottom:16px}.markdown-body a{color:var(--accent);text-decoration:none}.markdown-body a:hover{text-decoration:underline}.markdown-body strong{font-weight:600}.markdown-body ul,.markdown-body ol{padding-left:2em}.markdown-body ul{list-style-type:disc}.markdown-body ol{list-style-type:decimal}.markdown-body img{max-width:100%;box-sizing:content-box;background-color:var(--white)}.markdown-body code,.markdown-body tt{padding:.2em .4em;margin:0;font-size:85%;white-space:break-spaces;background-color:var(--surface2);border-radius:6px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace}.markdown-body pre{padding:16px;overflow:auto;font-size:85%;line-height:1.45;background-color:#f6f8fa;border-radius:6px}.markdown-body pre code{padding:0;margin:0;font-size:100%;white-space:pre;background:transparent;border:0}.markdown-body blockquote{padding:0 1em;color:var(--ink3);border-left:.25em solid var(--border2)}.markdown-body hr{height:.25em;padding:0;margin:24px 0;background-color:var(--border);border:0}.markdown-body table{display:block;width:100%;width:max-content;max-width:100%;overflow:auto}.markdown-body table th{font-weight:600}.markdown-body table th,.markdown-body table td{padding:6px 13px;border:1px solid var(--border)}.markdown-body table tr{background-color:var(--white);border-top:1px solid var(--border2)}.markdown-body table tr:nth-child(2n){background-color:var(--surface2)}
