:root{font-family:Inter,system-ui,Segoe UI,Arial,sans-serif;color:#1e293b;background:#f4f7fb;--primary:#2563eb;--primary2:#3b82f6;--accent:#0ea5e9;--ink:#1e293b;--muted:#64748b;--line:#dbe4f0;--soft:#eff6ff;--card:#fff;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--shadow:0 24px 80px rgba(37,99,235,.12)}*{box-sizing:border-box}body{margin:0;background:#f4f7fb}button,input,select,textarea{font:inherit}button{border:0;border-radius:14px;padding:12px 16px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;font-weight:800;display:inline-flex;gap:8px;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 12px 24px #2563eb2e}button.light,.ghost{background:#fff;color:var(--primary);border:1px solid var(--line);box-shadow:none}button.danger{background:#fff;color:#b91c1c;border:1px solid #fecaca;box-shadow:none}.sm{padding:7px 10px}.login{min-height:100vh;display:grid;grid-template-columns:1.2fr 430px;gap:34px;align-items:center;padding:7vw;background:radial-gradient(circle at 20% 15%,#dbeafe,transparent 28%),linear-gradient(135deg,#f8fbff,#eaf4ff 48%,#2563eb)}.logo{width:260px}.logo.small{width:128px;margin:10px auto 30px;display:block;filter:drop-shadow(0 12px 28px rgba(0,0,0,.16))}.loginHero h1{font-size:84px;letter-spacing:-5px;line-height:.95;margin:18px 0;color:#0f172a}.loginHero p{font-size:22px;max-width:740px;line-height:1.55;color:#334155}.loginCard,.panel,.card,.stat,.hero,.filters{background:#fffffff5;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}.loginCard{padding:32px}.loginCard h2{font-size:32px;margin:0 0 8px}.loginCard input,label input,label select,label textarea{width:100%;margin-top:8px;border:1px solid var(--line);border-radius:14px;padding:13px;background:#fff;color:var(--ink)}textarea{min-height:110px;resize:vertical}.loginCard label,label{display:block;font-weight:800;margin:14px 0}.muted,.stat span,.title p,.card small,.meta,.empty,.panel p{color:var(--muted)}.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}.passwordRules,.alert{border-radius:16px;padding:12px 14px;margin:12px 0;font-weight:800;display:flex;align-items:center;gap:8px}.passwordRules{background:#eff6ff;color:#1d4ed8}.alert.error{background:#fef2f2;color:#b91c1c}.alert.success{background:#ecfdf5;color:#047857}.authLinks{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0}.link{background:transparent;color:var(--primary);box-shadow:none;padding:8px}.app{min-height:100vh}.side{position:fixed;inset:0 auto 0 0;width:265px;background:linear-gradient(180deg,#1d4ed8,#075985);padding:18px;color:#fff}.side button{width:100%;justify-content:flex-start;background:transparent;color:#dbeafe;margin:4px 0;box-shadow:none}.side button.active,.side button:hover{background:#fffffff2;color:#1d4ed8}.sideFooter{position:absolute;left:20px;right:20px;bottom:22px;display:flex;align-items:center;gap:8px;color:#dbeafe;font-weight:800}.top{position:fixed;left:265px;right:0;top:0;height:78px;background:#ffffffe0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 26px;z-index:5}.search{flex:1;max-width:780px;background:#f8fbff;border:1px solid var(--line);border-radius:999px;padding:0 16px;display:flex;gap:10px;align-items:center;height:48px}.search input{border:0;background:transparent;outline:0;width:100%}.apiState{display:flex;align-items:center;gap:8px;font-weight:900;color:var(--muted)}.dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1;display:inline-block}.dot.on{background:var(--success)}.user{text-align:right;margin-left:auto}.user small{display:block;color:var(--muted)}main{margin-left:265px;padding:106px 30px 40px}.hero{padding:42px;background:radial-gradient(circle at right,#bfdbfe,transparent 32%),linear-gradient(135deg,#fff,#eff6ff);min-height:300px;display:flex;align-items:center}.hero h1{font-size:56px;letter-spacing:-3px;line-height:.95;margin:14px 0;color:#0f172a}.hero p{font-size:19px;color:#475569;max-width:850px;line-height:1.6}.pill,.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:8px 12px;font-weight:900;font-size:13px}.pill{background:#dbeafe;color:#1d4ed8}.badge{background:#eff6ff;color:#1d4ed8}.badge.public{background:#ecfdf5;color:#047857}.badge.private{background:#fff7ed;color:#c2410c}.heroBtns{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:22px 0}.stat{padding:22px}.stat b{font-size:40px;display:block;color:#0f172a}.title{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}.title h2{font-size:30px;margin:0}.panel{padding:26px;margin:22px 0}.cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.card{padding:20px;display:flex;flex-direction:column;gap:10px}.cardTop{display:flex;gap:8px;justify-content:space-between}.card h3{margin:4px 0;font-size:20px}.card p{margin:0;line-height:1.45}.actions{display:flex;gap:8px;align-items:center;margin-top:auto}.table{display:flex;flex-direction:column;gap:10px}.row{display:grid;grid-template-columns:1.7fr .7fr .45fr .45fr;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px}.row small{display:block;color:var(--muted);margin-top:4px}.form{max-width:960px}.form.narrow{max-width:520px}.drop{border:2px dashed #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:18px;padding:22px;text-align:center;font-weight:900;margin:14px 0}.empty{border:1px dashed var(--line);border-radius:20px;padding:34px;text-align:center;background:#f8fbff}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a7a;z-index:30;display:grid;place-items:center;padding:24px}.modalBox{max-width:1040px;width:100%;max-height:92vh;overflow:auto;position:relative}.close{position:absolute;right:20px;top:20px;z-index:2}.bars{display:grid;gap:12px}.bar{display:grid;grid-template-columns:180px 1fr;align-items:center;gap:12px}.bar b{display:block;background:linear-gradient(90deg,var(--primary),var(--accent));height:28px;color:#fff;border-radius:999px;padding:4px 10px;min-width:38px}.toast{position:fixed;right:28px;bottom:28px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px;padding:14px 16px;z-index:40;display:flex;gap:12px;align-items:center;font-weight:900}.accountGrid{display:flex;gap:18px;align-items:center;margin:16px 0 28px}.profileBadge{width:76px;height:76px;border-radius:26px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:grid;place-items:center;font-size:26px;font-weight:900}@media (max-width:950px){.login{grid-template-columns:1fr}.side{position:static;width:auto}.top{left:0;position:sticky}.user{display:none}main{margin-left:0;padding:24px}.stats,.cards,.row,.two{grid-template-columns:1fr}.loginHero h1{font-size:54px}}.programGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.programCard{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 14px 38px #2563eb14}.programCard h3{font-size:22px;margin:12px 0 6px}.programStats{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:8px;align-items:end;background:#f8fbff;border:1px solid var(--line);border-radius:18px;padding:12px;margin:14px 0}.programStats b{font-size:28px;color:#0f172a}.programStats span{color:var(--muted);font-weight:800}.competencyList{display:grid;gap:7px;margin-top:12px}.competencyList small{display:block;background:#eff6ff;border:1px solid #dbeafe;border-radius:12px;padding:8px 10px;color:#1e40af;font-weight:800}.filters{padding:14px;margin-bottom:18px;display:flex;gap:12px;align-items:center}.filters select{border:1px solid var(--line);border-radius:999px;padding:13px;background:#fff;font-weight:900;color:var(--ink)}@media (max-width:950px){.programGrid{grid-template-columns:1fr}.filters{flex-direction:column;align-items:stretch}.filters .search{max-width:none;width:100%}}.jsonBox{min-height:320px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;line-height:1.45}.importStats{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:8px 10px;align-items:center;background:#f5f9ff;border:1px solid #dbeafe;border-radius:16px;padding:16px;color:#15365f}.importStats b{font-size:28px}.importStats span{color:#64748b;font-size:13px}.uploadBox{border:2px dashed #bfdbfe;background:#eff6ff;border-radius:22px;padding:18px;margin:14px 0}.uploadBox input{display:block;margin-top:8px}.filePreview{display:flex;gap:12px;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;margin-top:10px}.filePreview span{color:var(--muted);font-weight:800}.previewBox{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:22px;max-width:1180px}.previewHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin:0 54px 16px 0}.previewHeader h2{margin:0;font-size:28px;color:#0f172a}.previewHeader p{margin:6px 0 0;color:var(--muted);font-weight:800}.previewFrame{width:100%;height:70vh;border:1px solid var(--line);border-radius:20px;background:#f8fbff}.previewImage{display:block;max-width:100%;max-height:70vh;margin:auto;border-radius:20px;border:1px solid var(--line);background:#f8fbff}.previewVideo{width:100%;max-height:70vh;border-radius:20px;background:#0f172a}.previewFallback{min-height:420px;border:2px dashed #bfdbfe;border-radius:22px;background:#eff6ff;display:grid;place-items:center;text-align:center;padding:36px;color:#1e40af}.previewFallback h3{margin:10px 0 0;font-size:24px}.previewFallback p{max-width:560px;color:#475569}.panel.highlight{border-color:#2563eb2e;background:linear-gradient(180deg,#eff6ffe6,#fff)}.programQuick{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.programChip{border:1px solid rgba(37,99,235,.2);background:#fff;border-radius:18px;padding:12px 16px;display:flex;flex-direction:column;align-items:flex-start;gap:3px;min-width:180px;cursor:pointer;box-shadow:0 10px 25px #0f172a0f}.programChip:hover{transform:translateY(-1px);border-color:#2563eb73}.programChip b{color:#1d4ed8}.programChip span{font-size:.82rem;color:#64748b}.myProgramsTop{margin:14px 0 18px;padding:16px;border-radius:22px;background:linear-gradient(135deg,#eff6ff,#fff);border:1px solid rgba(37,99,235,.14)}.myProgramsTop h3{margin:0 0 8px}.programCard.preferred{border:2px solid rgba(37,99,235,.35);box-shadow:0 16px 35px #2563eb1a}.badge.mine{background:#dbeafe;color:#1d4ed8}.programCheckGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.programCheck{border:1px solid #e2e8f0;border-radius:16px;padding:12px;display:flex;align-items:center;gap:10px;background:#fff;cursor:pointer}.programCheck input{width:18px;height:18px}.programCheck span{display:flex;flex-direction:column;gap:2px}.programCheck small{color:#64748b}.stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.storagePanel{background:linear-gradient(180deg,#fff,#f8fbff)}.storageGrid{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:14px}.storageCard{border:1px solid var(--line);border-radius:20px;background:#fff;padding:16px;box-shadow:0 10px 26px #2563eb0f}.storageCard.main{background:linear-gradient(135deg,#eff6ff,#fff);border-color:#bfdbfe}.storageHead{display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:900;margin-bottom:10px}.storageHead span{color:#1d4ed8;font-size:.92rem;white-space:nowrap}.progress{height:14px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin:10px 0}.progress i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent));min-width:0}.storageCard small,.accountStorageNote{color:var(--muted);font-weight:800}.accountStorageNote{display:inline-flex;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:10px 14px;margin:-10px 0 20px}@media (max-width:950px){.storageGrid{grid-template-columns:1fr}.storageHead{align-items:flex-start;flex-direction:column}}
