/* Authoring UX layer (frontend login + article editing), non-destructive */

.fs3-auth-page {
  max-width: 760px;
  margin: 24px auto 36px;
}

.fs3-auth-card {
  background: #fff;
  border: 1px solid #d8dfeb;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(9, 30, 66, 0.08);
  padding: 24px;
}

.fs3-auth-header h1 {
  margin-bottom: 14px;
  font-size: clamp(1.6rem, 2.2vw, 2.1rem);
  color: #10243f;
}

.fs3-auth-form .control-group,
.fs3-auth-form .mb-3,
.fs3-auth-form .form-group {
  margin-bottom: 14px;
}

.fs3-auth-form .control-label,
.fs3-auth-form label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
  color: #173a62;
}

.fs3-auth-form input[type="text"],
.fs3-auth-form input[type="password"],
.fs3-auth-form input[type="email"],
.fs3-auth-form .form-control,
.fs3-editor-form input[type="text"],
.fs3-editor-form input[type="email"],
.fs3-editor-form input[type="url"],
.fs3-editor-form select,
.fs3-editor-form textarea,
.fs3-editor-form .form-control {
  width: 100%;
  border: 1px solid #cdd8e8;
  border-radius: 10px;
  min-height: 42px;
  padding: 10px 12px;
  box-sizing: border-box;
  background: #fff;
  color: #10243f;
}

.fs3-auth-submit .btn,
.fs3-auth-extra .btn {
  width: 100%;
  border-radius: 10px;
  font-weight: 700;
}

.fs3-auth-links {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.fs3-auth-links a {
  display: block;
  border: 1px solid #d9e2f0;
  border-radius: 10px;
  padding: 10px 12px;
  text-decoration: none;
  color: #1a3f67;
  background: #f9fbff;
}

.fs3-auth-links a:hover,
.fs3-auth-links a:focus {
  background: #eef5ff;
}

.fs3-editor-page {
  max-width: 1100px;
  margin: 18px auto 40px;
}

.fs3-editor-header h1 {
  margin-bottom: 10px;
  color: #10243f;
  font-size: clamp(1.5rem, 2.4vw, 2.1rem);
}

.fs3-editor-form {
  background: #fff;
  border: 1px solid #d8dfeb;
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 10px 26px rgba(9, 30, 66, 0.06);
}

.fs3-editor-form .nav-tabs {
  border-bottom: 1px solid #d8dfeb;
  gap: 4px;
}

.fs3-editor-form .nav-tabs .nav-link {
  border-radius: 10px 10px 0 0;
  border: 1px solid transparent;
  color: #385a83;
  font-weight: 600;
}

.fs3-editor-form .nav-tabs .nav-link.active {
  color: #0f2f58;
  border-color: #d8dfeb #d8dfeb #fff;
  background: #fff;
}

.fs3-editor-form .tab-content {
  padding-top: 14px;
}

.fs3-editor-actions {
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid #e4e9f3;
}

.fs3-editor-actions .btn {
  border-radius: 10px;
  font-weight: 700;
}

@media (max-width: 979px) {
  .fs3-auth-page,
  .fs3-editor-page {
    margin: 12px 10px 24px;
    max-width: none;
  }

  .fs3-auth-card,
  .fs3-editor-form {
    border-radius: 12px;
    padding: 14px;
  }

  .fs3-editor-actions {
    position: sticky;
    bottom: 8px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(5px);
    border: 1px solid #d8dfeb;
    border-radius: 12px;
    padding: 10px;
    z-index: 30;
  }

  .fs3-editor-actions .btn {
    width: 100%;
    margin-bottom: 8px;
  }

  .fs3-editor-actions .btn:last-child {
    margin-bottom: 0;
  }
}

/* MFA captive flow (verification + method selection) */
.fs3-mfa-page {
  max-width: 920px;
}

.fs3-mfa-card {
  padding: 26px;
}

.fs3-mfa-title {
  margin: 0 0 10px;
  color: #10243f;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.25;
}

.fs3-mfa-title small {
  display: inline-block;
  margin-left: 6px;
  font-size: 0.72em;
  color: #4c6482;
}

.fs3-mfa-pre-message,
.fs3-mfa-post-message {
  color: #2c3e55;
  margin: 8px 0 14px;
}

.fs3-mfa-fields {
  margin-top: 10px;
}

.fs3-mfa-form .fs3-mfa-label {
  display: block;
  margin-bottom: 7px;
  font-weight: 700;
  color: #173a62;
}

.fs3-mfa-form #users-mfa-code {
  max-width: 340px;
}

.fs3-mfa-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
}

.fs3-mfa-actions .btn {
  min-height: 42px;
  border-radius: 10px;
  font-weight: 700;
}

.fs3-mfa-actions .btn.btn-primary {
  min-width: 150px;
}

.fs3-mfa-alt-method {
  margin-top: 12px;
}

.fs3-mfa-alt-method a {
  color: #1a4f83;
  font-weight: 600;
  text-decoration: none;
}

.fs3-mfa-alt-method a:hover,
.fs3-mfa-alt-method a:focus {
  text-decoration: underline;
}

.fs3-mfa-method-list {
  display: grid;
  gap: 10px;
  margin-top: 8px;
}

.fs3-mfa-method {
  display: flex;
  gap: 12px;
  align-items: center;
  border: 1px solid #d7e0ee;
  border-radius: 12px;
  padding: 10px 12px;
  background: #fbfdff;
  text-decoration: none;
}

.fs3-mfa-method:hover,
.fs3-mfa-method:focus {
  background: #eef5ff;
}

.fs3-mfa-method-image {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.fs3-mfa-method-body {
  display: grid;
  gap: 2px;
}

.fs3-mfa-method-title {
  color: #173a62;
  font-weight: 700;
}

.fs3-mfa-method-name {
  color: #5d7390;
}

@media (max-width: 979px) {
  .fs3-mfa-card {
    padding: 16px;
  }

  .fs3-mfa-form #users-mfa-code {
    max-width: 100%;
  }

  .fs3-mfa-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .fs3-mfa-actions .btn {
    width: 100%;
  }
}

/* Editor/article refinement for legacy full_screen_3 */
.edit.item-page.fs3-editor-page {
  max-width: 1240px;
  margin: 18px auto 140px;
  padding: 0 14px;
}

.edit.item-page.fs3-editor-page .page-header {
  margin-bottom: 12px;
}

.edit.item-page.fs3-editor-page .page-header h1 {
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  letter-spacing: 0.2px;
}

.fs3-editor-form {
  background: #ffffff !important;
  border: 1px solid #d4dfef !important;
  border-radius: 16px !important;
  box-shadow: 0 12px 30px rgba(15, 35, 60, 0.08) !important;
}

.fs3-editor-form fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

.fs3-editor-form .nav-tabs {
  margin-bottom: 14px;
}

.fs3-editor-form .nav-tabs .nav-link {
  font-size: 1.02rem;
  font-weight: 700;
}

.fs3-editor-form #jform_title,
.fs3-editor-form #jform_alias {
  max-width: 780px;
}

.fs3-editor-form .control-group,
.fs3-editor-form .mb-3,
.fs3-editor-form .form-group {
  margin-bottom: 16px;
}

.fs3-editor-form .control-label label,
.fs3-editor-form .form-label,
.fs3-editor-form label {
  font-weight: 700;
  color: #173a62;
}

.fs3-editor-form .tox-tinymce {
  border: 1px solid #cfd9ea !important;
  border-radius: 12px !important;
  overflow: hidden;
  box-shadow: 0 6px 16px rgba(13, 35, 61, 0.06);
}

.fs3-editor-form .tox .tox-toolbar,
.fs3-editor-form .tox .tox-toolbar__primary,
.fs3-editor-form .tox .tox-toolbar__overflow {
  background: #f5f8fd !important;
}

.fs3-editor-actions {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid #deE6f2;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.fs3-editor-actions .btn {
  min-height: 42px;
  padding: 10px 16px;
}

/* Frontend article readability */
.main_component .item-page {
  max-width: 980px;
  margin: 0 auto 26px;
  padding: 20px 22px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(26, 47, 74, 0.12);
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(14, 30, 52, 0.08);
}

.main_component .item-page h1,
.main_component .item-page h2,
.main_component .item-page h3 {
  line-height: 1.28;
  margin-top: 0.4em;
  margin-bottom: 0.55em;
}

.main_component .item-page p {
  margin: 0 0 0.95em;
  line-height: 1.72;
}

.main_component .item-page ul,
.main_component .item-page ol {
  margin: 0 0 1.05em 1.3em;
}

.main_component .item-page li {
  margin-bottom: 0.4em;
}

.main_component .item-page img {
  max-width: 100% !important;
  height: auto !important;
  border-radius: 10px;
  margin: 12px 0;
}

.main_component .item-page .img-intro-left,
.main_component .item-page .img-fulltext-left {
  margin: 0 16px 10px 0;
}

.main_component .item-page .img-intro-right,
.main_component .item-page .img-fulltext-right {
  margin: 0 0 10px 16px;
}

.main_component .item-page dl.article-info {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  background: #f4f7fc;
  border: 1px solid #dde6f2;
  border-radius: 10px;
  padding: 10px 12px;
  margin: 0 0 16px;
}

.main_component .item-page dl.article-info dt,
.main_component .item-page dl.article-info dd {
  margin: 0;
}

.main_component .item-page .actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  margin: 0 0 8px;
  padding: 0;
  list-style: none;
}

.main_component .item-page .readmore a,
.main_component .blog .readmore a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 14px;
  border-radius: 10px;
  background: #1f4f80;
  color: #fff !important;
  text-decoration: none;
  font-weight: 700;
}

.main_component .item-page .readmore a:hover,
.main_component .blog .readmore a:hover {
  background: #163b60;
}

/* Keep bottom fixed footer from overlapping authoring/edit area */
.edit.item-page.fs3-editor-page,
.com-users-login.fs3-auth-page,
.com-users-mfa-captive.fs3-auth-page,
#com-users-select.fs3-auth-page {
  padding-bottom: 70px;
}

@media (max-width: 979px) {
  .edit.item-page.fs3-editor-page {
    margin: 10px auto 120px;
    padding: 0 10px;
  }

  .main_component .item-page {
    padding: 14px;
    border-radius: 12px;
  }

  .fs3-editor-actions {
    position: sticky;
    bottom: 54px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid #d6e0ef;
    border-radius: 12px;
    padding: 10px;
    z-index: 35;
  }

  .fs3-editor-actions .btn {
    width: 100%;
  }
}

/* Editorial phase 2: blog/news presentation */
.main_component .blog {
  max-width: 1120px;
  margin: 0 auto;
}

.main_component .blog > h1 {
  max-width: 980px;
  margin: 0 auto 14px;
}

.main_component .blog .items-leading,
.main_component .blog .items-row {
  margin-bottom: 16px;
}

.main_component .blog .leading-0,
.main_component .blog .leading-1,
.main_component .blog .leading-2,
.main_component .blog .item {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(23, 46, 75, 0.14);
  border-radius: 14px;
  padding: 16px 18px;
  box-shadow: 0 8px 22px rgba(14, 31, 52, 0.08);
}

.main_component .blog .item .contentheading,
.main_component .blog .item h2.contentheading,
.main_component .blog .leading-0 .contentheading,
.main_component .blog .leading-1 .contentheading,
.main_component .blog .leading-2 .contentheading {
  margin: 0 0 10px;
  font-size: clamp(1.25rem, 1.9vw, 1.55rem);
  line-height: 1.34;
  border: 0;
  padding: 0;
}

.main_component .blog .item .contentheading a,
.main_component .blog .leading-0 .contentheading a,
.main_component .blog .leading-1 .contentheading a,
.main_component .blog .leading-2 .contentheading a {
  color: #173a62;
  text-decoration: none;
}

.main_component .blog .item .contentheading a:hover,
.main_component .blog .leading-0 .contentheading a:hover,
.main_component .blog .leading-1 .contentheading a:hover,
.main_component .blog .leading-2 .contentheading a:hover {
  color: #0f2f58;
  text-decoration: underline;
}

.main_component .blog .item .article-info,
.main_component .blog .leading-0 .article-info,
.main_component .blog .leading-1 .article-info,
.main_component .blog .leading-2 .article-info {
  margin-bottom: 12px;
}

.main_component .blog .item p,
.main_component .blog .leading-0 p,
.main_component .blog .leading-1 p,
.main_component .blog .leading-2 p {
  margin-bottom: 0.92em;
  line-height: 1.7;
}

.main_component .blog .item img,
.main_component .blog .leading-0 img,
.main_component .blog .leading-1 img,
.main_component .blog .leading-2 img {
  max-width: 100% !important;
  height: auto !important;
  border-radius: 10px;
  margin: 8px 0 12px;
}

.main_component .blog .row-separator {
  display: block;
  height: 0;
  clear: both;
}

.main_component .blog .pagination {
  margin-top: 12px;
}

/* Program/event article helper classes you can use in editor */
.main_component .item-page .fs3-program {
  background: #f7fbff;
  border: 1px solid #d9e6f5;
  border-radius: 12px;
  padding: 14px;
  margin: 14px 0;
}

.main_component .item-page .fs3-program > h3,
.main_component .item-page .fs3-program > h4 {
  margin-top: 0;
}

.main_component .item-page .fs3-program .fs3-program-month {
  display: inline-block;
  background: #214d7c;
  color: #fff;
  border-radius: 999px;
  font-weight: 700;
  font-size: .9rem;
  line-height: 1;
  padding: 7px 12px;
  margin-bottom: 10px;
}

.main_component .item-page .fs3-program ol,
.main_component .item-page .fs3-program ul {
  margin-left: 1.2em;
}

.main_component .item-page .fs3-program li {
  margin-bottom: .45em;
}

.main_component .item-page .fs3-note {
  border-left: 4px solid #2a69b8;
  background: #eef5ff;
  padding: 10px 12px;
  border-radius: 8px;
  margin: 12px 0;
}

@media (max-width: 979px) {
  .main_component .blog .leading-0,
  .main_component .blog .leading-1,
  .main_component .blog .leading-2,
  .main_component .blog .item {
    padding: 12px;
    border-radius: 12px;
  }
}


/* Frontend editing UX fixes for /nea authoring flow */
#navigation a.jmodedit,
#navigation a.jmodedit *,
#navigation .jmenuedit,
#navigation .jmenuedit *,
#navigation .module-edit,
#navigation .module-edit *,
#navigation .module-edit-link,
#navigation .module-edit-position,
#navigation .module-edit-info,
#navigation .mod-preview,
#navigation .mod-preview-wrapper,
#navigation .mod-preview-info,
#navigation .modpreview,
#navigation .modpreview-wrapper,
#navigation .modpreview-info,
#navigation [role="tooltip"] {
  display: none !important;
}

/* 2026-05-26 Contact page visual refresh (scoped, update-safe) */
.com-contact.contact {
  max-width: 1060px;
  margin: 0 auto 30px;
}

.com-contact.contact > .page-header {
  margin: 0 0 14px;
  padding: 0;
  border: 0;
}

.com-contact.contact > .page-header h1 {
  margin: 0;
  padding: 0;
  border: 0;
  color: #143458;
  font-size: clamp(1.45rem, 2.4vw, 2.05rem);
  letter-spacing: .2px;
}

.com-contact.contact > .com-contact__container {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(20, 48, 79, 0.13);
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(13, 30, 52, 0.08);
  padding: 18px;
  margin: 0 0 14px;
}

.com-contact.contact > .com-contact__container > h2,
.com-contact.contact > h2 {
  margin: 0 0 12px;
  color: #173a62;
  font-size: clamp(1.15rem, 1.9vw, 1.45rem);
  font-weight: 700;
}

.com-contact .com-contact__info {
  background: linear-gradient(180deg, #f9fcff, #f3f8ff);
  border: 1px solid #d9e5f3;
  border-radius: 12px;
  padding: 12px 14px;
}

.com-contact .com-contact__address {
  margin: 0;
}

.com-contact .com-contact__address dt {
  margin: 10px 0 3px;
  font-weight: 700;
  color: #1c4069;
}

.com-contact .com-contact__address dd {
  margin: 0 0 8px;
  color: #28384d;
}

.com-contact .com-contact__address .jicons-text {
  font-weight: 700;
}

.com-contact .com-contact__address a {
  color: #1f5b97;
  text-decoration: none;
}

.com-contact .com-contact__address a:hover,
.com-contact .com-contact__address a:focus {
  text-decoration: underline;
}

.com-contact .com-contact__form {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(20, 48, 79, 0.13);
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(13, 30, 52, 0.07);
  padding: 16px;
}

.com-contact .com-contact__form #contact-form {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  margin: 0;
  padding: 0;
}

.com-contact .com-contact__form #contact-form fieldset legend {
  font-size: 1.02rem;
  font-weight: 700;
  color: #1a3f67;
  margin-bottom: 12px;
}

.com-contact .com-contact__form #contact-form .control-group {
  display: grid;
  grid-template-columns: minmax(170px, 220px) 1fr;
  gap: 10px 16px;
  align-items: start;
  margin: 0 0 14px;
}

.com-contact .com-contact__form #contact-form .control-label,
.com-contact .com-contact__form #contact-form .control-label label {
  margin: 0;
  color: #183a61;
  font-weight: 700;
}

.com-contact .com-contact__form #contact-form .controls {
  margin: 0;
}

.com-contact .com-contact__form #contact-form input[type="text"],
.com-contact .com-contact__form #contact-form input[type="email"],
.com-contact .com-contact__form #contact-form textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid #c9d7ea;
  border-radius: 10px;
  padding: 10px 12px;
  box-sizing: border-box;
  background: #fff;
  color: #122f50;
}

.com-contact .com-contact__form #contact-form textarea {
  min-height: 160px;
  line-height: 1.55;
  resize: vertical;
}

.com-contact .com-contact__form #contact-form input[type="text"]:focus,
.com-contact .com-contact__form #contact-form input[type="email"]:focus,
.com-contact .com-contact__form #contact-form textarea:focus {
  border-color: #6da8e0;
  box-shadow: 0 0 0 3px rgba(83, 149, 214, 0.18);
  outline: none;
}

.com-contact .com-contact__form #contact-form .btn.btn-primary {
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 10px;
  font-weight: 700;
  letter-spacing: .2px;
  background: #1f5b97;
  border-color: #1f5b97;
}

.com-contact .com-contact__form #contact-form .btn.btn-primary:hover,
.com-contact .com-contact__form #contact-form .btn.btn-primary:focus {
  background: #174775;
  border-color: #174775;
}

.com-contact .com-contact__form #contact-form .star {
  color: #c61d3e;
}

.main_component [id^="OMapsID_"] {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(13, 30, 52, 0.12);
}

@media (max-width: 979px) {
  .com-contact.contact {
    margin-bottom: 20px;
  }

  .com-contact.contact > .com-contact__container,
  .com-contact .com-contact__form {
    border-radius: 12px;
    padding: 12px;
  }

  .com-contact .com-contact__form #contact-form .control-group {
    grid-template-columns: 1fr;
    gap: 6px;
    margin-bottom: 12px;
  }

  .com-contact .com-contact__form #contact-form .btn.btn-primary {
    width: 100%;
  }
}

/* 2026-05-26 contact harmonization pass (palette + centering) */
.com-contact.contact > .page-header h1,
.com-contact.contact > .com-contact__container > h2,
.com-contact.contact > h2,
.com-contact .com-contact__form #contact-form fieldset legend,
.com-contact .com-contact__form #contact-form .control-label,
.com-contact .com-contact__form #contact-form .control-label label {
  color: #2a2f36;
}

.com-contact.contact > .com-contact__container,
.com-contact .com-contact__form {
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(0, 0, 0, 0.16);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.10);
}

.com-contact .com-contact__info {
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(0, 0, 0, 0.12);
}

.com-contact .com-contact__address dt,
.com-contact .com-contact__address dd,
.com-contact .com-contact__address a {
  color: #303741;
}

.com-contact .com-contact__form #contact-form {
  max-width: 860px;
  margin: 0 auto;
}

.com-contact .com-contact__form #contact-form .control-group {
  grid-template-columns: 1fr;
  gap: 6px;
  margin-bottom: 12px;
}

.com-contact .com-contact__form #contact-form .control-label,
.com-contact .com-contact__form #contact-form .controls {
  width: 100%;
  float: none;
  text-align: left;
}

.com-contact .com-contact__form #contact-form input[type="text"],
.com-contact .com-contact__form #contact-form input[type="email"],
.com-contact .com-contact__form #contact-form textarea {
  border-color: rgba(0, 0, 0, 0.18);
  color: #222a33;
}

.com-contact .com-contact__form #contact-form input[type="text"]:focus,
.com-contact .com-contact__form #contact-form input[type="email"]:focus,
.com-contact .com-contact__form #contact-form textarea:focus {
  border-color: #4d5968;
  box-shadow: 0 0 0 3px rgba(77, 89, 104, 0.18);
}

.com-contact .com-contact__form #contact-form .btn.btn-primary {
  background: #2f3843;
  border-color: #2f3843;
}

.com-contact .com-contact__form #contact-form .btn.btn-primary:hover,
.com-contact .com-contact__form #contact-form .btn.btn-primary:focus {
  background: #20262d;
  border-color: #20262d;
}

/* 2026-05-26 contact submit accessibility fix */
.com-contact .com-contact__form #contact-form .btn.btn-primary,
.com-contact .com-contact__form #contact-form .btn.btn-primary:link,
.com-contact .com-contact__form #contact-form .btn.btn-primary:visited,
.com-contact .com-contact__form #contact-form .btn.btn-primary:hover,
.com-contact .com-contact__form #contact-form .btn.btn-primary:focus {
  color: #fff !important;
  text-shadow: none !important;
}

.com-contact .com-contact__form #contact-form > .control-group:last-child .controls {
  text-align: center;
}

.com-contact .com-contact__form #contact-form .btn.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
}

@media (max-width: 979px) {
  .com-contact .com-contact__form #contact-form > .control-group:last-child .controls {
    text-align: stretch;
  }

  .com-contact .com-contact__form #contact-form .btn.btn-primary {
    display: flex;
    width: 100%;
    min-width: 0;
  }
}
