
:root{
  --navy:#0f2747;
  --blue:#2563eb;
  --gold:#f59e0b;
  --red:#cf2e2e;
  --bg:#f6f8fc;
  --white:#ffffff;
  --text:#172033;
  --muted:#5c687d;
  --line:#dbe4f1;
  --success:#157347;
  --warn:#b26a00;
  --shadow:0 18px 45px rgba(15,39,71,.09);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.55}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.topbar{background:var(--navy);color:#fff;font-size:14px}
.topbar .container{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 20px}
.navbar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.navbar .container{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:14px 20px}
.brand{display:flex;align-items:center;gap:14px;font-weight:800}
.brand img{width:58px;height:58px;border-radius:16px;object-fit:cover;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.brand small{display:block;font-weight:600;color:var(--muted)}
.nav-links{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.nav-links a{font-weight:700;color:var(--muted)}
.nav-links a:hover{color:var(--navy)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:14px;border:1px solid transparent;font-weight:800;cursor:pointer}
.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:#1d4fd1}
.btn-secondary{background:#fff;color:var(--navy);border-color:var(--line)}.btn-secondary:hover{background:#eff5ff}
.btn-gold{background:var(--gold);color:#1d2433}
.hero{padding:72px 0 36px;background:linear-gradient(180deg,#f8fbff 0%, #e9f1ff 100%)}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:28px;align-items:center}
.eyebrow{display:inline-block;padding:8px 12px;border-radius:999px;background:#e8f0ff;color:var(--blue);font-size:13px;font-weight:800;margin-bottom:14px}
.hero h1{font-size:52px;line-height:1.08;margin:0 0 16px}
.hero p{font-size:18px;color:var(--muted)}
.card,.hero-card{background:var(--white);border:1px solid #eaf0f8;border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-card{padding:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.kpi{background:#f9fbff;border:1px solid var(--line);padding:16px;border-radius:18px}
.kpi strong{display:block;font-size:24px}
.section{padding:64px 0}.section h2{font-size:34px;margin:0 0 12px}.lead{color:var(--muted);max-width:820px}
.course-card,.feature-card,.contact-card,.faq-card{padding:24px}
.badge{display:inline-block;padding:7px 10px;border-radius:999px;background:#eef3ff;color:var(--blue);font-size:12px;font-weight:800}
.price{font-size:28px;font-weight:900;color:var(--navy);margin:12px 0 2px}
.meta{color:var(--muted);font-size:14px}
.feature-list,.simple-list{padding-left:18px;color:var(--muted);margin:14px 0 0}
.cta-band{display:flex;justify-content:space-between;align-items:center;gap:24px;background:linear-gradient(135deg,var(--navy),#174276);color:#fff;padding:30px;border-radius:28px}
.footer{margin-top:46px;background:var(--navy);color:#fff;padding:36px 0 18px}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:26px}
.footer a{color:#dce9ff}.small{font-size:13px;color:#cbd8ee}
.notice{padding:12px 14px;border-radius:14px;background:#f7f9ff;border:1px solid var(--line);color:var(--muted);font-size:14px}
.center{text-align:center}
.portal-hero{padding:44px 0;background:linear-gradient(180deg,#eef5ff 0%,#f8fbff 100%)}
.portal-layout{display:grid;grid-template-columns:290px 1fr;min-height:calc(100vh - 100px)}
.sidebar{background:#fff;border-right:1px solid var(--line);padding:24px;position:sticky;top:88px;height:calc(100vh - 88px);overflow:auto}
.side-link{display:block;padding:12px 14px;border-radius:14px;color:var(--muted);font-weight:800;margin-bottom:8px}.side-link.active,.side-link:hover{background:#eef4ff;color:var(--blue)}
.portal-main{padding:24px}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
th,td{padding:14px 12px;border-bottom:1px solid #eef2f7;text-align:left;font-size:14px}th{background:#f8fbff}
.status{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800}.status.open{background:#e4efff;color:var(--blue)}.status.locked{background:#fff4e5;color:var(--warn)}.status.done{background:#e8f7ee;color:var(--success)}
.flex{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.hidden{display:none!important}.no-print{}
.transcript{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:26px}.transcript-header{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;border-bottom:2px solid #edf2fb;padding-bottom:16px;margin-bottom:18px}.grade{font-size:34px;font-weight:900;color:var(--navy)}
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0}.summary-grid .kpi{background:#fff}
.login-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}.login-card{padding:24px}.field{margin-bottom:12px}.field label{display:block;font-weight:700;margin-bottom:6px}.input{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);font-size:15px;background:#fff}
.page-hero{padding:44px 0;background:linear-gradient(180deg,#f8fbff 0%, #eef4ff 100%)}
.page-hero h1{font-size:42px;margin:0 0 10px}
@media (max-width:980px){.hero-grid,.grid-3,.grid-2,.footer-grid,.login-grid,.summary-grid{grid-template-columns:1fr}.hero h1{font-size:40px}.portal-layout{grid-template-columns:1fr}.sidebar{position:relative;top:0;height:auto;border-right:none;border-bottom:1px solid var(--line)}}
@media (max-width:700px){.nav-links{display:none}.hero h1{font-size:34px}.kpi-grid{grid-template-columns:1fr}.cta-band{flex-direction:column;align-items:flex-start}}
@media print{.no-print{display:none!important}body{background:#fff}.transcript{box-shadow:none;border:none;padding:0}}


.program-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.program-detail h2{margin:12px 0 8px}
.program-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}
.dashboard-grid{display:grid;grid-template-columns:360px 1fr;gap:22px}
.stack{display:grid;gap:18px}
.label{display:block;font-weight:700;margin-bottom:6px}
.select,.textarea,.input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#fff}
.textarea{min-height:110px;resize:vertical}
.item-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;font-size:13px;font-weight:700}
.pill-lesson{background:#e9f2ff;color:#1d4fd1}
.pill-assignment{background:#fff4df;color:#b26a00}
.pill-quiz{background:#fce8ec;color:#b42318}
.module-block{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff}
.item-row{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--line)}
.item-row:first-of-type{border-top:none;padding-top:0}
.item-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.status-open{color:var(--success);font-weight:800}
.status-locked{color:#b42318;font-weight:800}
.status-complete{color:#0f766e;font-weight:800}
.muted{color:var(--muted)}
.notice{padding:12px 14px;border-radius:14px;background:#eff5ff;border:1px solid #cfe0ff}
.small-btn{padding:9px 12px;border-radius:12px;font-size:14px}
.inline-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
@media (max-width:900px){
  .program-grid,.dashboard-grid{grid-template-columns:1fr}
}


/* prettier programs page */
.page-hero{
  background: radial-gradient(circle at top left, #e8f0ff 0%, #f7f9fc 42%, #ffffff 100%);
  padding: 68px 0 52px;
  border-bottom: 1px solid var(--line);
}
.page-hero .lead{max-width:760px}
.program-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:24px;
}
.program-detail{
  position:relative;
  overflow:hidden;
  border:1px solid #dfe6f1;
  box-shadow:0 18px 40px rgba(13,42,74,.08);
  transition:transform .18s ease, box-shadow .18s ease;
}
.program-detail:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 48px rgba(13,42,74,.12);
}
.program-detail::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:7px;
  background:linear-gradient(90deg,#0b2a4a,#1d4fd1,#7aa5ff);
}
.program-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  flex-wrap:wrap;
}
.program-head h2{
  margin:12px 0 4px;
  font-size:1.45rem;
  line-height:1.2;
}
.program-detail p{
  color:#425466;
  line-height:1.7;
}
.price{
  font-size:1.55rem;
  font-weight:800;
  color:#0b2a4a;
  background:#eef4ff;
  border:1px solid #d8e5ff;
  border-radius:999px;
  padding:10px 16px;
  min-width:max-content;
}
.feature-list{
  display:grid;
  gap:10px;
  padding-left:0;
  list-style:none;
  margin:18px 0 0;
}
.feature-list li{
  position:relative;
  padding-left:28px;
  color:#243b53;
}
.feature-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:#0f766e;
  font-weight:800;
}
.eyebrow{
  display:inline-block;
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#1d4fd1;
  font-weight:800;
  margin-bottom:12px;
}
.flex{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.navbar .btn.btn-primary.portal-cta{display:none}
@media (max-width:760px){
  .program-head{flex-direction:column}
  .price{font-size:1.35rem}
}


.narrow-stack{
  max-width: 860px;
}
.course-section{
  margin-bottom: 22px;
  border: 1px solid #dfe6f1;
  box-shadow: 0 12px 30px rgba(13,42,74,.06);
}
.course-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.course-section h2{
  margin:10px 0 0;
  font-size:1.5rem;
  line-height:1.2;
}
.course-section p{
  color:#425466;
  line-height:1.7;
}
.center-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:28px;
}
@media (max-width:760px){
  .course-top{flex-direction:column}
}


.transcript-card{padding:28px}
.transcript-header{
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  align-items:flex-start;
}
.transcript-summary{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.table-wrap{overflow:auto}
.transcript-table{
  width:100%;
  border-collapse:collapse;
}
.transcript-table th,.transcript-table td{
  padding:12px 10px;
  border-bottom:1px solid var(--line);
  text-align:left;
  vertical-align:top;
}
.transcript-table th{
  background:#f8fbff;
}
.simple-list{
  margin:0;
  padding-left:18px;
}
.simple-list li{
  margin:8px 0;
}


.media-block{margin-top:12px}
.media-image{max-width:100%;border-radius:14px;border:1px solid var(--line)}
.media-video{width:100%;max-height:420px;border-radius:14px}
.transcript-card{padding:28px}
.transcript-header{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:flex-start}
.transcript-summary{display:flex;gap:10px;flex-wrap:wrap}
.table-wrap{overflow:auto}
.transcript-table{width:100%;border-collapse:collapse}
.transcript-table th,.transcript-table td{padding:12px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.transcript-table th{background:#f8fbff}


.builder-panel{background:#f8fbff;border:1px dashed #c8d8ef;border-radius:18px;padding:14px;margin:14px 0}
.builder-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.xs-btn{padding:6px 10px;font-size:12px;border-radius:10px}
.course-builder-item.dragging{opacity:.55}
.slim-input{max-width:110px}
.quiz-panel{margin-top:14px;padding:14px;border:1px solid var(--line);border-radius:14px;background:#fbfcff}
.quiz-question{font-weight:700;margin-bottom:10px}
.quiz-choice{display:block;margin:8px 0}
.certificate-card{background:linear-gradient(180deg,#fff,#f9fbff);border:10px solid #0b2a4a;border-radius:22px;padding:20px;box-shadow:0 18px 40px rgba(13,42,74,.12)}
.certificate-inner{min-height:520px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:24px}
.certificate-title{font-size:2.5rem;font-weight:800;color:#0b2a4a;margin-bottom:18px}
.certificate-school{font-size:1.2rem;font-weight:700;margin-bottom:18px}
.certificate-text{font-size:1.05rem;color:#425466;margin:10px 0}
.certificate-name{font-size:2rem;font-weight:800;margin:12px 0;color:#1d4fd1}
.certificate-course{font-size:1.3rem;font-weight:700;margin:12px 0}
.certificate-date{margin-top:30px;color:#425466}


#autoQuizResults .module-block{background:#fbfdff}


.checkbox-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:10px 0 14px;
}
.checkbox-grid label{
  display:flex;
  align-items:center;
  gap:8px;
}
@media (max-width:700px){
  .checkbox-grid{grid-template-columns:1fr}
}


.checkbox-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:10px 0 14px;
}
.checkbox-grid label{
  display:flex;
  align-items:center;
  gap:8px;
}
@media (max-width:700px){
  .checkbox-grid{grid-template-columns:1fr}
}


.badge-success{background:#e7f7ef;color:#067647;border:1px solid #abefc6}
.badge-warning{background:#fff7e8;color:#b26a00;border:1px solid #fedf89}


.badge-success{background:#e7f7ef;color:#067647;border:1px solid #abefc6}
.badge-warning{background:#fff7e8;color:#b26a00;border:1px solid #fedf89}


.quiz-launcher{margin-top:14px;padding:16px;border:1px solid var(--line);border-radius:16px;background:#f8fbff}
.quiz-collapsible{display:none;margin-top:14px}
.quiz-collapsible.open{display:block}
.quiz-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.quiz-summary-text{font-weight:700;color:var(--navy)}
.course-focus-banner{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap;padding:4px 0}
.course-focus-stats{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.quiz-draft-toolbar{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.quiz-count-badge{background:#e8f0ff;color:var(--blue);border:1px solid #cfe0ff}
.current-course-badge{background:#eef8ee;color:#157347;border:1px solid #b6e0c3}
@media (max-width:700px){
  .course-focus-banner{flex-direction:column}
}
