:root{--blue:#0b61f6;--blue2:#063d9a;--cyan:#17c6d7;--orange:#ff8a1c;--green:#21c78a;--purple:#7a5cff;--red:#f04444;--ink:#071637;--muted:#64748b;--line:#e6eef8;--soft:#f5f9ff;--card:#fff;--shadow:0 18px 45px rgba(18,42,88,.11);--shadow2:0 10px 26px rgba(15,23,42,.08);--r16:16px;--r22:22px;--r28:28px;--font:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:linear-gradient(180deg,#f3f8ff 0,#f8fbff 45%,#fff 100%);color:var(--ink);font-family:var(--font);min-height:100vh}button,input,select{font:inherit}button{cursor:pointer;border:0}.top-header{height:78px;display:grid;grid-template-columns:330px minmax(260px,1fr) auto;align-items:center;gap:28px;padding:0 72px;background:linear-gradient(135deg,#0746a6,#063682 56%,#072d6d);color:#fff;position:sticky;top:0;z-index:50;box-shadow:0 8px 28px rgba(3,28,78,.24)}.brand{display:flex;align-items:center;gap:14px;color:#fff;text-decoration:none}.brand-mark{width:50px;height:50px;display:grid;place-items:center}.brand-mark svg{width:48px;height:48px;fill:#fff}.brand strong{display:block;font-size:30px;line-height:1;font-weight:950}.brand small{display:block;font-size:12px;color:#d5e6ff;font-weight:700}.search-shell{height:52px;background:#fff;border-radius:999px;display:flex;align-items:center;gap:14px;padding:0 18px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.8),0 8px 22px rgba(0,0,0,.12)}.search-shell input{width:100%;border:0;outline:0;font-size:15px;color:#0f172a}.search-icon{font-size:29px;color:#64748b;transform:rotate(-15deg)}kbd{background:#f2f6fb;border:1px solid #dce7f5;border-radius:12px;padding:5px 9px;color:#607086;font-weight:800}.top-actions{display:flex;align-items:center;gap:14px}.ghost-btn,.accent-btn,.icon-btn,.profile-btn,.primary-btn,.outline-btn{border-radius:14px;min-height:44px;padding:0 20px;font-weight:900}.ghost-btn{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28)}.accent-btn{background:var(--orange);color:#fff;box-shadow:0 8px 20px rgba(255,138,28,.33)}.icon-btn{position:relative;background:transparent;color:#fff;font-size:24px;padding:0 8px}.icon-btn b{position:absolute;right:0;top:7px;background:#ef4444;border:2px solid #fff;border-radius:99px;font-size:11px;padding:0 5px}.profile-btn{display:flex;align-items:center;gap:8px;background:transparent;color:#fff;padding:0 0}.avatar{width:42px;height:42px;border-radius:999px;background:linear-gradient(135deg,#fff,#cae2ff);color:#0746a6;display:grid;place-items:center;font-weight:950}.main-nav{height:58px;display:flex;align-items:center;gap:34px;padding:0 80px;background:rgba(255,255,255,.93);backdrop-filter:blur(18px);border-bottom:1px solid #dfe8f5;position:sticky;top:78px;z-index:45}.nav-item{height:58px;background:transparent;color:#1e293b;display:inline-flex;align-items:center;gap:10px;font-weight:850;position:relative}.nav-item span{font-size:22px;color:#66738d}.nav-item.is-active{color:var(--blue)}.nav-item.is-active:after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;border-radius:99px;background:var(--blue)}.dashboard-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:22px;padding:22px 58px 36px;max-width:1760px;margin:auto}.main-column{min-width:0;display:grid;gap:16px}.side-column{display:grid;gap:16px;align-content:start}.hero-card{min-height:310px;border-radius:var(--r28);padding:34px 32px;display:grid;grid-template-columns:minmax(440px,1.1fr) minmax(370px,.8fr) 320px;gap:24px;background:radial-gradient(circle at 56% 32%,rgba(52,157,255,.18),transparent 34%),linear-gradient(135deg,#fff,#eef7ff);box-shadow:var(--shadow);overflow:hidden;position:relative}.hero-copy{z-index:2}.welcome-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid #e3edf8;border-radius:999px;padding:9px 14px;color:#46617f;font-weight:850;margin-bottom:16px}.hero-copy h1{margin:0;color:#071637;font-size:clamp(40px,4.3vw,64px);line-height:.98;letter-spacing:-.06em}.hero-copy h1 span{display:block;color:var(--blue)}.hero-copy p{max-width:650px;color:#66738d;font-size:17px;line-height:1.58;margin:22px 0}.hero-actions{display:flex;gap:14px}.primary-btn{background:var(--blue);color:#fff;box-shadow:0 12px 28px rgba(11,97,246,.26)}.outline-btn{background:#fff;color:var(--blue);border:1px solid #b9d4ff}.hero-visual{position:relative;min-height:240px}.device-card{position:absolute;left:98px;top:34px;width:280px;height:165px;background:#fff;border-radius:22px;box-shadow:0 28px 58px rgba(11,36,78,.22);transform:rotate(-5deg);overflow:hidden}.device-bar{height:32px;background:#0f2b55}.play-bubble{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--blue),#31d0ff);display:grid;place-items:center;color:#fff;position:absolute;left:112px;top:56px}.mini-chart{position:absolute;left:35px;right:35px;bottom:22px;display:flex;gap:8px;align-items:end}.mini-chart i{flex:1;background:linear-gradient(#a8d4ff,#0b61f6);border-radius:8px}.mini-chart i:nth-child(1){height:28px}.mini-chart i:nth-child(2){height:48px}.mini-chart i:nth-child(3){height:36px}.mini-chart i:nth-child(4){height:62px}.lab-books{position:absolute;left:20px;bottom:28px;z-index:3;display:grid;gap:5px}.lab-books span{display:block;width:120px;border-radius:8px;padding:6px 10px;color:#fff;font-size:12px;font-weight:950;box-shadow:0 6px 12px rgba(0,0,0,.15)}.lab-books span:nth-child(1){background:#0d9f87}.lab-books span:nth-child(2){background:#1855d8}.lab-books span:nth-child(3){background:#8b5cf6}.molecule-art{position:absolute;left:0;top:20px;width:150px}.molecule-art line{stroke:#4f80c7;stroke-width:5;stroke-linecap:round}.molecule-art circle{fill:#ff844a;filter:drop-shadow(0 8px 8px rgba(0,0,0,.12))}.molecule-art circle:nth-of-type(2){fill:#18bdbb}.molecule-art circle:nth-of-type(3){fill:#1d74ff}.molecule-art circle:nth-of-type(4){fill:#ffc14d}.microscope{position:absolute;right:16px;bottom:14px;width:85px;height:160px;border-radius:40px 40px 20px 20px;border:16px solid #1f2937;border-left-color:transparent;border-bottom-color:#1f2937;transform:rotate(14deg);opacity:.85}.microscope span{position:absolute;width:92px;height:22px;border-radius:12px;background:#1f2937;right:-42px;top:10px}.stats-card{background:rgba(255,255,255,.86);border:1px solid rgba(255,255,255,.75);border-radius:24px;padding:18px;box-shadow:var(--shadow2);display:grid;grid-template-columns:1fr 1fr;gap:12px;align-self:center}.stats-card div{background:#fff;border:1px solid #e9f0fb;border-radius:16px;padding:16px;display:grid;gap:5px}.stats-card div span{font-size:24px}.stats-card strong{font-size:23px;color:#16345c}.stats-card small{color:#64748b}.stats-card p{grid-column:1/-1;background:#eaf4ff;border-radius:14px;padding:12px;text-align:center;color:#0b61f6;font-weight:900;margin:0}.category-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;background:#fff;border:1px solid #e5edf7;border-radius:22px;padding:12px;box-shadow:var(--shadow2)}.category-strip button{display:flex;align-items:center;justify-content:center;gap:10px;min-height:58px;border-radius:16px;background:#fff;color:#1f2c45;font-weight:850}.category-strip button:hover,.category-strip button.is-active{background:#eff6ff;color:var(--blue)}.category-strip span{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:#eef6ff;color:var(--blue);font-size:22px}.promo-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.promo{height:146px;border-radius:22px;padding:20px;position:relative;overflow:hidden;color:#fff;display:grid;grid-template-columns:1fr 170px;box-shadow:var(--shadow2)}.promo h3{font-size:24px;margin:0 0 8px}.promo p{margin:0 0 14px;line-height:1.4;font-weight:600;color:rgba(255,255,255,.86)}.promo button{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:999px;padding:9px 16px;font-weight:850}.promo-blue{background:linear-gradient(135deg,#0b61f6,#0045aa)}.promo-orange{background:linear-gradient(135deg,#ff8a1c,#ffad27)}.promo-teal{background:linear-gradient(135deg,#03afa8,#03c1cf)}.promo-canvas{position:absolute;right:0;top:0;width:220px;height:146px}.section-card,.side-card{background:#fff;border:1px solid #e5edf7;border-radius:22px;box-shadow:var(--shadow2)}.section-card{padding:18px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.section-head h2,.side-card h3{margin:0}.section-head h2 span{font-size:13px;background:#e8f2ff;color:var(--blue);border-radius:999px;padding:5px 9px;vertical-align:middle}.section-head p{margin:4px 0 0;color:#64748b}.section-head button,.side-card header button{background:transparent;color:var(--blue);font-weight:900}.module-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.module-card{border:1px solid #e6edf7;background:#fff;border-radius:16px;overflow:hidden;text-align:left;box-shadow:0 10px 20px rgba(15,23,42,.07);transition:.18s transform,.18s box-shadow}.module-card:hover{transform:translateY(-4px);box-shadow:0 18px 35px rgba(15,23,42,.14)}.module-thumb{height:110px;position:relative;overflow:hidden;background:linear-gradient(135deg,#0b61f6,#20c5d7)}.module-thumb canvas{width:100%;height:100%}.module-chip{position:absolute;left:10px;top:10px;border-radius:999px;background:rgba(255,255,255,.85);padding:5px 8px;color:#0b61f6;font-size:11px;font-weight:900}.module-body{padding:13px}.module-body h3{font-size:16px;line-height:1.2;margin:0 0 6px}.module-body p{height:38px;overflow:hidden;color:#64748b;font-size:12px;line-height:1.45;margin:0 0 10px}.module-meta{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#64748b}.play-dot{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#eef6ff;color:var(--blue);border:1px solid #c9ddff}.side-card{padding:16px}.side-card header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.progress-body{display:grid;grid-template-columns:100px 1fr;gap:12px;align-items:center}.progress-ring{width:94px;height:94px;border-radius:50%;background:conic-gradient(var(--blue) calc(var(--progress)*1%),#e7effb 0);display:grid;place-items:center;position:relative}.progress-ring:after{content:"";position:absolute;inset:10px;border-radius:50%;background:#fff}.progress-ring strong,.progress-ring span{z-index:1}.progress-ring strong{font-size:20px}.progress-ring span{font-size:12px;color:#64748b;margin-top:-16px}.progress-body ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}.progress-body li{display:flex;justify-content:space-between;gap:8px;font-size:12px}.progress-line{height:8px;background:#e9f0fb;border-radius:999px;overflow:hidden;margin-top:14px}.progress-line i{display:block;height:100%;background:var(--blue);border-radius:999px}.schedule-list,.task-list{display:grid;gap:9px}.schedule-list button,.task-list button{border:1px solid #edf2f8;background:#fff;border-radius:14px;padding:10px;text-align:left;display:grid;grid-template-columns:88px 1fr auto;gap:6px;align-items:center}.schedule-list time{font-size:12px;color:#64748b}.schedule-list strong,.task-list strong{font-size:13px}.schedule-list span,.task-list small{font-size:12px;color:#64748b}.schedule-list em,.task-list em{font-size:11px;font-style:normal;background:#e8f2ff;color:#0b61f6;border-radius:8px;padding:4px 6px}.task-list button{grid-template-columns:26px 1fr auto}.quick-actions div{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.quick-actions button{min-height:82px;border-radius:14px;background:#f8fbff;color:#31415c;font-size:11px;font-weight:850}.quick-actions span{display:block;font-size:24px;margin-bottom:8px}.filter-row{display:flex;gap:10px;margin-bottom:14px}.filter-row select,.filter-row button{height:44px;border-radius:12px;border:1px solid #dbe8f7;background:#fff;padding:0 12px}.catalog-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.catalog-item{border:1px solid #e6edf7;border-radius:14px;background:#fff;padding:12px;text-align:left}.catalog-item strong{display:block}.catalog-item small{color:#64748b}.hidden{display:none!important}.module-dialog{width:min(1240px,96vw);height:min(830px,92vh);border:0;border-radius:24px;box-shadow:0 30px 80px rgba(0,0,0,.28);padding:0}.module-dialog::backdrop,.info-dialog::backdrop{background:rgba(3,18,45,.55);backdrop-filter:blur(8px)}.dialog-shell{height:100%;display:grid;grid-template-rows:60px 1fr}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:0 18px;border-bottom:1px solid #e5edf7;background:#fff}.dialog-header small{display:block;color:#64748b}.dialog-header button{height:38px;border-radius:12px;background:#eef6ff;color:var(--blue);font-weight:900;padding:0 12px}.dialog-header button:last-child{background:#fee2e2;color:#b91c1c;font-size:24px}iframe{width:100%;height:100%;border:0}.info-dialog{border:0;border-radius:22px;padding:0;box-shadow:var(--shadow);max-width:480px}.info-dialog form{padding:0;margin:0}.info-dialog header{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid #e5edf7}.info-dialog header button{background:#f1f5f9;border-radius:10px;width:34px;height:34px}.info-dialog p{padding:20px;margin:0;color:#43516a;line-height:1.6}.info-dialog menu{display:flex;justify-content:flex-end;padding:0 18px 18px;margin:0}.noscript{margin:20px;padding:16px;background:#fee2e2;color:#991b1b;border-radius:12px}@media(max-width:1280px){.top-header{padding:0 24px;grid-template-columns:250px minmax(220px,1fr) auto}.dashboard-layout{grid-template-columns:1fr;padding:18px}.hero-card{grid-template-columns:1fr}.stats-card{grid-template-columns:repeat(4,1fr)}.side-column{grid-template-columns:repeat(2,1fr)}.module-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:820px){.top-header{height:auto;grid-template-columns:1fr;padding:14px}.search-shell{grid-column:1/-1}.top-actions{grid-column:1/-1;flex-wrap:wrap}.main-nav{top:0;overflow-x:auto;padding:0 14px;gap:20px}.dashboard-layout{padding:12px}.hero-card{padding:22px;min-height:auto}.hero-copy h1{font-size:42px}.category-strip{grid-template-columns:repeat(2,1fr)}.promo-grid,.side-column,.stats-card,.module-grid,.catalog-list{grid-template-columns:1fr}.hero-visual{display:none}}