/* ==========================================================================
   VALSTR — Global Styles + Page Structure + Caspio Bridge Skin (Responsive)
   ========================================================================== */

/* ========== Theme Tokens ========== */
:root{
  --bg: #f7f8fc;
  --panel: #ffffff;
  --ink: #0b1426;
  --muted: #6a7280;
  --primary: #0b117a;
  --primary-600: #1d2cf3;
  --accent: #2b6bff;
  --ring: #e7e9f2;
  --tile: #eaf2ff;
  --radius: 16px;
  --shadow: 0 6px 24px rgba(16,24,40,.08);
}

/* Reset + Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif !important;
  color:var(--ink);
  background:var(--bg);
}

.flex-col-center {
	display: flex;
	width: 100%;
	flex-direction: column;
	align-items: center;       /* horizontal center */
	height: 100%;  
	padding-top: 15px;
}


.embed-box * {
	font-family: Poppins !important;
}

/* ========== Utilities ========== */
.hidden{display:none !important;}
.center{text-align:center}
.muted{color:var(--muted)}
.small{font-size:.92rem}
.w-full{width:100%}
.rounded{border-radius:var(--radius)}
.shadow{box-shadow:var(--shadow)}
.ring{border:1px solid var(--ring)}
.grid{display:grid}
.gap-sm{gap:10px}
.gap-md{gap:16px}
.gap-lg{gap:20px}
.gap-xl{gap:28px}


/* ========== Cards ========== */

.flex-col{display:flex;}

.card{
  background:var(--panel);
  border:1px solid var(--ring);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
}
.card-title{margin:0 0 12px;font-size:22px;font-weight:700}

.card-col{
  background:var(--panel);
  border:1px solid var(--ring);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  min-width: 280px;
  flex-grow: 1;
  display: flex;
  transition: 0.15s linear all;
  flex-direction: column;
  } 
  
  .card-description {
  background:var(--panel);
  border:1px solid var(--ring);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  min-width: 280px;
  flex-grow: 1;
  display: flex;
  transition: 0.15s linear all;
  flex-direction: column;
  } 
  
  .card-divider{
  background:#f5faff;
  border:1px solid var(--ring);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:8px;
  height: 100%;
  max-width: 100px;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  opacity: 0.6;
  cursor: pointer;
  transition: 0.3s;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  }
  
  .small-col { 
	max-width: 30%;
	opacity: 0.6;
  }
  
  .card-divider:hover {
	  opacity: 1;
  }
  
  .divider-text {
	  color: #bdd3f8;
	  font-size: 15px;
	  text-align: center;
	  line-height: 22px;
  }
  
  .divider-arrow {
	  font-size: 50px;
	  color: #bdd3f8;
	  text-align: center;

  }
  
  .divider-content {
	display: flex;
	flex-direction: column;
	justify-content: space-evenly;
	height: 100%;
  }
  
  #large-left {
  }
  
  #large-right {
  }
  
  #large-left {
  transition: opacity 250ms ease, transform 350ms ease, visibility 0s linear 250ms;
}
	#large-left.is-hidden {
	  opacity: 0;
	  transform: translateX(-8px);
	  visibility: hidden;           /* delayed via transition above */
	  transition: opacity 250ms ease, transform 350ms ease, visibility 0s;
	}
  


/* ========== Buttons ========== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 16px;border-radius:14px;border:0;cursor:pointer;font-weight:800;}
.btn-primary{background:linear-gradient(180deg,#1e2cff,#0d2cff);color:#fff;box-shadow:0 10px 26px rgba(13,44,255,.35);}
.btn-primary:hover{filter:brightness(1.05);}
.btn-ghost{background:#eef3ff;color:var(--ink);border:1px solid var(--ring);}
.btn-ghost:hover{background:#e6edff;}

/* ========== Inputs ========== */
.input,input,select,textarea{
  width:100%;padding:12px;border:1px solid var(--ring);border-radius:12px;background:#fbfcff;
  font-size:1rem;outline:none;transition:box-shadow .15s,border-color .15s;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 4px rgba(43,107,255,.18);background:#fff;
}

/* ==========================================================================
   Page Structure
   ========================================================================== */

/* Sidebar */
.sidebar{
  position:fixed;inset:0 auto 0 0;width:250px;background:#0a0f3e;color:#eaf0ff;
  display:flex;flex-direction:column;padding:20px 16px;
  transform:translateX(0);transition:transform .25s ease;z-index:50;
}
.brand{display:flex;align-items:center;gap:10px;padding:6px 10px 18px;border-bottom:1px solid rgba(255,255,255,.08);}
.brand-mark{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#66a6ff,#1e2cff);}
.brand-name{font-weight:800;letter-spacing:.5px;}
.side-nav{margin-top:16px;display:grid;gap:8px;}
.side-link{display:grid;grid-template-columns:28px 1fr;align-items:center;gap:12px;padding:12px 10px;border-radius:12px;color:#eaf0ff;text-decoration:none;font-weight:600;}
.side-link:hover{background:rgba(255,255,255,.06);}
.side-link.active{background:rgba(255,255,255,.12);}
.side-footer{margin-top:auto;display:flex;gap:10px;padding:8px 6px;}
.bubble{width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:#fff;cursor:pointer;}

/* Shell */
.shell{margin-left:250px;min-height:100%;display:flex;flex-direction:column;}

/* Topbar */
.topbar{height:64px;background:#050a33;color:white;display:flex;align-items:center;justify-content:space-between;padding:0 18px;position:sticky;top:0;z-index:40;}
.nav-toggle{display:none;border:0;background:transparent;color:#fff;font-size:24px;}
.top-actions{display:flex;align-items:center;gap:12px;}
.top-icon{width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.1);color:#fff;position:relative;}
.badge{position:absolute;right:-6px;top:-6px;background:#ff3b30;color:#fff;font-size:10px;border-radius:999px;padding:2px 6px;font-weight:700;}
.avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.35);}
.avatar img{width:100%;height:100%;object-fit:cover;display:block;}

/* Logo */
.logo{
  height:auto;
  width:100%;
  display:block;
  filter: drop-shadow(0 4px 16px rgba(0,0,0,.25));
}
/* Content */
.content{padding:20px;display:grid;gap:24px;}

/* Hero */
.hero{position:relative;height:220px;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);}
.hero-img{width:100%;height:100%;object-fit:cover;filter:brightness(.65);}
.hero-greeting{position:absolute;inset:0;display:grid;place-items:center;text-align:center;}
.hero h1{color:#fff;font-size:clamp(28px,3.2vw,44px)!important;margin:0;font-weight:800!important;}
.highlight{color:#cfe4ff;}

/* Section Head */
.section-head{display:flex;align-items:center;gap:10px;}
.section-head h2{margin:0;font-size:20px;}

/* ==========================================================================
   Embed Containers
   ========================================================================== */
.embed-box{
  border:2px dashed var(--ring);
  border-radius:14px;
  min-height:200px;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  height: 100%;
  align-items: flex-start;
}

.grid-container {
	display: flex;
	flex-wrap: wrap;
}

.comms-container {
	display: flex;
	flex-wrap: wrap;
}

.width-49 {
	max-width: 49% !important;
	background: #ededef;
}

.grid-box {
	background: #fff;
	flex-direction: column;
	flex: 1 0 49%;
	margin: 5px;
	max-width: 48%;
	min-height: 130px;
	min-width: 150px;
	padding: 10px;
	display: flex;
	border-radius: 8px;
	overflow: hidden;
	justify-content: space-between;
}

.grid-title {
	font-size: 21px;
	color: #0b1426;
	align-self: flex-start;
	font-weight: 800;
	line-height: 19px;
}

.grid-stat {
	font-size: 40px;
	color: #2b6bff;
	align-self: flex-end;
	font-weight: 800;
	line-height: 30px;
}

.home-col {
	background: #fff;
	flex-direction: column;
	flex: 1 0 24%;
	margin: 5px;
	max-width: 23%;
	min-width: 100px;
	padding: 10px;
	display: flex;
	border-radius: 8px;
	overflow: hidden;
	justify-content: space-between;
}

/* ==========================================================================
   Caspio Bridge Skin
   ========================================================================== */
.cbFormTable{width:100%;}
.cbFormLabelCell{padding:8px 10px;color:var(--muted);font-weight:600;}
.cbFormDataCell{padding:8px 10px;}
input.cbTextbox,textarea.cbTextarea,select.cbSelect{composes: input;}
input.cbSubmitButton,button.cbSubmitButton,a.cbButton{composes: btn-primary;}
a.cbButton.secondary,button.cbButton.secondary{composes: btn-ghost;}
.cbError{color:#9f1239;background:#fff1f2;border:1px solid #fecdd3;padding:8px 10px;border-radius:10px;margin-top:6px;}
.cbResultSetTable{width:100%;border-collapse:separate;border-spacing:0;background:var(--panel);border:1px solid var(--ring);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);}
.cbResultSetTable th{background:#f3f6ff;padding:12px;font-weight:700;color:var(--ink);}
.cbResultSetTable td{padding:12px;border-top:1px solid var(--ring);}
.cbResultSetTable tr:hover{background:#f7faff;}
.cbPager{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;}
.cbPager a,.cbPager span{padding:8px 12px;border:1px solid var(--ring);border-radius:10px;text-decoration:none;color:var(--ink);}
.cbPager .cbCurrentPage{background:#eef3ff;font-weight:700;}
.cbChart{background:var(--panel);border:1px solid var(--ring);border-radius:14px;box-shadow:var(--shadow);padding:14px;}

/* ==========================================================================
   Responsive Breakpoints
   ========================================================================== */

/* Large tablets / smaller desktops */
@media (max-width:1200px){
  .content{padding:16px}
}

/* Tablets */
@media (max-width:980px){
  .shell{margin-left:0}
  .nav-toggle{display:inline-flex}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .hero{height:200px}
}

/* Mobile */
@media (max-width:720px){
  .content{padding:14px}
  .hero{height:160px}
  .section-head h2{font-size:18px}
  .side-link{padding:10px 8px}
  .card{padding:12px}
}

/* ==========================================================================
   Modules (blue buttons in a row)
   ========================================================================== */
.modules{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.module-row{
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.module-btn{
  flex: 0 0 auto; /* don’t stretch, keep natural size */
  min-width: 160px;
  display: grid;
  place-items: center;
  gap: 8px;
  text-align: center;
  padding: 18px 14px;
  border-radius: 20px;
  text-decoration: none;
  background: #0d2cff; /* brand blue */
  flex-grow: 1;
  color: #fff;
  font-weight: 700;
  line-height: 1.2;
  box-shadow: 0 12px 28px rgba(13,44,255,.22);
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
.module-btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(13,44,255,.28);
  filter: brightness(1.05);
}
.module-emoji{ font-size: 32px; }
.module-title{ font-size: .95rem; }

/* ==========================================================================
   Main content: flexible column layout
   ========================================================================== */
.flex-cols{
  display: flex;
  flex-wrap: wrap;              /* allows columns to wrap on smaller screens */
  gap: 16px;                    /* matches your spacing scale */
  align-items: stretch;
}

/* Generic column: grows, but won’t get narrower than 280px */
.col{
  flex: 1 1 320px;              /* grow | shrink | preferred width */
  min-width: 280px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Optional fixed-width columns (use as needed) */
.col-fixed-280{ flex: 0 0 280px; }
.col-fixed-320{ flex: 0 0 320px; }
.col-fixed-360{ flex: 0 0 360px; }
.col-fixed-400{ flex: 0 0 400px; }


/* Make a column sticky (e.g., filters/nav) under the 64px topbar */
.col-sticky{ position: sticky; top: 88px; }

/* Column items often are cards; these keep a consistent look */
.col .card{ padding: 16px; }

/* Responsive tweaks */
@media (max-width: 980px){
  .flex-cols{ gap: 14px; }
  /* Columns naturally wrap; no extra rules required */
}
@media (max-width: 720px){
  .flex-cols{ gap: 12px; }
  .col{ min-width: 100%; }      /* stack to a single column on narrow screens */
}


/* ==========================================================================
   Progress Tracker / Flow Chart
   ========================================================================== */
:root{
  --circle: 36px;
  --track: 3px;
  --gap: 12px;
}

/* layout */
.progress-tracker{
  display: flex;
  align-items: center;
  gap: var(--gap);
  margin: 20px 0;
  padding: 20px;
  background: var(--panel);
  border: 1px solid var(--ring);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

/* steps */
.progress-step{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-width: 0;
}

.progress-circle{
  width: var(--circle);
  height: var(--circle);
  border-radius: 50%;
  background: var(--ring);
  color: var(--ink);
  display: grid;
  place-items: center;
  font-weight: 700;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}

.progress-label{
  margin-top: 8px;
  font-size: .95rem;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.2;
  max-width: 16ch;
  text-wrap: balance;
}

/* connectors between steps (the rail pieces) */
.progress-connector{
  flex: 1 1 auto;          /* this makes the line stretch between circles */
  height: var(--track);
  background: var(--ring);
  border-radius: 999px;
  align-self: center;       /* aligns with circle center line */
}

/* states */
.progress-step.completed .progress-circle{ background: var(--accent); color:#fff; }
.progress-step.active .progress-circle{
  background: var(--primary-600);
  color:#fff;
  box-shadow: 0 0 0 4px rgba(43,107,255,.2);
  transform: scale(1.04);
}
.progress-step.completed .progress-label{ color: var(--accent); }
.progress-step.active .progress-label{ color: var(--primary-600); }

.progress-connector.completed{ background: var(--accent); }

/* stack on narrow screens */
@media (max-width: 720px){
  .progress-tracker{
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .progress-connector{ display: none; }
  .progress-step{
    flex-direction: row;
    align-items: center;
    gap: 12px;
    text-align: left;
  }
  .progress-label{ margin-top: 0; max-width: none; }
}
/* ==========================================================================
   Right-aligned Button Menu
   ========================================================================== */
.button-menu{
  display: flex;
  justify-content: flex-end;  /* push buttons to the right */
  gap: 16px;
  margin: 20px 0;
  flex-wrap: wrap;             /* allows wrap on smaller screens */
}

.button-menu .btn-wide{
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 200px;
  padding: 16px 24px;
  font-size: 1.05rem;
  font-weight: 800;
  border-radius: 14px;
  border: 0;
  color: #fff;
  background: var(--accent);
  box-shadow: 0 10px 26px rgba(13,44,255,.35);
  cursor: pointer;
  text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

.button-menu .btn-wide:hover{
  transform: translateY(-2px);
  box-shadow: 0px 4px 26px rgba(13, 44, 255, .35);
  filter: brightness(1.05);
}

.button-menu .btn-help{
  background: #0b117a; /* darker variant for Help */
}

.button-menu .btn-output{
  background: #fcb363; /* darker variant for Help */
}

.button-menu .btn-prev{
  background: #6390f7; /* darker variant for Help */
}

/* Mobile: stack buttons full width */
@media (max-width: 720px){
  .button-menu{
    justify-content: center;
  }
  .button-menu .btn-wide{
    flex: 1 1 100%;
    min-width: unset;
  }
}

/* RAG TABLE */

.rag-table {
	max-width: 400px;
	margin: 10px;
	font-style: normal;
}

.rag-row {
  display: flex;
  border: 1px solid #262626;
  margin-bottom: 8px;
  border-radius: 4px;
  overflow: hidden;
}

.rag-number {
  font-weight: bold;
  padding: 12px 20px;
  min-width: 60px;
  text-align: center;
  color: black;
}

/* Levels with RAG colors */
.level-1 {
  background-color: #e53935; /* red */
}

.level-2 {
  background-color: #fb8c00; /* orange */
}

.level-3 {
  background-color: #fdd835; /* yellow */
}

.level-4 {
  background-color: #43a047; /* light green */
}

.level-5 {
  background-color: #2e7d32; /* dark green */
}

.rag-text {
  padding: 12px;
  flex: 1;
  color: black;
}

/* CUSTOM EMBEDS */

.cbResultSetModifyButton {
	background: #2b6bff !important;
	border-radius: 4px !important;
	text-transform: capitalize !important;
	border: 0 !important;
	width: auto !important;
}
	
.cbResultSetCancelButton {
	background: #d60000 !important;
	border-radius: 4px !important;
	text-transform: capitalize !important;
	border: 0 !important;
	width: auto !important;
	color: #fff !important;
}
	

.ST21326CA4C55A42449672C137A699553E {
width: 100%;
padding: 10px;
}

.cbResultSetData {
	font-family: Poppins !important;
	font-size: 16px !important;
}

.cbResultSetTable {
	border-radius: 5px !important;
	background: #e8e6f1 !important;
	border: 1px solid #262626 !important;
}

.cbResultSetGroup1Label {
	font-size: 18px !important;
}

.cbResultSetLabelLink {
	font-size: 18px !important;
	font-weight: bold !important;
}

.cbResultSetHeaderCell {
	background: var(--accent) !important;
}

.cbResultSetLabel {
	font-family: Poppins !important;
	font-size: 16px !important;
}

.cbUpdateButton, .cbSearchButton, .cbSubmitButton {
	display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 200px !important;
  padding: 16px 24px !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  font-family: Poppins !important;
  border-radius: 14px !important;
  border: 0 !important;
  color: #fff !important;
  background: var(--accent) !important;
  box-shadow: 0 10px 26px rgba(13,44,255,.35) !important;
  cursor: pointer !important; 
  text-decoration: none !important;
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease !important;
  text-transform: none !important;
  height: 58px !important;
}

.cbUpdateButton:hover, .cbSearchButton:hover, .cbSubmitButton:hover{
  transform: translateY(-2px);
  box-shadow: 0px 4px 26px rgba(13, 44, 255, .35);
  filter: brightness(1.05);
}

.cbFormTextField {
	min-width: 250px;
}
	
/* CHECKBOXES */

:root {
  --form-control-color: green;
  --form-control-disabled: #959495;
}

input[type="checkbox"] {
  /* Add if not using autoprefixer */
  -webkit-appearance: none;
  /* Remove most all native input styles */
  appearance: none;
  /* For iOS < 15 */
  background-color: var(--form-background);
  /* Not removed via appearance */
  margin: 0;

  font: inherit;
  color: currentColor;
  width: 1em;
  height: 1em;
  border: 0.15em solid currentColor;
  border-radius: 0.15em;
  transform: translateY(-0.075em);

  display: inline-grid;
  place-content: center;
}

input[type="checkbox"]::before {
  content: "";
  width: 1em;
  height: 1em;
  clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
  transform: scale(0);
  transform-origin: bottom left;
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1em 1em var(--form-control-color);
  /* Windows High Contrast Mode */
  background-color: CanvasText;
}

input[type="checkbox"]:checked::before {
  transform: scale(1);
}

input[type="checkbox"]:focus {
  outline: max(2px, 0.15em) solid currentColor;
  outline-offset: max(2px, 0.15em);
}

input[type="checkbox"]:disabled {
  --form-control-color: var(--form-control-disabled);

  color: var(--form-control-disabled);
  cursor: not-allowed;
}


.cbFormFieldCell > .GoalsFormLimit:nth-child(n+17) {
  display: none !important;
}

.GoalsFormLimit > span {
	font-size: 16px !important;
}

.GoalsFormLimit > span > label {
	padding-left: 5px !important;
}

.Dialog, .Window, #Alert {
	background: var(--panel) !important;
    border: 1px solid var(--ring) !important;
    border-radius: 5px !important;
    box-shadow: var(--shadow) !important;
    padding: 16px !important;
    min-width: 280px !important;
	overflow: hidden !important;
	font-family: Poppins !important;
}

.Title {
	background-color: #2b6bff !important;
	border-bottom: 0 !important;
	
}

.TitleText {
	font-size: 18px !important;
	font-weight: bold !important;
	color: #fff !important;
}

.ClsBtn {
	background: transparent !important;
}

.cbBulkFormData {
	font-family: Poppins !important;
	font-size: 14px !important;
}

.ButtonsCtnr {
	background: transparent !important;
	border-top: 0 !important;
	text-align: center !important;
	display: flex;
}

.SimpleButton {
	display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 4px 8px !important;
	font-family: Poppins !important;
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    border-radius: 6px !important;
    border: 0 !important;
    color: #fff !important;
    background: #6390f7 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: transform .12s ease, box-shadow .12s ease, filter .12s ease !important;
	-webkit-text-shadow: none !important;
    text-shadow: none !important;
	flex-grow: 1;
	margin-left: 10px !important;
	margin-right: 10px !important;
}

.ActionButton {
	background: var(--accent) !important;
}


.cbResultSetActionsContainerCellspacing.cbResultSetActionsContainer.cbActionPanel > ul {
       background: #2b6bff !important;
       border-radius: 5px;
       padding: 8px;
       }

.cbActionPanel ul li {
       margin-right: 8px !important;
}

.cbResultSetBulkEditActionLink {
       color: #fff !important;
       font-weight: 800 !important; 
       font-size: 15px !important;
}

.cbResultSetBulkEditActionLink > img {
       display: none !important;
}

.cbResultSetActionsContainer {
padding-left: 0 !important;
padding-right: 0 !important;
}

.assessment-table {
	display: flex;
	flex-direction: column;
	width: 100%;
	align-items: center;
}

.assessment-table > .module-btn {
	margin-top: 10px;
	margin-bottom: 10px;
	width: 60%;
	display: flex;
	justify-content: space-between;
	
}

.cbResultSetHeaderCellNumberDate, .cbResultSetHeaderCheckBoxCell {
	background: var(--accent) !important;
}

.cbResultSetRecordIndex {
	font-size: 16px !important;
}

.cbResultSetCheckBoxCell {
	border-bottom: 1px solid var(--ring) !important;
}


/* baseline */
.sticky-box {
  position: sticky;
  top: 90px;              /* or e.g. 16px */
  z-index: 1;          /* stay above content */
  background: #fff;    /* avoid see-through when fixed at top */
  /* optional: width: fit-content; or a fixed width if layout shifts */
}

.assessment-title{ 
	font-size: 24px; 
	}