:root{--brand:#0b5cab;--brand-dark:#082f5f;--bg:#f6f9fe;--text:#0f172a;--muted:#64748b;--card:#ffffff;--ring:rgba(11,92,171,.15)}*{box-sizing:border-box}html,body,#root{height:100%}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;display:flex;flex-direction:column}body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:var(--brand);text-decoration:none}.container{max-width:1100px;margin:0 auto;padding:24px}.nav{position:sticky;top:0;-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);background:#fffc;border-bottom:1px solid #e5e7eb;z-index:10}.nav-inner{display:flex;align-items:center;gap:18px;padding:12px 16px;max-width:1100px;margin:0 auto}.nav a{font-weight:700;padding:8px 10px;border-radius:10px}.nav a:hover{background:var(--ring)}.logo{display:flex;align-items:center;gap:10px}.logo img{height:40px;width:40px;border-radius:10px;border:1px solid #e5e7eb;background:#fff}.logo .brand{font-weight:900;color:var(--brand-dark)}.hero{padding:72px 0;background:linear-gradient(180deg,#fff,#eef5ff)}.hero h1{font-size:48px;line-height:1.1;margin:0 0 12px}.hero p{font-size:18px;color:var(--muted);max-width:800px}.cta{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:12px;border:1px solid #dbe3f3;background:var(--card);font-weight:800;cursor:pointer}.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 10px 20px -10px var(--ring)}.btn-primary:hover{filter:brightness(1.03)}.section{padding:48px 0}.h2{font-size:28px;margin:0 0 8px}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.card{background:var(--card);border:1px solid #e5e7eb;border-radius:16px;padding:18px;box-shadow:0 10px 30px -20px #0b5cab40}.card h3{margin:0 0 6px}.kpi{display:flex;gap:16px;margin-top:12px}.kpi .pill{padding:6px 10px;border-radius:999px;background:#eef4ff;border:1px solid #dbe3f3;font-weight:700;color:var(--brand-dark)}.footer{background:#0c1a33;color:#dbeafe;padding:36px 16px;margin-top:48px}.footer a{color:#93c5fd}input,button,select{font:inherit}input,select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #dce3ef;background:#fff}input:focus{outline:none;box-shadow:0 0 0 4px var(--ring);border-color:var(--brand)}.form{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form .full{grid-column:1 / -1}.table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;background:#fff}.table th,.table td{padding:12px 14px;border-bottom:1px solid #eef2f7}.table th{text-align:left;background:#f8fbff}.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#ecfdf5;color:#065f46;font-weight:700;border:1px solid #a7f3d0}.note{padding:12px;border-radius:12px;background:#fffbeb;border:1px solid #fde68a}.small{font-size:13px}@keyframes floatUp{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulseGlow{0%,to{box-shadow:0 20px 60px -25px #0b5cab59}50%{box-shadow:0 30px 80px -30px #0b5cab80}}.reveal{opacity:0;transform:translateY(18px);transition:all .7s cubic-bezier(.2,.8,.2,1)}.reveal.in{opacity:1;transform:none}.hero-visual{position:relative;border-radius:20px;background:radial-gradient(1200px 600px at 10% -10%,#dbeafe,#dbeafe00 60%),radial-gradient(1000px 600px at 110% 20%,#e0e7ff,#e0e7ff00 55%),linear-gradient(180deg,#fff,#eef5ff);overflow:hidden;padding:36px;border:1px solid #e5e7eb}.hero-visual .bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;filter:saturate(1.05) contrast(1.02) brightness(.95);opacity:.28}.hero-visual .glass{position:relative;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:18px;padding:28px;border:1px solid rgba(255,255,255,.5);background:linear-gradient(180deg,#ffffffa6,#ffffff59);animation:floatUp .8s ease-out both}.hero-cta .btn-primary{animation:pulseGlow 4s ease-in-out infinite}.brand-strip{display:flex;gap:18px;flex-wrap:wrap;align-items:center;opacity:.85;margin-top:14px}.brand-strip img{height:28px;filter:grayscale(100%);opacity:.7}.brand-strip img:hover{opacity:1;filter:none}.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}.tile{grid-column:span 6;position:relative;border-radius:14px;overflow:hidden;background:#eef2ff;border:1px solid #e5e7eb}.tile img{width:100%;height:100%;object-fit:cover;display:block}.ratio-16x10{aspect-ratio:16 / 10}.ratio-4x5{aspect-ratio:4 / 5}.ratio-21x9{aspect-ratio:21 / 9}@media (max-width: 900px){.tile{grid-column:span 12}}.tile img{opacity:0;transition:opacity .4s ease}.tile img.loaded{opacity:1}.provider-strip{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:16px}.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;font-weight:800;border:1px solid #dbe3f3;background:#fff;color:var(--brand-dark)}.chip img{height:16px;width:16px;display:block;filter:grayscale(100%);opacity:.85}.chip:hover img{filter:none;opacity:1}.webinar{padding:48px 0}.webinar .band{background:linear-gradient(180deg,#fff,#eef5ff);border:1px solid #e5e7eb;border-radius:20px;padding:20px}.webinar .hgroup{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-weight:800;border:1px solid #dbe3f3;background:#fff;color:var(--brand-dark)}.sessions{display:grid;gap:16px;margin-top:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.session{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px}.session h3{margin:0 0 4px}.roles{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.badge-line{display:inline-block;padding:4px 10px;border-radius:999px;background:#eef4ff;border:1px solid #dbe3f3;font-weight:700}.speakers{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}.speaker{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid #eef2f7;border-radius:12px;background:#fafcff}.avatar{width:42px;height:42px;border-radius:999px;object-fit:cover;background:#e5e7eb;border:1px solid #dbe3f3}.mod{background:#fffbeb;border-color:#fde68a}@media (max-width: 900px){.sessions,.speakers{grid-template-columns:1fr}}.date-chip{display:inline-block;padding:10px 14px;border-radius:14px;background:#eef4ff;border:1px solid #dbe3f3;font-weight:800}.session{box-shadow:0 12px 30px -20px #0c204d2e}.speaker{background:#fff}.speaker.mod{background:#fffdf4}.webinar .hgroup h2{margin:0}.speaker{align-items:flex-start}.speaker .text{flex:1;min-width:0}.speaker .label-badge{float:none;display:inline-flex;align-self:flex-start;margin:0 0 6px;font-size:11px;padding:3px 8px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#0b1b3a}.speaker.mod .label-badge{background:#fff7d6;border-color:#f8e08a}.speaker .headline{font-weight:800;font-size:14px;line-height:1.25;margin:0 0 1px}.speaker .meta{font-size:12px;line-height:1.35;color:var(--muted);margin:0 0 6px}.speaker .topic{font-size:12px;line-height:1.35}.role-line{font-size:12px;color:var(--muted);margin:0 0 2px}.company-line{font-size:12px;color:var(--muted);margin:0 0 6px}.filters{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 16px}.input{padding:10px 12px;border:1px solid #dce3ef;border-radius:12px;background:#fff;min-width:220px}.select{padding:10px 12px;border:1px solid #dce3ef;border-radius:12px;background:#fff}.prog-grid{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 1000px){.prog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 680px){.prog-grid{grid-template-columns:1fr}}.prog-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 10px 30px -20px #0b5cab33;display:flex;flex-direction:column;gap:8px}.prog-head{display:flex;align-items:center;gap:10px}.prog-icon{width:40px;height:40px;border-radius:10px;background:#eef4ff;display:flex;align-items:center;justify-content:center;font-weight:900;color:#0b5cab}.prog-title{margin:0;font-size:18px;line-height:1.25}.prog-meta{color:var(--muted);font-size:13px}.prog-tags{display:flex;gap:8px;flex-wrap:wrap}.tag-pill{padding:4px 10px;border-radius:999px;border:1px solid #dbe3f3;background:#f8fbff;font-weight:700;font-size:12px}.prog-foot{display:flex;gap:10px;align-items:center;margin-top:auto}.deadline{padding:6px 10px;border-radius:10px;background:#fffbeb;border:1px solid #fde68a;font-weight:800;font-size:12px}.wizard{display:grid;gap:14px}.step-tabs{display:flex;gap:8px;flex-wrap:wrap}.step-tabs .pill{padding:8px 12px;border-radius:12px;font-weight:800;border:1px solid #dbe3f3;background:#fff;cursor:pointer}.step-tabs .pill.active{background:var(--brand);color:#fff;border-color:var(--brand)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row .full{grid-column:1 / -1}.msg-ok{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:10px 12px;border-radius:12px;font-weight:700}.msg-err{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:10px 12px;border-radius:12px;font-weight:700}.success-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px;text-align:center;box-shadow:0 10px 30px -20px #0b5cab33}@media (max-width: 900px){.form-row{grid-template-columns:1fr}}.mat-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:6px 0 14px}.mat-toolbar .input{min-width:260px}.mat-grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width:1000px){.mat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:680px){.mat-grid{grid-template-columns:1fr}}.res-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;box-shadow:0 10px 30px -20px #0b5cab24}.res-icon{width:44px;height:44px;display:grid;place-items:center;border:1px solid #e6ebf5;border-radius:12px;background:#f7fbff;font-weight:900;color:#0b5cab}.res-title{margin:0;font-size:16px;line-height:1.3}.res-meta{font-size:12px;color:var(--muted)}.res-tags{display:flex;gap:8px;flex-wrap:wrap}.res-pill{padding:4px 10px;border-radius:999px;border:1px solid #dbe3f3;background:#f8fbff;font-weight:700;font-size:12px}.res-actions{display:flex;gap:8px;justify-content:flex-end;grid-column:1 / -1}.uploader{background:#fff;border:1px dashed #cdd6ea;border-radius:14px;padding:12px;display:flex;gap:10px;align-items:center}.note-warn{background:#fffbeb;border:1px solid #fde68a;color:#7a5800;padding:8px 10px;border-radius:10px;font-weight:700}.web-hero{border:1px solid #e5e7eb;border-radius:20px;padding:24px;background:linear-gradient(180deg,#fff,#eef5ff)}.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 14px}.admin-tabs .pill{padding:8px 12px;border:1px solid #dbe3f3;border-radius:12px;background:#fff;font-weight:800;cursor:pointer}.admin-tabs .pill.active{background:var(--brand);color:#fff;border-color:var(--brand)}.kpis{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width:1000px){.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:600px){.kpis{grid-template-columns:1fr}}.kpi{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;box-shadow:0 10px 30px -20px #0b5cab24}.kpi .label{color:var(--muted);font-size:12px}.kpi .value{font-size:24px;font-weight:900}.table{width:100%;border-collapse:separate;border-spacing:0 8px}.th,.td{text-align:left;padding:10px 12px;background:#fff;border:1px solid #e5e7eb}.tr .td:first-child,.tr .th:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}.tr .td:last-child,.tr .th:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}.formline{display:grid;grid-template-columns:1fr 1fr;gap:10px}.formline .full{grid-column:1 / -1}.smallmuted{font-size:12px;color:var(--muted)}.badge-ok{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:4px 8px;border-radius:999px;font-weight:800;font-size:12px}.badge-warn{background:#fffbeb;border:1px solid #fde68a;color:#7a5800;padding:4px 8px;border-radius:999px;font-weight:800;font-size:12px}.badge-danger{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:4px 8px;border-radius:999px;font-weight:800;font-size:12px}.nav-links-inline{display:flex;gap:24px;align-items:center}.nav-menu-toggle{display:none;border:none;background:#111827;color:#fff;border-radius:999px;padding:6px 10px;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:3px}.nav-menu-bar{width:18px;height:2px;background:#fff;border-radius:999px}.nav-menu-dropdown{position:absolute;right:12px;top:56px;background:#fff;border-radius:8px;box-shadow:0 10px 25px #0f172a2e;padding:8px 0;display:flex;flex-direction:column;min-width:180px;z-index:20}.nav-menu-dropdown a{padding:8px 16px;text-decoration:none;color:#111827;font-size:14px}.nav-menu-dropdown a:hover{background:#f3f4f6}@media (max-width: 768px){html,body{width:100%;overflow-x:hidden}.nav-inner,.container,.hero-visual,.footer .container{max-width:100%;width:100%;margin:0;padding-left:16px;padding-right:16px}.section{max-width:100%;width:100%}.nav-links-inline{display:none}.nav-menu-toggle{display:flex;margin-left:auto}}.footer{margin-top:40px;padding:24px 0;background:#7a5800}.footer .small{font-size:.9rem;color:#fff}.social-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.social-links a{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;background:#7d8189;font-size:.85rem;text-decoration:none;color:#111827}.social-links a:hover{background:#1d4ed8;color:#fff}@media (max-width: 768px){.footer .container{grid-template-columns:1fr}}.social-links{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:4px}.social-links a{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;text-decoration:none;color:inherit;padding:6px 12px;border-radius:999px;background:#0f172a4d}.social-links a:hover{text-decoration:underline}@media (max-width: 768px){.social-links{justify-content:flex-start}.social-links a{flex:0 0 calc(50% - 8px);justify-content:center}}@media print{.nav,.footer,.no-print{display:none!important}body{background:#fff}.container.section{padding-top:16px}}.cert-id{font-size:12px;text-align:center;margin-top:16px;color:#555}.auth-page{max-width:200px;margin:0 auto;padding:2.5rem 1.5rem 4rem}.auth-card{background:#fff;border-radius:18px;padding:1.75rem 1.5rem;box-shadow:0 18px 40px #0f172a14}.auth-title{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.auth-subtitle{color:#6b7280;font-size:.95rem;margin-bottom:1.5rem}.instructor-login-page{min-height:calc(100vh - 80px);padding:40px 16px 64px;display:flex;align-items:flex-start;justify-content:center;background:#f3f4f6}@media (min-width: 768px){.instructor-login-page{align-items:center}}.instructor-login-page .auth-card{width:100%;max-width:640px;background:#fff;border-radius:20px;padding:28px 24px 20px;box-shadow:0 18px 45px #0f172a14}.auth-header .auth-label{display:inline-block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#1d3a8a}.auth-header h1{margin:14px 0 6px;font-size:26px;font-weight:700;color:#111827}.auth-header .auth-subtitle{font-size:14px;color:#4b5563;max-width:540px}.auth-form .form-group label{display:block;font-size:14px;font-weight:500;margin-bottom:4px;color:#111827}.auth-form .form-group input{width:100%;border-radius:10px;border:1px solid #d1d5db;padding:10px 12px;font-size:15px;outline:none;background:#f9fafb}.auth-form .form-group input:focus{border-color:#2563eb;background:#fff;box-shadow:0 0 0 1px #2563eb40}.auth-submit{width:100%;margin-top:18px}.auth-alert{margin-top:16px;margin-bottom:12px;padding:10px 12px;border-radius:10px;font-size:14px}.auth-alert-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.auth-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;font-size:14px}.auth-footer .link{color:#2563eb;text-decoration:none}.auth-footer .link:hover{text-decoration:underline}@media print{body{-webkit-print-color-adjust:exact;print-color-adjust:exact}.cert-bg{background:#e5e7eb!important}.cert-card{background:#ffffff29!important;box-shadow:none}.no-print{display:none!important}}
