.legalModal{
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease;
}

.legalModal.isOpen,
.legalModal.isClosing{
  pointer-events:auto;
}

.legalModal.isOpen{
  opacity:1;
}

.legalModal .studentModalBackdrop{
  background:rgba(15,23,42,.54);
  backdrop-filter:blur(4px);
  opacity:0;
  transition:opacity .28s ease;
}

.legalModal.isOpen .studentModalBackdrop{
  opacity:1;
}

.legalModal.isClosing .studentModalBackdrop{
  opacity:0;
}

.legalModal.isOpen .legalModalDialog{
  opacity:1;
  transform:translateY(0) scale(1);
}

.legalModal.isClosing .legalModalDialog{
  opacity:0;
  transform:translateY(16px) scale(.985);
}

.legalModalBody{
  padding:18px 18px 20px;
}

.legalModalHero{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:center;
  padding:8px 4px 16px;
}

.legalModalLogo{
  width:68px;
  height:68px;
  object-fit:contain;
  border-radius:18px;
  padding:10px;
  background:linear-gradient(
    180deg,
    color-mix(in srgb, var(--headerBg) 12%, white),
    color-mix(in srgb, var(--headerBg) 4%, white)
  );
  border:1px solid color-mix(in srgb, var(--headerBg) 18%, white);
  box-shadow:0 12px 30px rgba(15,23,42,.10);
}

.legalModalEyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--titleBadgeBorder, rgba(30,86,160,.28));
  background:linear-gradient(180deg, var(--titleBadgeBg1), var(--titleBadgeBg2));
  color:var(--titleBadgeText);
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}

.legalModalHeading{
  margin:0;
  color:var(--headerBg);
  font-size:clamp(22px, 2.3vw, 30px);
  line-height:1.1;
}

.legalModalLead{
  margin:6px 0 0;
  color:color-mix(in srgb, var(--headerBg, #1e56a0) 28%, var(--tableText, #172033) 72%);
  font-size:14px;
  line-height:1.55;
}

.legalModalMetaRow,
.legalModalContentTitleRow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.legalModalMetaRow{
  margin-bottom:16px;
}

.legalMetaPill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:34px;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid var(--statsSoftBorder, #b5caef);
  background:linear-gradient(180deg, var(--statsSoftBg1, #eef4ff), var(--statsSoftBg2, #d8e7ff));
  color:var(--statsSoftText, #315c9a);
  font-size:12px;
  font-weight:700;
}

.legalMetaPill strong{
  font-weight:800;
}

.legalMetaPill.isSoft{
  border-color:var(--statsNeutralBorder, #c8d3e2);
  background:linear-gradient(180deg, var(--statsNeutralBg1, #f4f7fb), var(--statsNeutralBg2, #e7edf6));
  color:var(--statsNeutralText, #1e2b3d);
}

.legalAccordion{
  display:grid;
  gap:12px;
}

.legalAccordionItem{
  border:1px solid var(--cardBorder);
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(
    180deg,
    color-mix(in srgb, var(--cardBg) 92%, white),
    color-mix(in srgb, var(--tableWrapBg) 48%, white)
  );
  box-shadow:0 10px 28px rgba(15,23,42,.08);
}

.legalAccordionSummary{
  width:100%;
  appearance:none;
  border:0;
  background:transparent;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px;
  text-align:left;
}

.legalAccordionTitle{
  font-size:18px;
  font-weight:800;
  color:var(--headerBg);
}

.legalAccordionMeta{
  flex:0 0 auto;
  text-align:right;
}

.legalAccordionMeta.legalMetaPill{
  min-height:32px;
  padding:6px 10px;
}

.legalAccordionSummary::after{
  content:"+";
  flex:0 0 auto;
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:1px solid var(--cardBorder);
  background:#fff;
  color:var(--headerBg);
  font-size:22px;
  line-height:1;
  transition:transform .25s ease;
}

.legalAccordionItem.isOpen .legalAccordionSummary::after{
  content:"−";
  transform:rotate(180deg);
}

.legalAccordionPanel{
  overflow:hidden;
  height:0;
  opacity:0;
  will-change:height, opacity;
  transition:height .28s ease, opacity .22s ease;
}

.legalAccordionPanel[hidden]{
  display:block;
  height:0 !important;
  opacity:0 !important;
}

.legalAccordionContent{
  border-top:1px solid var(--cardBorder);
  padding:0 18px 18px;
}

.legalModalContentWrap{
  padding-top:16px;
}

.legalModalContentTitle{
  margin:0;
  color:var(--headerBg);
  font-size:22px;
}

.legalModalContentLead{
  margin:10px 0 0;
  color:color-mix(in srgb, var(--headerBg, #1e56a0) 24%, var(--tableText, #172033) 76%);
  font-size:14px;
  line-height:1.6;
}

.legalModalRichText{
  margin-top:16px;
  display:grid;
  gap:14px;
}

.legalModalSection{
  display:grid;
  gap:8px;
}

.legalModalSection h3{
  margin:0;
  color:var(--headerBg);
  font-size:17px;
}

.legalModalSection p,
.legalModalSection li{
  color:var(--tableText, #172033);
  font-size:14px;
  line-height:1.7;
}

.legalModalSection ul{
  margin:0;
  padding-left:20px;
}

.legalModalNote{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--statsStrongBorder, #3f7fe0);
  background:linear-gradient(180deg, var(--statsStrongBg1, #dfeeff), var(--statsStrongBg2, #b6d3ff));
  color:var(--statsStrongText, #1553ad);
  font-size:14px;
  font-weight:700;
  line-height:1.6;
}

.legalFooterBtn{
  appearance:none;
  border:0;
  background:none;
  padding:0;
  margin:0;
  font:inherit;
  color:inherit;
  cursor:pointer;
}

.legalFooterBtn:hover{
  text-decoration:underline;
}

.legalModalDialog{
  position:relative;
  width:min(980px, calc(100vw - 32px - var(--safeLeft) - var(--safeRight)));
  max-height:calc(100dvh - 34px - var(--safeTop) - var(--safeBottom));
  border-radius:28px;

  border:1px solid transparent;
  background:
    linear-gradient(var(--cardBg), var(--cardBg)) padding-box,
    linear-gradient(135deg, var(--headerBg), var(--accent, #4f8cff)) border-box;

  box-shadow:0 24px 70px rgba(15,23,42,.18);
}

.legalModalBody{
  padding:20px 20px calc(22px + var(--safeBottom));
}

.legalModalHero{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:center;
  padding:8px 110px 16px 4px;
}

.legalModalClose{
  position:absolute;
  top:max(16px, var(--safeTop));
  right:max(16px, var(--safeRight));
  z-index:60;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:112px;
  height:46px;
  padding:0 18px;
  border-radius:999px;
  opacity:0;
  transform:translateY(-6px) scale(.94);
  transition:
    opacity .24s ease,
    transform .28s ease,
    background .2s ease,
    border-color .2s ease,
    box-shadow .2s ease;
  background:linear-gradient(
    180deg,
    color-mix(in srgb, var(--cardBg, #fff) 92%, white),
    color-mix(in srgb, var(--tableWrapBg, #f5f8fc) 84%, white)
  );
  border:1px solid color-mix(in srgb, var(--cardBorder) 92%, white);
  color:var(--headerBg);
  box-shadow:0 14px 30px rgba(15,23,42,.14);
  white-space:nowrap;
  font-size:15px;
  font-weight:800;
  letter-spacing:.01em;
  cursor:pointer;
}

.legalModal.isOpen .legalModalClose{
  opacity:1;
  transform:translateY(0) scale(1);
}

.legalModal.isClosing .legalModalClose{
  opacity:0;
  transform:translateY(-6px) scale(.94);
}

.legalModalClose:hover{
  background:color-mix(in srgb, var(--tableWrapBg, #f5f8fc) 72%, white);
  border-color:color-mix(in srgb, var(--headerBg, #1e56a0) 18%, white);
  box-shadow:0 18px 36px rgba(15,23,42,.18);
}



.legalModalClose:focus-visible{
  outline:2px solid color-mix(in srgb, var(--headerBg, #1e56a0) 32%, white);
  outline-offset:2px;
}
@media (max-width: 1024px){
  .legalModalDialog{
    width:min(940px, calc(100vw - 20px - var(--safeLeft) - var(--safeRight)));
    max-height:calc(100dvh - 16px - var(--safeTop) - var(--safeBottom));
    border-radius:22px;
  }
}

@media (max-width: 820px){
  .legalModal{
    align-items:flex-end;
    padding:0;
  }

  .legalModalDialog{
    width:100%;
    max-width:none;
    max-height:calc(100dvh - var(--safeTop));
    height:auto;
    border-radius:24px 24px 0 0;
    border:none;
    transform:translateY(28px);
  }

  .legalModalBody{
    padding:calc(78px + var(--safeTop)) 14px calc(18px + var(--safeBottom));
  }

  .legalModalHero{
    grid-template-columns:1fr;
    gap:12px;
    padding:0 0 14px;
  }

  .legalModalClose{
    position:fixed;
    top:calc(12px + var(--safeTop));
    right:calc(12px + var(--safeRight));
    min-width:118px;
    height:48px;
    padding:0 18px;
    font-size:15px;
  }

  .legalModalLogo{
    width:60px;
    height:60px;
  }

  .legalAccordionSummary{
    align-items:flex-start;
    padding:15px 14px;
  }

  .legalAccordionContent{
    padding:0 14px 16px;
  }

  .legalAccordionTitle{
    font-size:17px;
  }

  .legalAccordionMeta{
    display:block;
    margin-top:4px;
    text-align:left;
  }
}

/* ============================
   UPDATES / CHANGELOG
============================ */

.updatesList{
  display:flex;
  flex-direction:column;
  gap:18px;
  margin-top:10px;
}

.updateEntry{
  padding:16px 18px;
  border:1px solid var(--cardBorder);
  border-radius:18px;
  background:linear-gradient(
    180deg,
    color-mix(in srgb, var(--headerBg) 6%, white),
    #ffffff
  );
  box-shadow:0 10px 24px rgba(15,23,42,.05);
}

.updateEntryHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.updateDate{
  margin:0;
  font-size:24px;
  line-height:1.15;
  font-weight:800;
  color:var(--statsNeutralText);
}

.updateVersion{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--titleBadgeBorder);
  background:linear-gradient(
    180deg,
    var(--titleBadgeBg1),
    var(--titleBadgeBg2)
  );
  color:var(--titleBadgeText);
  font-size:13px;
  font-weight:800;
  white-space:nowrap;
}

.updateBullets{
  margin:0;
  padding-left:18px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.updateBullets li{
  color:var(--tooltipText);
  font-size:16px;
  line-height:1.6;
}

.updateBullets li::marker{
  color:var(--titleBadgeText);
}

@media (max-width:640px){
  .updateEntry{
    padding:14px 14px;
    border-radius:14px;
  }

  .updateDate{
    font-size:20px;
    letter-spacing:-0.3px;
  }

  .updateVersion{
    font-size:12px;
    padding:5px 10px;
  }

  .updateVersion.major{
  background:linear-gradient(135deg,var(--statsStrongBg1),var(--statsStrongBg2));
  border:1px solid var(--statsStrongBorder);
  color:var(--statsStrongText);
}

  .updateBullets li{
    font-size:15px;
    line-height:1.55;
  }
}
