:root{--blue:#2563eb;--blue-dark:#1d4ed8;--text:#0f172a;--muted:#64748b;--bg:#f8fafc;--card:#fff;--ring:#e2e8f0;--shadow:0 6px 24px rgba(15,23,42,.06)}*{box-sizing:border-box}body,html{margin:0;height:100%}body{font:16px/1.5 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto;color:var(--text);background:#fff}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{max-width:1200px;margin:auto;padding:0 1rem}.accent{color:var(--blue)}.mt-2{margin-top:.5rem}.mb-1{margin-bottom:1rem}.btn{background:var(--blue);color:#fff;border:0;border-radius:12px;padding:.65rem 1rem;cursor:pointer}.btn:hover{background:var(--blue-dark)}.input{flex:1 1;padding:.7rem 1rem;border:1px solid var(--ring);border-radius:12px}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;background:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--ring);box-shadow:0 8px 24px rgba(15,23,42,.06)}.header.is-sticky{position:-webkit-sticky;position:sticky;top:0;z-index:50}.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.25rem}.brand span{letter-spacing:.5px}.menu{display:flex;gap:.75rem}.menu,.menu-link{align-items:center}.menu-link{position:relative;display:inline-flex;gap:.4rem;padding:.35rem .25rem;border-radius:8px;font-weight:600;color:var(--text);text-decoration:none;border:1px solid transparent}.menu-link svg{width:18px;height:18px;opacity:.7}.menu-link:hover{background:#f8fafc}.menu-link:hover svg{opacity:1}.menu-link:after{content:"";position:absolute;left:.35rem;right:.35rem;bottom:.2rem;height:2px;background:linear-gradient(90deg,#93c5fd,#2563eb);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.menu-link:hover:after{transform:scaleX(1)}.menu-link.is-active{background:#eef2ff;color:#3730a3}.menu-link.is-active svg{opacity:1}.btn-outline{padding:.45rem .7rem;border-radius:10px;background:#fff}.menu-right{display:flex;align-items:center;gap:.6rem}.welcome-stack{display:flex;flex-direction:column;line-height:1.1;align-items:flex-end}.welcome-title{font-size:.85rem;color:var(--muted)}.welcome-name{font-weight:700}@media (max-width:480px){.welcome-stack{display:none}}.header-divider{height:2px;background:linear-gradient(90deg,transparent,#93c5fd,#2563eb,#93c5fd,transparent)}.hero{background:linear-gradient(#e6f3ff,#f5fbff);padding:3rem 0}.hero h1{font-size:2.2rem;margin:.2rem 0}.hero p{color:var(--muted);max-width:none}.search{display:flex;gap:.5rem;margin-top:1rem}.page-hero{background:linear-gradient(#f8fafc,#fff);border-bottom:1px solid var(--ring);padding:1rem 0 1.25rem;margin-bottom:1rem}.page-hero h1{margin:.25rem 0 0;font-size:1.6rem}.breadcrumb{color:var(--muted);font-size:.9rem}.breadcrumb a{text-decoration:underline}.section{padding:2rem 0}.section h2{font-size:1.8rem;margin:0 0 .6rem}.muted{color:var(--muted)}.grid{display:grid;grid-gap:1rem;gap:1rem}@media (min-width:640px){.grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.grid{grid-template-columns:repeat(4,1fr)}}.card{background:var(--card);border:1px solid var(--ring);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}.card-body{padding:1rem}.title{font-weight:700}.rating{display:flex;align-items:center;gap:.4rem;color:#f59e0b;margin-top:.4rem}.tag{display:inline-block;background:#eef2ff;color:#3730a3;border-radius:999px;padding:.15rem .55rem;font-size:.85rem;margin-top:.6rem}.thumb{display:block;width:100%;height:auto!important;aspect-ratio:16/9;object-fit:cover;border-bottom:1px solid var(--ring)}.progress{margin:.6rem 0}.footer{background:#0b1220;margin-top:2rem}.footer,.footer a{color:#cbd5e1}.footer a:hover{color:#fff}.footer h4{margin:0 0 .6rem;font-size:1rem;color:#e2e8f0}.footer-grid{display:grid;grid-gap:2rem;gap:2rem;padding:2rem 0;grid-template-columns:1fr}@media (min-width:900px){.footer-grid{grid-template-columns:1.2fr .8fr 1fr}}.brand-invert span{color:#fff}.addr{margin:.8rem 0 0;font-style:normal;display:grid;grid-gap:.25rem;gap:.25rem}.addr a{color:#93c5fd}.social{display:flex;gap:.6rem;margin-top:.8rem}.social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#0f172a;color:#9ca3af;border:1px solid #1f2937}.social a:hover{color:#fff;background:#111827}.footer-list{list-style:none;padding:0;margin:0;display:grid;grid-gap:.45rem;gap:.45rem}.news{display:flex;gap:.5rem;margin-top:.5rem}.news input{flex:1 1;padding:.65rem .9rem;border-radius:12px;border:1px solid #334155;background:#0f172a;color:#e5e7eb}.news input::placeholder{color:#64748b}.dump{background:#0f172a;color:#a7f3d0;border:1px solid #1f2937;padding:.75rem;border-radius:12px;max-height:160px;overflow:auto}.copy{border-top:1px solid #1f2937}.copy-flex{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}.brand a{display:inline-flex;align-items:center}.brand a:hover{opacity:.9}.course-intro{display:grid;grid-gap:.5rem;gap:.5rem}.meta-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.25rem 0 .75rem}.pill{display:inline-block;padding:.35rem .6rem;border:1px solid var(--ring);border-radius:999px;background:#fff;color:var(--text);font-size:.9rem}.pill-ok{background:#ecfeff;border-color:#a5f3fc}.cta-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.points-chip{display:inline-block;padding:.35rem .55rem;border:1px solid var(--ring);border-radius:999px;background:#eef2ff;color:#3730a3;font-weight:700;font-size:.9rem}.copy-center{display:flex;align-items:center;justify-content:center;padding:1rem 0;text-align:center}.table-wrap{width:100%;border-radius:12px}.table{font-size:.95rem}.table td,.table th{padding:.75rem .9rem;text-align:left}.table thead th{background:#f8fafc;font-weight:700}.table tbody tr:hover{background:#f9fafb}.progress-item{display:grid;grid-gap:.25rem;gap:.25rem}.course-chip{padding:.2rem .5rem;background:#fff;color:var(--text);font-size:.8rem}.progress{height:10px;border-radius:9999px;background:#f1f5f9;border:1px solid var(--ring);overflow:hidden;margin:.3rem 0}.progress>span{display:block;height:100%;background:var(--blue);width:0;transition:width .4s ease}.progress-val{font-size:.85rem}.stars{color:#e5e7eb}.star{cursor:pointer;color:#cbd5e1}.star:disabled{cursor:default;opacity:.7}.play-row{justify-content:space-between;gap:.75rem;flex-wrap:wrap}.play-actions,.play-row{display:flex;align-items:center}.play-actions{gap:.6rem}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--ring);border-radius:12px;padding:.55rem .9rem;cursor:pointer}.btn-outline:hover{background:#f8fafc}.stars{gap:.25rem;color:#cbd5e1}.star,.stars{display:inline-flex}.star{align-items:center;justify-content:center;border:0;background:transparent;padding:0}.star.filled{color:#f59e0b}.stars.readonly .star{cursor:default;opacity:.9}.stats{display:grid;grid-gap:.75rem;gap:.75rem;grid-template-columns:repeat(3,minmax(0,1fr));margin:.75rem 0 1rem}.stat{background:#f8fafc;border:1px solid var(--ring);border-radius:12px;padding:.75rem 1rem}.stat-label{color:var(--muted);font-size:.9rem}.stat-value{font-size:1.25rem;font-weight:700}.badge{padding:.2rem .6rem;font-weight:700;background:#fff;color:var(--text)}.badge.b-0{background:#f1f5f9;color:#475569}.badge.b-10{background:#e0f2fe;color:#075985}.badge.b-20{background:#dbeafe;color:#1e3a8a}.badge.b-30{background:#e0e7ff;color:#3730a3}.badge.b-40{background:#ede9fe;color:#6d28d9}.badge.b-50{background:#dcfce7;color:#166534}.table td,.table th{padding:.55rem .6rem;border-bottom:1px solid var(--ring)}.course-chip{background:#f1f5f9;padding:.05rem .4rem}.filters{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-top:1rem}.select{padding:.7rem 1rem;border:1px solid var(--ring);border-radius:12px;background:#fff}.kpi-row{display:grid;grid-gap:.75rem;gap:.75rem;margin:1rem 0}@media (min-width:900px){.kpi-row{grid-template-columns:repeat(3,1fr)}}.kpi{background:#fff;border:1px solid var(--ring);border-radius:16px;padding:1rem;box-shadow:var(--shadow)}.kpi-val{font-size:1.6rem;font-weight:800;margin-top:.25rem}.table-wrap{overflow:auto;border:1px solid var(--ring);border-radius:16px;background:#fff;box-shadow:var(--shadow)}.table{width:100%;border-collapse:collapse;min-width:980px}.table td,.table th{padding:.75rem .8rem;border-bottom:1px solid #eef2f7;vertical-align:top}.table th{background:#f8fafc;text-align:left;font-weight:700}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border-radius:999px;font-size:.85rem;border:1px solid var(--ring);white-space:nowrap}.badge-0{background:#f1f5f9}.badge-20{background:#eff6ff}.badge-40{background:#e0f2fe}.badge-60{background:#dcfce7}.badge-80{background:#d1fae5}.badge-100{background:#bbf7d0}.units{white-space:nowrap}.progress-list{list-style:none;padding:0;margin:0;display:grid;grid-gap:.6rem;gap:.6rem}.progress-item{min-width:360px}.progress-sm{height:8px}.progress-green>span{background:#16a34a}.course-chip{display:inline-block;padding:.15rem .45rem;border:1px solid var(--ring);border-radius:999px;background:#f8fafc}.progress-val{color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.progress-label{display:flex;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.25rem}.user-status{margin-top:.75rem;padding:.75rem 1rem;border:1px solid var(--ring);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.status-text{margin:0;color:var(--text)}.notice{border:1px solid var(--ring);background:#f6fbff;border-radius:16px;padding:14px 16px;margin-top:14px}.notice-inner{display:flex;align-items:center;justify-content:center;gap:10px;text-align:center;flex-wrap:wrap}.notice-icon{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.25);font-size:18px}.notice strong{font-weight:700}.notice .muted{opacity:.8}