/* =========================================================
   Global font (safe)
========================================================= */
html {
  font-family: "Onest", system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
body { 
    font-family: inherit; 
    color:#414141;
}


/* =========================================================
   Home wrapper
========================================================= */
.layout-container .ie-home { background: #fff; }


/* =========================================================
   FOOTER
========================================================= */
.layout-container .footer-main {
  margin-bottom: 65px; /* guide spacing */
}

/* Footer menu list */
.layout-container .footer-menus ul {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px; /* space around separators */
  margin: 0;
  padding: 0;
  list-style: none;
}

.layout-container .footer-menus li {
  display: flex;
  align-items: center;
}

.layout-container .footer-menus li:not(:last-child)::after {
  content: "|";
  margin-left: 18px;
  color: #000;
  font-weight: 600;
}

.layout-container .footer-menus a {
  color: #000;
  text-decoration: none;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
}

.layout-container .footer-menus a:hover {
  text-decoration: underline;
}

/* With thanks to… */
.layout-container .ie-footer-thanks {
  padding: 40px 0 20px;
}

.layout-container .ie-footer-thanks__inner {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  text-align: center;
}

.layout-container .ie-footer-thanks__title {
  margin: 0 0 40px; /* <-- requested 40px */
  font-size: 18px;
  font-weight: 600;
  color: #2b2b2b;
}

/* Actual rendered structure: .ie-footer-thanks__logos > div > div > img */
.layout-container .ie-footer-thanks__logos > div {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
  flex-wrap: wrap;
}

.layout-container .ie-footer-thanks__logos > div > div {
  flex: 0 0 auto;
  margin: 0;
}

.layout-container .ie-footer-thanks__logos img {
  display: block;
  height: 46px;
  width: auto;       /* preserve aspect ratio */
  object-fit: contain;
}

/* =========================================================
   Accordion (styles only; your existing JS handles open/close)
========================================================= */

.layout-container .accordion-section {
  background: #eef2f5; /* your grey */
  padding: 60px 0;
}

.layout-container .accordion-section .inner {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

/* Accordion wrapper */
.layout-container .accordion {
  max-width: 818px;   /* matches your intro width spec */
  margin: 0 auto;
  display: grid;
  gap: 12px;
}

/* Toggle button */
.layout-container .accordion__header {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(47, 80, 100, 0.25);
  background: #fff;
  color: #2b2b2b;

  padding: 18px 56px 18px 20px;
  border-radius: 2px;

  font-size: 18px;
  font-weight: 600;
  line-height: 1.2;

  cursor: pointer;
  position: relative;
}

/* Plus/minus indicator */
.layout-container .accordion__header::after {
  content: "+";
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 700;
  color: #2f5064;
}

/* Open state (driven by aria-expanded) */
.layout-container .accordion__header[aria-expanded="true"] {
  border-color: rgba(47, 80, 100, 0.45);
  box-shadow: 0 2px 0 rgba(47, 80, 100, 0.08);
}

.layout-container .accordion__header[aria-expanded="true"]::after {
  content: "–";
}

/* Panel */
.layout-container .accordion__panel {
  border: 1px solid rgba(47, 80, 100, 0.18);
  border-top: 0;
  background: #fff;
  border-radius: 0 0 2px 2px;

  padding: 0 20px;
}

/* Hide the duplicated title inside the panel (you already have it in the button) */
.layout-container .accordion__panel .accordion__title {
  display: none;
}

/* Content spacing */
.layout-container .accordion__panel .accordion-content {
  padding: 18px 0 22px;
  font-size: 16px;
  line-height: 1.6;
  color: #4b4b4b;
}

/* Actually hide panels when aria-hidden=true (JS sets this already) */
.layout-container .accordion__panel[aria-hidden="true"] {
  display: none;
}

/* Optional: make panel appear “attached” to the open header */
.layout-container .accordion__header[aria-expanded="true"] + .accordion__panel {
  display: block;
}

/* Focus state */
.layout-container .accordion__header:focus-visible {
  outline: 3px solid rgba(62, 166, 195, 0.45);
  outline-offset: 2px;
}

/* Mobile */
@media (max-width: 768px) {
  .layout-container .accordion__header {
    padding: 16px 52px 16px 16px;
  }
}


.layout-container .ie-hero-band__hero {
  background: #2f5064;
  padding: 70px 0;
}

.layout-container .ie-hero-band__hero-inner {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

.layout-container .ie-hero-band__title {
  margin: 0;
  color: #fff;
  font-weight: 600;
  font-size: 56px;
  line-height: 1.05;
}


@media (max-width: 768px) {
  .layout-container .ie-hero-band__title {
    font-size: clamp(32px, 7vw, 44px);
  }
}

/* =========================================================
   Register pages (mentor/mentee)
========================================================= */

.layout-container .ie-registerpage__inner {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

/* Section heading */
.layout-container .ie-registerpage__inner .ie-form-section {
  text-align: center;
  margin: 24px 0 36px;
}

.layout-container .ie-registerpage__inner .ie-form-section__title {
  margin: 40px 0 0;
  font-size: 38px;
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #3b3b3b;
}

.layout-container .ie-registerpage__inner .ie-form-section__rule {
  display: inline-block;
  width: 176px;
  height: 10px;
  margin-top: 18px;
  background: #ff6f73;
}

/* Form width */
.layout-container .ie-registerpage__inner form {
  width: min(700px, 100%);
  margin: 0 auto;
}

/* Intro paragraph inside form */
.layout-container .ie-registerpage__inner form > p {
  margin: 0 0 26px;
  font-size: 16px;
  line-height: 1.55;
}

/* Default field rows: label | control */
.layout-container .ie-registerpage__inner form .form-item {
  display: grid;
  grid-template-columns: 260px 1fr;
  align-items: center;
  column-gap: 40px;
  row-gap: 10px;
  margin: 0 0 22px;
}

.layout-container .ie-registerpage__inner form .form-item > label {
  margin: 0;
  font-size: 18px;
  line-height: 1.1;
  font-weight: 700;
  color: #3b3b3b;
}

/* Inputs/selects/textarea base */
.layout-container .ie-registerpage__inner form input[type="text"],
.layout-container .ie-registerpage__inner form input[type="email"],
.layout-container .ie-registerpage__inner form input[type="url"],
.layout-container .ie-registerpage__inner form input[type="number"],
.layout-container .ie-registerpage__inner form select,
.layout-container .ie-registerpage__inner form textarea {
  width: 100%;
  box-sizing: border-box;
  border: 2px solid #3b3b3b;
  border-radius: 0;
  padding: 0 22px;
  font-size: 18px;
  color: #2e2e2e;
  background: #fff;
}

/* 48px tall controls */
.layout-container .ie-registerpage__inner form input[type="text"],
.layout-container .ie-registerpage__inner form input[type="email"],
.layout-container .ie-registerpage__inner form input[type="url"],
.layout-container .ie-registerpage__inner form input[type="number"],
.layout-container .ie-registerpage__inner form select {
  height: 48px;
  line-height: 48px;
}

.layout-container .ie-registerpage__inner form textarea {
  min-height: 140px;
  padding: 14px 22px;
  line-height: 1.4;
  resize: vertical;
}

.layout-container .ie-registerpage__inner form input::placeholder,
.layout-container .ie-registerpage__inner form textarea::placeholder {
  color: #7a7a7a;
  opacity: 1;
}

/* Managed file: keep sane */
.layout-container .ie-registerpage__inner form .form-managed-file {
  width: 100%;
}
.layout-container .ie-registerpage__inner form .form-managed-file input[type="file"] {
  font-size: 16px;
  padding: 10px 0;
  border: 0;
}

/* =========================================================
   Methodologies fieldset: legend left, options right
========================================================= */

.layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper {
  display: grid;
  grid-template-columns: 260px 1fr;
  column-gap: 40px;
  align-items: start;
  margin: 0 0 22px;
  border: 0;
  padding: 0;
  min-width: 0;
}

.layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper > legend {
  padding: 0;
  margin: 0;
}

.layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper .fieldset-legend {
  display: block;
  margin: 0;
  font-size: 18px;
  line-height: 1.1;
  font-weight: 700;
  color: #3b3b3b;
}

/* Options: override the global .form-item grid inside the checkbox list */
.layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper #edit-methodologies.form-checkboxes > .form-item {
  display: flex !important;
  align-items: center;
  gap: 16px;
  margin: 0 0 18px;
}

/* Chunkier checkbox */
.layout-container .ie-registerpage__inner form input.form-checkbox {
  transform: scale(1.25);
  transform-origin: left center;
  margin: 0;
}

.layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper #edit-methodologies.form-checkboxes > .form-item > label.option {
  margin: 0;
  display: inline-block;
}

/* Ensure checkbox list sits in the right column */
.layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper .fieldset-wrapper {
  grid-column: 2;
}

/* =========================================================
   Agree checkbox: left label column, right is checkbox+text inline
========================================================= */

.layout-container .ie-registerpage__inner form .form-item-agree {
  display: grid;
  grid-template-columns: 260px 1fr;
  column-gap: 40px;
  align-items: center;
  margin: 0 0 22px;
}

/* Hide the empty left “label column” effect (agree has no left label element) */
.layout-container .ie-registerpage__inner form .form-item-agree::before {
  content: "";
}

/* Put checkbox + label into the right column and align inline */
.layout-container .ie-registerpage__inner form .form-item-agree input.form-checkbox {
  grid-column: 2;
}

.layout-container .ie-registerpage__inner form .form-item-agree label.option {
  grid-column: 2;
}

/* Force checkbox + label to be on one line */
.layout-container .ie-registerpage__inner form .form-item-agree {
  grid-auto-flow: row;
}

.layout-container .ie-registerpage__inner form .form-item-agree input.form-checkbox,
.layout-container .ie-registerpage__inner form .form-item-agree label.option {
  display: inline-block;
  vertical-align: middle;
}

.layout-container .ie-registerpage__inner form .form-item-agree label.option {
  margin-left: 16px;
}

/* =========================================================
   Submit button
========================================================= */

.layout-container .ie-registerpage__inner form .form-actions {
  margin-top: 32px;
  text-align: center;
}

.layout-container .ie-registerpage__inner form .form-actions .form-submit {
  width: 350px;
  height: 55px;

  background-color: #f2c14b;
  color: #3b3b3b;

  border: 0;
  border-radius: 0;

  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.01em;

  cursor: pointer;
  transition: background 0.2s ease;

  /* Baseline/vertical centering for <input type="submit"> */
  line-height: normal;
  padding: 0 70px 4px;

  /* Plus icon (two strokes) */
  background-image:
    linear-gradient(currentColor, currentColor),
    linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size:
    16px 2px,
    2px 16px;
  background-position:
    right 28px center,
    right 35px center;
}

.layout-container .ie-registerpage__inner form .form-actions .form-submit:hover {
  background-color: #e5b53e;
}

/* =========================================================
   Mobile: stack labels above controls
========================================================= */

@media (max-width: 900px) {
  .layout-container .ie-registerpage__inner form .form-item {
    grid-template-columns: 1fr;
    column-gap: 0;
  }

  .layout-container .ie-registerpage__inner form fieldset#edit-methodologies--wrapper {
    grid-template-columns: 1fr;
  }

  .layout-container .ie-registerpage__inner form .form-item-agree {
    grid-template-columns: 1fr;
  }

  .layout-container .ie-registerpage__inner form .form-item-agree input.form-checkbox,
  .layout-container .ie-registerpage__inner form .form-item-agree label.option {
    grid-column: auto;
    margin-left: 0;
  }

  .layout-container .ie-registerpage__inner form .form-actions .form-submit {
    width: min(350px, 100%);
  }

  .layout-container .ie-registerpage__inner form .form-item-agree::before {
    display: none;
  }

  .layout-container .ie-registerpage__inner form .form-item-agree::before {
    display: none;
  }
}

/* =========================================================
   T&Cs (agree) checkbox: force it to sit in the right column
========================================================= */

.layout-container .ie-registerpage__inner form .form-item-agree {
  display: grid;
  grid-template-columns: 260px 1fr;
  column-gap: 40px;
  align-items: center;
  margin: 0 0 22px;
}

/* Create an empty left column cell so the right column behaves */
.layout-container .ie-registerpage__inner form .form-item-agree::before {
  content: "";
}

/* Put BOTH checkbox + label into the right column */
.layout-container .ie-registerpage__inner form .form-item-agree input.form-checkbox,
.layout-container .ie-registerpage__inner form .form-item-agree label.option {
  grid-column: 2;
}

/* Make checkbox + label sit next to each other */
.layout-container .ie-registerpage__inner form .form-item-agree input.form-checkbox {
  justify-self: start;
}

.layout-container .ie-registerpage__inner form .form-item-agree label.option {
  justify-self: start;
  margin-left: 16px;
  display: inline-block;
}

/* Prevent any centering coming from the theme */
.layout-container .ie-registerpage__inner form .form-item-agree {
  text-align: left;
}
/* =========================================================
   Agree checkbox: make it behave like the other checkbox rows
========================================================= */

/* Stop the global label|control grid affecting this one item */
.layout-container .ie-registerpage__inner form .form-item-agree {
  display: flex !important;
  align-items: center;
  gap: 16px;
  margin: 0 0 22px;
  padding-left: 260px; /* line up with checkbox column in right side */
}

/* Keep checkbox chunky + aligned */
.layout-container .ie-registerpage__inner form .form-item-agree > input.form-checkbox {
  margin: 0 !important;
  transform: scale(1.25);
  transform-origin: left center;
}

/* Label sits neatly to the right */
.layout-container .ie-registerpage__inner form .form-item-agree > label.option {
  margin: 0 !important;
  display: inline-block;
}
/* =========================================================
   Register switcher
========================================================= */

.layout-container .ie-register-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin: 28px auto 36px;
  width: min(1120px, calc(100% - 32px));
}

/* Base card */
.layout-container .ie-register-switch__card {
  display: block;
  padding: 34px;

  font-size: 36px;
  font-weight: 600;
  line-height: 1.1;

  color: #3b3b3b;
  text-decoration: none;
  border-radius: 4px;

  background: #FFF2CC;   /* softer inactive */
  transition: background 0.15s ease;
}

/* Hover only affects links */
.layout-container .ie-register-switch__card[href]:hover {
  background: #FFE08A;
}

/* Active */
.layout-container .ie-register-switch__card.is-active {
  background: #FFD166;   /* fully opaque */
  cursor: default;
}

.layout-container .ie-registerpage__formband {
  background: #FAFAFA;
  padding: 40px 0 60px;
  margin-top: 28px;

  /* full-bleed band */
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* =========================================================
   Generic basic page
========================================================= */

.layout-container .ie-generic-page__body {
  background: #fff;
}

.layout-container .ie-generic-page__body .ie-wrap {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

/* Rich text styling */
.layout-container .ie-generic-page__body .ie-rich {
  font-size: 16px;
  line-height: 1.65;
}

.layout-container .ie-generic-page__body .ie-rich h2 {
  font-size: 30px;
  font-weight: 600;
  margin: 40px 0 18px;
}

.layout-container .ie-generic-page__body .ie-rich h3 {
  font-size: 22px;
  font-weight: 600;
  margin: 32px 0 14px;
}

.layout-container .ie-generic-page__body .ie-rich p {
  margin: 0 0 16px;
}

/* Generic page HR */
.layout-container .ie-generic-page__body .ie-rich hr {
  border: 0;
  height: 2px;
  background: #f2c14b;
  margin: 40px 0;
}

/* =========================================================
   Generic page blockquote
========================================================= */

.layout-container .ie-generic-page__body .ie-rich blockquote {
  margin: 48px auto;
  padding: 28px 32px;
  max-width: 818px;          /* narrower than 1120 inner */
  
  font-size: 22px;           /* larger */
  line-height: 1.5;
  font-weight: 500;

  color: #2f5064;            /* brand blue */
  background: rgba(47, 80, 100, 0.06);
  border-left: 6px solid #2f5064;
}

/* Remove default italics if you want a more modern feel */
.layout-container .ie-generic-page__body .ie-rich blockquote p {
  margin: 0;
}

/* Optional citation styling */
.layout-container .ie-generic-page__body .ie-rich blockquote cite {
  display: block;
  margin-top: 16px;
  font-size: 14px;
  font-style: normal;
  color: #414141;
  opacity: 0.8;
}

/* =========================================================
   Generic page table
========================================================= */

.layout-container .ie-generic-page__body .ie-rich table {
  width: 100%;
  max-width: 818px;        /* narrower like blockquote */
  border-collapse: collapse;
  font-size: 16px;
  line-height: 1.6;
}

/* Header row */
.layout-container .ie-generic-page__body .ie-rich thead th {
  text-align: left;
  font-weight: 600;
  padding: 14px 18px;

  color: #2f5064;
  border-bottom: 2px solid #2f5064;
}

/* Body cells */
.layout-container .ie-generic-page__body .ie-rich td {
  padding: 14px 18px;
  border-bottom: 1px solid rgba(47, 80, 100, 0.15);
}

/* Subtle alternating rows */
.layout-container .ie-generic-page__body .ie-rich tbody tr:nth-child(even) {
  background: rgba(47, 80, 100, 0.04);
}

/* Remove last border */
.layout-container .ie-generic-page__body .ie-rich tbody tr:last-child td {
  border-bottom: 0;
}

/* Add subtle outer border */
.layout-container .ie-generic-page__body .ie-rich table {
  border: 1px solid #2f5064;
  border-radius: 2px;
  overflow: hidden; /* keeps border clean with radius */
}

/* Generic page table */
.layout-container .ie-generic-page__body .ie-rich table.table {
  width: 100%;
  max-width: 818px;
  border-collapse: separate;      /* important */
  border-spacing: 0;              /* remove gaps */
  border: 1px solid rgba(47, 80, 100, 0.25);
  border-radius: 2px;
  overflow: hidden;
}

.ie-dashboard-subnav {
  background: #fafafa;
  padding: 28px 0;
}

.ie-dashboard-subnav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.ie-dashboard-subnav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  background: #f2c14b;
  color: #414141;
  text-decoration: none;
  font-weight: 600;
  border-radius: 2px;
}

.ie-dashboard-subnav a.is-active,
.ie-dashboard-subnav a[aria-current="page"] {
  background: #ffd166;
}

/* Dashboard: constrain the 2 latest-* view blocks to the usual 1120 inner */
#block-custom-views-block-mentees-block-1,
#block-custom-views-block-mentors-block-1,#block-custom-views-block-mentors-block-2,#block-custom-views-block-mentees-block-2 {
  width: min(1120px, calc(100% - 32px));
  margin-left: auto;
  margin-right: auto;
}

/* Optional: give them a bit of breathing room */
#block-custom-views-block-mentees-block-1 {
  margin-top: 24px;
}

#block-custom-views-block-mentors-block-1 {
  margin-top: 40px;
}

#block-custom-views-block-mentees-block-1 table,
#block-custom-views-block-mentors-block-1 table {
  width: 100%;
  max-width: 100%;
}

/* =========================================================
   Dashboard tables
========================================================= */

#block-custom-views-block-mentees-block-1 table,
#block-custom-views-block-mentors-block-1 table,
#block-custom-views-block-mentors-block-2 table,
#block-custom-views-block-mentees-block-2 table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(47, 80, 100, 0.25); /* outer border */
  background: #fff;
}

/* Header row */
#block-custom-views-block-mentees-block-1 thead,
#block-custom-views-block-mentors-block-1 thead,
#block-custom-views-block-mentors-block-2 thead,
#block-custom-views-block-mentees-block-2 thead {
  background: rgba(47, 80, 100, 0.08);
}

#block-custom-views-block-mentees-block-1 th,
#block-custom-views-block-mentors-block-1 th,
#block-custom-views-block-mentors-block-2 th,
#block-custom-views-block-mentees-block-2 th {
  text-align: left;
  padding: 14px 16px;
  font-size: 14px;
  font-weight: 700;
  color: #2f5064;
  border-bottom: 1px solid rgba(47, 80, 100, 0.25);
}

/* Table cells */
#block-custom-views-block-mentees-block-1 td,
#block-custom-views-block-mentors-block-1 td,
#block-custom-views-block-mentors-block-2 td,
#block-custom-views-block-mentees-block-2 td {
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.5;
  border-bottom: 1px solid rgba(47, 80, 100, 0.12);
}

/* Zebra rows (subtle) */
#block-custom-views-block-mentees-block-1 tbody tr:nth-child(even),
#block-custom-views-block-mentors-block-1 tbody tr:nth-child(even),
#block-custom-views-block-mentors-block-2 tbody tr:nth-child(even),
#block-custom-views-block-mentees-block-2 tbody tr:nth-child(even) {
  background: rgba(47, 80, 100, 0.04);
}

/* Hover */
#block-custom-views-block-mentees-block-1 tbody tr:hover,
#block-custom-views-block-mentors-block-1 tbody tr:hover,
#block-custom-views-block-mentors-block-2 tbody tr:hover,
#block-custom-views-block-mentees-block-2 tbody tr:hover {
  background: rgba(242, 193, 75, 0.18);
}

/* Edit links */
#block-custom-views-block-mentees-block-1 td a,
#block-custom-views-block-mentors-block-1 td a,
#block-custom-views-block-mentors-block-2 td a,
#block-custom-views-block-mentees-block-2 td a {
  color: #2f5064;
  font-weight: 600;
  text-decoration: none;
}

#block-custom-views-block-mentees-block-1 td a:hover,
#block-custom-views-block-mentors-block-1 td a:hover,
#block-custom-views-block-mentors-block-2 td a:hover,
#block-custom-views-block-mentees-block-2 td a:hover {
  text-decoration: underline;
}

/* =========================================================
   Primary Yellow Button (matches dashboard subnav)
========================================================= */

a.button,
.button.button--yellow {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 44px;                 /* matches subnav presence */
  padding: 0 20px;

  background: #FFD166;
  color: #414141;

  border: 0;
  border-radius: 2px;

  font-size: 18px;
  font-weight: 600;
  line-height: 1.1;

  text-decoration: none;
  cursor: pointer;

  transition: background 0.2s ease, transform 0.05s ease;
}

/* Hover */
a.button:hover,
.button.button--yellow:hover {
  background: #f2c14b;
  color: #414141;
  text-decoration: none;
}

/* Active press */
a.button:active,
.button.button--yellow:active {
  transform: translateY(1px);
}

/* Center dashboard block footer buttons */
#block-custom-views-block-mentees-block-1 footer,
#block-custom-views-block-mentors-block-1 footer,
#block-custom-views-block-mentees-block-2 footer,
#block-custom-views-block-mentors-block-2 footer {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

/* =========================================================
   Login page
========================================================= */

.layout-container .ie-login-page__body {
  background: #fafafa;
  padding: 60px 0 80px;
}

.layout-container .ie-login-card {
  max-width: 480px;
  margin: 0 auto;
  padding: 40px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
}

/* Login form spacing */
.layout-container .ie-login-card form .form-item {
  margin-bottom: 22px;
}

/* Inputs */
.layout-container .ie-login-card input[type="text"],
.layout-container .ie-login-card input[type="password"] {
  width: 100%;
  height: 48px;
  padding: 0 18px;
  border: 2px solid #3b3b3b;
  border-radius: 0;
}

/* Submit */
.layout-container .ie-login-card .form-actions {
  text-align: center;
  margin-top: 30px;
}

.layout-container .ie-login-card .form-submit {
  width: 100%;
  height: 55px;
  background: #f2c14b;
  color: #414141;
  border: 0;
  font-size: 20px;
  font-weight: 700;
  cursor: pointer;
}

/* Forgot password */
.layout-container .ie-login__forgot {
  margin-top: 22px;
  text-align: center;
}

.layout-container .ie-login__forgot a {
  color: #2f5064;
  font-weight: 600;
  text-decoration: none;
}

.layout-container .ie-login__forgot a:hover {
  text-decoration: underline;
}

/* Remove create account link if Drupal outputs it */
.layout-container .ie-login-card .user-login-form .description,
.layout-container .ie-login-card .user-login-form .form-item-register {
  display: none;
}

/* Login band background starts at form */
.layout-container .ie-login-page__body {
  background: #fafafa;
  padding: 48px 0 80px;
}

/* Ensure the login form uses the register form layout rules */
.layout-container .ie-login-page__form form {
  width: min(700px, 100%);
  margin: 0 auto;
}

/* Optional: slightly narrower if you prefer */
.layout-container .ie-login-page__form form {
  max-width: 700px;
}

/* Forgot password link styling */
.layout-container .ie-login-page__forgot {
  margin-top: 18px;
  text-align: center;
}

.layout-container .ie-login-page__forgot a {
  color: #414141;
  font-weight: 600;
  text-decoration: underline;
}

/* Hide create account / register help text if it appears */
.layout-container .ie-login-page .user-login-form .description,
.layout-container .ie-login-page .user-login-form .item-list {
  display: none;
}

/* Login: use the generic yellow button style (no +) */
.layout-container .ie-login-page .form-actions .form-submit {
  /* match .button.button--yellow */
  background: #f2c14b;
  color: #414141;
  border: 0;
  border-radius: 0;
  font-weight: 700;

  /* size like your other buttons */
  height: 55px;
  min-width: 350px;
  padding: 0 28px;
  font-size: 16px;

  cursor: pointer;
  background-image: none !important;
}

.layout-container .ie-login-page .form-actions {
  margin-top: 20px;
  display: flex;
  justify-content: center;
}

/* Login: use the generic yellow button style (no +) */
.layout-container .ie-login-page .form-actions .form-submit {
  /* match .button.button--yellow */
  background: #f2c14b;
  color: #414141;
  border: 0;
  border-radius: 0;
  font-weight: 700;

  /* size like your other buttons */
  height: 22px;
  min-width: 350px;
  padding: 0 28px;
  font-size: 18px;

  cursor: pointer;
  background-image: none !important;
}

.layout-container .ie-login-page .form-actions {
  margin-top: 20px;
  display: flex;
  justify-content: center;
}

/* Add password to your existing input styling */
.layout-container .ie-registerpage__inner form input[type="password"] {
  width: 100%;
  box-sizing: border-box;
  border: 2px solid #3b3b3b;
  border-radius: 0;
  padding: 0 22px;
  font-size: 18px;
  color: #2e2e2e;
  background: #fff;

  height: 48px;
  line-height: 48px;
}
