/**
 * Clay 3.149.2
 *
 * SPDX-FileCopyrightText: © 2020 Liferay, Inc. <https://liferay.com>
 * SPDX-FileCopyrightText: © 2020 Contributors to the project Clay <https://github.com/liferay/clay/graphs/contributors>
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */
/**
 * Bootstrap v4.4.1
 *
 * SPDX-FileCopyrightText: © 2019 Twitter, Inc. <https://twitter.com>
 * SPDX-FileCopyrightText: © 2019 The Bootstrap Authors <https://getbootstrap.com/>
 *
 * SPDX-License-Identifier: LicenseRef-MIT-Bootstrap
 */
/**
 * Clay 3.149.2
 *
 * SPDX-FileCopyrightText: © 2020 Liferay, Inc. <https://liferay.com>
 * SPDX-FileCopyrightText: © 2020 Contributors to the project Clay <https://github.com/liferay/clay/graphs/contributors>
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */
/**
 * Bootstrap v4.4.1
 *
 * SPDX-FileCopyrightText: © 2019 Twitter, Inc. <https://twitter.com>
 * SPDX-FileCopyrightText: © 2019 The Bootstrap Authors <https://getbootstrap.com/>
 *
 * SPDX-License-Identifier: LicenseRef-MIT-Bootstrap
 */
/* ==================================================
   PGS PORTAL - FIGMA DESIGN SYSTEM
   Based on Figma CSS Export
   ================================================== */
/* Import Urbanist Font */
@import url("https://fonts.googleapis.com/css2?family=Urbanist:wght@300;400;500;600;700;800;900&display=swap");
/* ==================================================
   GLOBAL STYLES
   ================================================== */
@import url("https://fonts.googleapis.com/css2?family=Urbanist:wght@300;400;500;600;700;800;900&display=swap");
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

/* Screen reader only content */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Focus management */
.focus-trap:focus {
  outline: 2px solid var(--color-primary, #7F0723);
  outline-offset: 2px;
}

body {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-base, 16px);
  font-weight: var(--font-weight-normal, 400);
  line-height: 1.5;
  color: var(--color-text-primary, #0D0D0D);
  background-color: var(--color-background, #FFFFFF);
  margin: 0;
  padding: 0;
  overflow-x: hidden; /* Prevent horizontal overflow from fixed elements */
}

/* Container */
.container {
  max-width: var(--container-width, 1920px) !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

.content-container {
  max-width: var(--content-width, 1640px);
  margin: 0 auto;
  padding: 0 var(--content-offset, 140px);
}

.text-uppercase {
  text-transform: uppercase;
}

.sr-only {
  border: 0;
  clip: rect(0, 0, 0, 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.sr-only-focusable:active, .sr-only-focusable:focus {
  clip: auto;
  height: auto;
  overflow: visible;
  position: static;
  white-space: normal;
  width: auto;
}

.lfr-asset-column-details .lfr-asset-categories {
  color: #7d7d7d;
}
.lfr-asset-column-details .lfr-asset-categories .lfr-asset-category {
  color: #555;
}
.lfr-asset-column-details .lfr-asset-description {
  color: #444;
  font-style: italic;
  margin: 0.5em auto 2em;
  -ms-hyphens: none;
  -webkit-hyphens: none;
  hyphens: none;
}
.lfr-asset-column-details .lfr-asset-icon {
  border-right: 1px solid transparent;
  color: #999;
  float: left;
  line-height: 1em;
  margin-right: 10px;
  padding-right: 10px;
}
.lfr-asset-column-details .lfr-asset-icon.last {
  border-width: 0;
}
.lfr-asset-column-details .lfr-asset-tags {
  color: #7d7d7d;
}
.lfr-asset-column-details .lfr-asset-tags .tag {
  color: #555;
}
.lfr-asset-column-details .lfr-asset-metadata {
  clear: both;
  margin-bottom: 1.5em;
  padding-bottom: 1.5em;
}
.lfr-asset-column-details .lfr-panel {
  clear: both;
  margin-bottom: 0.2em;
}
.lfr-asset-column-details .lfr-panel.lfr-extended {
  border: 1px solid #ccc;
  margin-bottom: 0;
}
.lfr-asset-column-details .taglib-custom-attributes-list label,
.lfr-asset-column-details .lfr-asset-field label {
  display: block;
}
.lfr-asset-column-details .taglib-custom-attributes-list {
  margin-bottom: 1em;
}

.overlay {
  position: absolute;
}

.overlay-hidden,
.overlaymask-hidden {
  display: none;
}

.lfr-form-row {
  border-bottom: 1px solid #ccc;
  margin-bottom: 10px;
  margin-top: 10px;
  padding: 1px 5px 25px;
  position: relative;
}
.lfr-form-row:after {
  clear: both;
  content: "";
  display: block;
  height: 0;
}
.lfr-form-row:hover {
  border: solid #ccc;
  border-width: 1px 0;
  padding-top: 0;
}
.lfr-form-row.lfr-form-row-inline .form-group {
  margin-right: 5px;
}
.lfr-form-row legend .field-label {
  float: left;
  margin-right: 10px;
}
.lfr-form-row .handle-sort-vertical {
  background: url(../images/application/handle_sort_vertical.png) no-repeat 0 50%;
  cursor: move;
  padding-left: 20px;
}
.lfr-form-row fieldset {
  border-width: 0;
  margin: 0;
  padding: 0;
}

.lfr-autorow-controls {
  bottom: 5px;
  position: absolute;
  right: 5px;
}

.datepicker-popover-content .popover-content {
  padding: 0.75rem 1rem;
}

.dropdown.open > .dropdown-menu, .overlay-content .open > .dropdown-menu {
  display: block;
}

.user-avatar-link {
  display: block;
  position: relative;
}
.user-avatar-link .panel-notifications-count {
  display: block;
  margin: 0;
  max-width: none;
  position: absolute;
  right: calc(100% - 0.7rem);
  top: -0.4rem;
}
.user-avatar-link .text-default {
  align-items: center;
  display: flex;
}
.user-avatar-link .text-default .user-full-name {
  margin-left: 0.5rem;
}
@media (max-width: 575.98px) {
  .user-avatar-link .text-default .user-full-name {
    display: none;
  }
}

.user-personal-bar .fieldset {
  position: relative;
}
.user-personal-bar .user-avatar-link .panel-notifications-count {
  right: calc(100% - 1rem);
  top: -0.6rem;
}

.form-control-inline {
  background-color: transparent;
  font-size: 1.125rem;
  font-weight: 700;
}
.form-control-inline:not(:hover) {
  border-color: transparent;
}
.form-control-inline::placeholder {
  color: #a9afb5;
  font-style: italic;
}

.form-search .input-group {
  position: relative;
}
.form-search .input-group.advanced-search .search-query {
  padding-left: 40px;
  z-index: 0;
}
.form-search .input-group.advanced-search .toggle-advanced {
  cursor: pointer;
  left: 0;
  line-height: 1;
  padding: 8px 10px;
  position: absolute;
  top: 0;
}
.form-search .input-group.advanced-search .toggle-advanced .caret {
  margin-top: 7px;
}
.form-search .input-group.advanced-search .toggle-advanced .icon-search {
  font-size: 14px;
}
@media (max-width: 991.98px) {
  .form-search .input-group {
    width: 100%;
  }
  .form-search .input-group .btn {
    clip: rect(0, 0, 0, 0);
    left: -9999px;
    position: absolute;
  }
  .form-search .input-group input.search-query {
    width: 100%;
  }
}

.lfr-table {
  border-collapse: collapse;
  clear: both;
}
.lfr-table > tbody > tr > td,
.lfr-table > tbody > tr > th,
.lfr-table > thead > tr > td,
.lfr-table > thead > tr > th,
.lfr-table > tfoot > tr > td,
.lfr-table > tfoot > tr > th {
  padding: 0 5px;
  overflow-wrap: break-all;
  word-wrap: break-all;
}
.lfr-table > tbody > tr > td:first-child, .lfr-table > tbody > tr > td.first-child,
.lfr-table > tbody > tr > th:first-child,
.lfr-table > tbody > tr > th.first-child,
.lfr-table > thead > tr > td:first-child,
.lfr-table > thead > tr > td.first-child,
.lfr-table > thead > tr > th:first-child,
.lfr-table > thead > tr > th.first-child,
.lfr-table > tfoot > tr > td:first-child,
.lfr-table > tfoot > tr > td.first-child,
.lfr-table > tfoot > tr > th:first-child,
.lfr-table > tfoot > tr > th.first-child {
  padding-left: 0;
}
.lfr-table > tbody > tr > td:last-child, .lfr-table > tbody > tr > td.last-child,
.lfr-table > tbody > tr > th:last-child,
.lfr-table > tbody > tr > th.last-child,
.lfr-table > thead > tr > td:last-child,
.lfr-table > thead > tr > td.last-child,
.lfr-table > thead > tr > th:last-child,
.lfr-table > thead > tr > th.last-child,
.lfr-table > tfoot > tr > td:last-child,
.lfr-table > tfoot > tr > td.last-child,
.lfr-table > tfoot > tr > th:last-child,
.lfr-table > tfoot > tr > th.last-child {
  padding-right: 0;
}
.lfr-table > tbody > tr > th,
.lfr-table > thead > tr > th,
.lfr-table > tfoot > tr > th {
  font-weight: bold;
}

.lfr-pagination:after {
  clear: both;
  content: "";
  display: block;
  height: 0;
  visibility: hidden;
}
.lfr-pagination .dropdown-menu {
  display: none;
}
.lfr-pagination .dropdown-toggle .icon-caret-down {
  margin-left: 5px;
}
.lfr-pagination .lfr-pagination-controls {
  float: left;
}
.lfr-pagination .lfr-pagination-controls .search-results {
  display: inline-block;
  margin-left: 10px;
  margin-top: 5px;
  top: 10px;
}
.lfr-pagination .lfr-pagination-controls li .lfr-pagination-link {
  border-width: 0;
  clear: both;
  color: #333;
  display: block;
  font-weight: normal;
  line-height: 20px;
  padding: 3px 20px;
  text-align: left;
  white-space: nowrap;
  width: 100%;
}
.lfr-pagination .lfr-pagination-delta-selector {
  float: left;
}
@media (max-width: 991.98px) {
  .lfr-pagination .lfr-pagination-delta-selector .lfr-icon-menu-text {
    display: none;
  }
}
.lfr-pagination .pagination-content {
  float: right;
}

.lfr-panel.lfr-extended {
  border: 1px solid transparent;
  border-color: #dedede #bfbfbf #bfbfbf #dedede;
}
.lfr-panel.lfr-extended.lfr-collapsible .lfr-panel-button {
  display: block;
}
.lfr-panel.lfr-extended.lfr-collapsed .lfr-panel-titlebar {
  border-bottom-width: 0;
}
.lfr-panel.panel-default .panel-heading {
  border-bottom-width: 0;
}
.lfr-panel .toggler-header {
  cursor: pointer;
}

.sidebar-sm .sheet-subtitle {
  font-size: 0.75rem;
  margin-bottom: 1rem;
}
.sidebar-sm .form-control[type=file] {
  padding: 0;
}
.sidebar-sm .article-content-description .input-localized.input-localized-editor .input-group-item .wrapper .form-control {
  min-height: auto;
  padding: 0.285rem 0.75rem;
}
.sidebar-sm .list-group-item-flex {
  padding: 0.5rem 0.25rem;
}
.sidebar-sm .list-group-item-flex .autofit-col {
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.lfr-translation-manager {
  border-radius: 4px;
  display: inline-block;
  margin-top: 0.5em;
  min-height: 1.8em;
}
.lfr-translation-manager .lfr-translation-manager-content .lfr-translation-manager-default-locale {
  display: inline-block;
  width: auto;
}
.lfr-translation-manager .lfr-translation-manager-content .lfr-translation-manager-icon-menu {
  float: none;
  padding: 0.4em 0;
}
.lfr-translation-manager .lfr-translation-manager-content .lfr-translation-manager-icon-menu li,
.lfr-translation-manager .lfr-translation-manager-content .lfr-translation-manager-icon-menu li strong {
  display: inline;
}
.lfr-translation-manager .lfr-translation-manager-content .lfr-translation-manager-translations-message {
  margin: 10px 0;
}
.lfr-translation-manager .lfr-translation-manager-available-translations {
  white-space: normal;
}
.lfr-translation-manager .lfr-translation-manager-available-translations .lfr-translation-manager-available-translations-links {
  line-height: 1;
}
.lfr-translation-manager .lfr-translation-manager-translation {
  border: 1px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  display: inline-block;
  margin: 0.2em;
  padding: 0.4em 0.3em 0.4em 0.5em;
  text-decoration: none;
}
.lfr-translation-manager .lfr-translation-manager-translation * {
  vertical-align: middle;
}
.lfr-translation-manager .lfr-translation-manager-translation img {
  margin-right: 0.3em;
}
.lfr-translation-manager .lfr-translation-manager-translation:hover {
  background-color: #d1e5ef;
}
.lfr-translation-manager .lfr-translation-manager-translation.lfr-translation-manager-translation-editing {
  background-color: #598bec;
  border-color: #224fa8;
  color: #fff;
}
.lfr-translation-manager .lfr-translation-manager-change-default-locale {
  margin: 0 0.4em;
}
.lfr-translation-manager .lfr-translation-manager-delete-translation {
  display: inline-block;
  padding: 0 2px;
}
.lfr-translation-manager .lfr-translation-manager-delete-translation svg {
  pointer-events: none;
}

.lfr-tree a {
  text-decoration: none;
}
.lfr-tree li {
  margin-bottom: 2px;
  padding-left: 0;
}
.lfr-tree li ul li, .lfr-tree li.tree-item {
  padding-left: 0;
}
.lfr-tree li.tree-item {
  padding-left: 5px;
}
.lfr-tree li.tree-item li {
  padding-left: 20px;
}
.lfr-tree li.tree-item ul {
  margin-left: 0;
  margin-top: 5px;
}

.lfr-upload-container {
  margin-bottom: 1rem;
}
.lfr-upload-container .upload-target {
  border: 3px dashed #e5e7e9;
  margin-bottom: 1rem;
  min-height: 2rem;
  padding: 2rem 0;
  position: relative;
  text-align: center;
}
.upload-drop-intent .lfr-upload-container .upload-target {
  z-index: 100;
}
.upload-drop-active .lfr-upload-container .upload-target {
  background-color: #92e5a5;
  border-color: #69db83;
}
.lfr-upload-container .upload-target .drop-file-text {
  font-weight: normal;
}
.mobile .lfr-upload-container .upload-target .drop-file-text {
  display: none;
}
.lfr-upload-container .upload-target .small {
  display: block;
  margin: 5px 0;
  text-transform: lowercase;
}
.lfr-upload-container .manage-upload-target {
  padding-top: 5px;
  position: relative;
}
.lfr-upload-container .manage-upload-target .select-files {
  float: left;
  line-height: 0;
  margin: 0 1.125rem 1.125rem;
  padding: 0 0 0 5px;
}
.lfr-upload-container .cancel-uploads,
.lfr-upload-container .clear-uploads {
  background-repeat: no-repeat;
  float: right;
}
.lfr-upload-container .cancel-uploads {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAAnFBMVEX////4YWP/dXjyS07/dXj9bXD6a234YWP4XWD2WVv2VFfsOTzoLzHmKSvkISP2VFf0TE/vREftPT/iHB72WVvvREf0TE//hon/gYX/fYD/e33/dXj/cXP9bXD/a236a23/Zmb4YWP4XWD/Wl32WVv/VVj2VFf3VFb0TE/yS072SUvvREfuQELtPT/sOTzrMzXoLzHnLC/mKSvkISPh2jkWAAAAF3RSTlMAESIiMzMzMzMzMzMzMzNERERERHd3qtw8lzkAAACOSURBVHjaZcjZDsIgEIXhcd+tu5YBKUixttS6vP+7OQKJTfxvTr4D7Tpxu/2w410SjDjwVvLQ805TPiRryfQeKM6OTI68K/BJPHGlJZJjSqSMofEOGXbJecsTgzkds58V5+J8refBU7Jx9yIrmkW0sA6gqbLyuaRjZZWtgXq58rEFan0jf3uTfRuIkf/7AO8DDcVPSSG3AAAAAElFTkSuQmCC);
  margin-right: 0;
}
.lfr-upload-container .clear-uploads {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAAdVBMVEX///+6QwTEVx65RQPEVx3EWB64RQPDVxq5RAO5RAO5RQPATQ65RQO5RQO5RQPRczjJZCW9TQTLay28QgTdZAHhaAPmdyHqeQXrikDudgDvfxj0nWP1qHL2tY33tY34dgD+za7+1rj/dxH/fxj/hiH/kk3///9TM3sUAAAAFHRSTlMAbXd4eHh6gN3e3+Hi4+T5+/z8/mIsq5IAAABHSURBVBjTY2CgGWDlFuZhRuIz8cspyggxIgQ4ZFWVVCQ4EQLCCmpqalLCCAFeaWV5SVE+hAC7gJi4iCAbkqksXMK8bNRzNADCOQN++eLhCQAAAABJRU5ErkJggg==);
  padding-left: 16px;
}
.lfr-upload-container .upload-file.upload-complete.file-saved {
  padding-left: 25px;
}
.lfr-upload-container .upload-file .file-title {
  display: inline-block;
  max-width: 95%;
  overflow: hidden;
  padding-right: 16px;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
}
.lfr-upload-container .upload-file .icon-file {
  font-size: 40px;
}
.lfr-upload-container .upload-list-info {
  margin: 1em 0 0.5em;
}
.lfr-upload-container .upload-list-info .h4,
.lfr-upload-container .upload-list-info h4 {
  font-size: 1.3em;
}
.lfr-upload-container .cancel-button {
  color: #6c757d;
  margin-top: 1px;
  position: absolute;
  right: 5px;
  top: 50%;
  white-space: nowrap;
}
.lfr-upload-container .cancel-button .cancel-button-text {
  display: none;
  margin-left: 5px;
}
.lfr-upload-container .cancel-button:hover .cancel-button-text {
  display: inline;
}
.lfr-upload-container .cancel-button .lexicon-icon {
  height: 12px;
}
.lfr-upload-container .delete-button {
  color: #6c757d;
}
.lfr-upload-container .delete-button-col {
  padding-right: 10px;
}
.lfr-upload-container .file-added .success-message {
  float: right;
  font-weight: normal;
}
.lfr-upload-container .upload-error {
  opacity: 1;
  padding-left: 25px;
}
.lfr-upload-container .upload-complete .cancel-button,
.lfr-upload-container .delete-button,
.lfr-upload-container .upload-complete.file-saved .delete-button,
.lfr-upload-container .upload-complete.upload-error .delete-button {
  display: none;
}
.lfr-upload-container .multiple-files .upload-error {
  background: #f5c4c9 url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABGdBTUEAAK/INwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAJPSURBVDjLpZPLS5RhFMYfv9QJlelTQZwRb2OKlKuINuHGLlBEBEOLxAu46oL0F0QQFdWizUCrWnjBaDHgThCMoiKkhUONTqmjmDp2GZ0UnWbmfc/ztrC+GbM2dXbv4ZzfeQ7vefKMMfifyP89IbevNNCYdkN2kawkCZKfSPZTOGTf6Y/m1uflKlC3LvsNTWArr9BT2LAf+W73dn5jHclIBFZyfYWU3or7T4K7AJmbl/yG7EtX1BQXNTVCYgtgbAEAYHlqYHlrsTEVQWr63RZFuqsfDAcdQPrGRR/JF5nKGm9xUxMyr0YBAEXXHgIANq/3ADQobD2J9fAkNiMTMSFb9z8ambMAQER3JC1XttkYGGZXoyZEGyTHRuBuPgBTUu7VSnUAgAUAWutOV2MjZGkehgYUA6O5A0AlkAyRnotiX3MLlFKduYCqAtuGXpyH0XQmOj+TIURt51OzURTYZdBKV2UBSsOIcRp/TVTT4ewK6idECAihtUKOArWcjq/B8tQ6UkUR31+OYXP4sTOdisivrkMyHodWejlXwcC38Fvs8dY5xaIId89VlJy7ACpCNCFCuOp8+BJ6A631gANQSg1mVmOxxGQYRW2nHMha4B5WA3chsv22T5/B13AIicWZmNZ6cMchTXUe81Okzz54pLi0uQWp+TmkZqMwxsBV74Or3od4OISPr0e3SHa3PX0f3HXKofNH/UIG9pZ5PeUth+CyS2EMkEqs4fPEOBJLsyske48/+xD8oxcAYPzs4QaS7RR2kbLTTOTQieczfzfTv8QPldGvTGoF6/8AAAAASUVORK5CYII=) no-repeat 5px 5px;
  border-color: #bd2130;
  color: #bd2130;
  font-weight: normal;
  margin-bottom: 16px;
  padding: 8px 8px 8px 24px;
}
.lfr-upload-container .multiple-files .upload-error .error-message {
  display: block;
}
.lfr-upload-container .multiple-files .upload-complete.file-saved .form-check-middle-left .card-body,
.lfr-upload-container .multiple-files .upload-complete.upload-error .form-check-middle-left .card-body {
  padding-left: 1rem;
}
.lfr-upload-container .multiple-files .upload-complete.file-saved .form-check-middle-left .custom-control-label,
.lfr-upload-container .multiple-files .upload-complete.upload-error .form-check-middle-left .custom-control-label {
  display: none;
}
.lfr-upload-container .single-file .upload-error {
  list-style: none;
  margin-top: 1em;
}
.lfr-upload-container .single-file .upload-error .upload-error-message {
  margin-bottom: 0.5em;
}
.lfr-upload-container .upload-complete {
  padding-left: 5px;
}
.lfr-upload-container .upload-complete .error-message,
.lfr-upload-container .upload-complete .success-message {
  font-weight: bold;
  margin-left: 1em;
}
.lfr-upload-container .upload-complete .delete-button {
  display: inline-block;
}
.lfr-upload-container .upload-complete .select-file:disabled + .custom-control-label {
  display: none;
}
.lfr-upload-container .progress {
  display: none;
  margin-top: 0.5rem;
}
.lfr-upload-container .file-uploading .progress {
  display: flex;
}

.lfr-alert-container {
  left: 0;
  position: absolute;
  right: auto;
  top: auto;
  width: 100%;
  z-index: 430;
}
.lfr-alert-container.inline-alert-container {
  position: relative;
}
.lfr-alert-container.inline-alert-container .lfr-alert-wrapper {
  padding: 0;
}
.lfr-alert-container .lfr-alert-wrapper {
  margin-bottom: 5px;
  overflow: hidden;
}

.lfr-search-container td .overlay.entry-action {
  position: static;
}
.lfr-search-container td .overlay.entry-action .btn a {
  display: block;
  padding: 4px 12px;
}

.contextual-sidebar {
  height: calc(
		100vh - var(--control-menu-container-height) - 49px
	);
  pointer-events: none;
  position: fixed;
  right: 0;
  top: calc(var(--control-menu-container-height) + 49px);
  transform: translateX(100%);
  transition: transform ease 0.5s;
  visibility: hidden;
  width: 320px;
  will-change: transform;
}
.contextual-sidebar.contextual-sidebar-visible {
  pointer-events: auto;
  transform: translateX(0);
  visibility: visible;
}

@media (min-width: 768px) {
  .contextual-sidebar {
    height: calc(
			100vh - var(--control-menu-container-height) - 64px
		);
    top: calc(
			var(--control-menu-container-height) + 64px
		);
  }
  .contextual-sidebar-content {
    transition: padding ease 0.5s;
    will-change: padding;
  }
  .contextual-sidebar-visible .contextual-sidebar-content,
  .contextual-sidebar-visible + .contextual-sidebar-content {
    padding-right: 320px;
  }
}
.taglib-diff-html div.diff-removed-image {
  background: #fdc6c6 url(../images/diff/minus.png);
}
.taglib-diff-html div.diff-added-image {
  background: #cfc url(../images/diff/plus.png) no-repeat;
}
.taglib-diff-html div.diff-removed-image, .taglib-diff-html div.diff-added-image {
  height: 300px;
  margin: 2px;
  opacity: 0.55;
  position: absolute;
  width: 200px;
}
.taglib-diff-html span.diff-html-added {
  background-color: #cfc;
  font-size: 1em;
}
.taglib-diff-html span.diff-html-added img {
  border: 2px solid #cfc;
}
.taglib-diff-html span.diff-html-changed {
  background: url(../images/diff/underline.png) bottom repeat-x;
}
.taglib-diff-html span.diff-html-changed img {
  border: 2px dotted #009;
}
.taglib-diff-html span.diff-html-removed {
  background-color: #fdc6c6;
  font-size: 1em;
  text-decoration: line-through;
}
.taglib-diff-html span.diff-html-removed img {
  border: 2px solid #fdc6c6;
}

.taglib-discussion {
  font-size: 0.875rem;
  margin-top: 1rem;
}
.taglib-discussion .actions-menu .component-action {
  display: inline-flex;
}
.taglib-discussion .button-holder {
  margin: 1rem 0;
}
.taglib-discussion .comment-container {
  margin-bottom: 1.5rem;
}
.taglib-discussion .lfr-discussion .lfr-discussion-form-edit .alloy-editor-placeholder {
  border-left-color: #dbdde1;
}
.taglib-discussion .lfr-discussion-body {
  font-size: 1rem;
}
@media (min-width: 576px) {
  .taglib-discussion .lfr-discussion-body {
    padding-left: 3.5rem;
  }
}
@media (min-width: 576px) {
  .taglib-discussion .lfr-discussion-details .taglib-user-display {
    word-wrap: break-word;
  }
}
.taglib-discussion .lfr-discussion-details .taglib-user-display .user-details .user-name {
  font-weight: bold;
  text-decoration: none;
}
.taglib-discussion .lfr-discussion-details .taglib-user-display .user-details .user-name:hover {
  text-decoration: underline;
}
.taglib-discussion .lfr-discussion-details .taglib-user-display .user-profile-image .avatar {
  background-size: 50px;
}
.taglib-discussion .lfr-discussion-container {
  border-bottom: 1px solid #e7e7ed;
  margin-bottom: 1.5rem;
}
.taglib-discussion .lfr-discussion-container:first-of-type {
  border-top: 1px solid #e7e7ed;
  padding-top: 1.5rem;
}
.taglib-discussion .lfr-discussion-container:last-of-type {
  border-bottom: 0;
}
.taglib-discussion .lfr-discussion-container .lfr-discussion {
  padding-left: 1rem;
}
.taglib-discussion .lfr-discussion-container .lfr-discussion .lfr-discussion .lfr-discussion .lfr-discussion {
  padding-left: 0;
}
@media (min-width: 576px) {
  .taglib-discussion .lfr-discussion-container .lfr-discussion {
    padding-left: 3.5rem;
  }
}
.taglib-discussion .lfr-discussion-parent-link {
  color: #67678c;
  font-weight: 600;
  margin-left: 1em;
}
@media (max-width: 767.98px) {
  .taglib-discussion .lfr-discussion-parent-link {
    display: block;
    margin-left: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}
.taglib-discussion .lfr-discussion-controls .autofit-col:first-of-type > .btn-outline-borderless {
  margin-left: -0.75rem;
}
.taglib-discussion .lfr-discussion-more-comments {
  border-top: 1px solid #e7e7ed;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  text-align: center;
}
.taglib-discussion .username {
  color: #272833;
  font-weight: 600;
}
.taglib-discussion .taglib-workflow-status {
  margin-left: 0.5rem;
}
.taglib-discussion .workflow-value {
  text-transform: uppercase;
}
@media (min-width: 576px) {
  .taglib-discussion .actions-menu {
    display: none;
  }
  .taglib-discussion .comment-container:hover .actions-menu,
  .taglib-discussion .actions-menu:focus,
  .taglib-discussion .actions-menu.open {
    display: inline-block;
  }
}

.drop-zone {
  min-height: 80px;
  padding: 20px;
  text-align: center;
}
.drop-zone.drop-enabled {
  outline: 2px dashed transparent;
}
.drop-zone.drop-enabled:not(.no-border) {
  outline-color: rgba(176, 180, 187, 0.5);
}
.drop-zone p {
  margin: 10px auto 0;
  max-width: 75%;
}

.drop-here-info {
  font-size: 25px;
  height: 100%;
  left: 0;
  min-height: 100px;
  opacity: 0;
  position: absolute;
  text-align: center;
  top: 0;
  visibility: hidden;
  width: 100%;
  transition: all 0.2s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .drop-here-info {
    transition: none;
  }
}
.drop-here-info {
  transition: none;
}

.drop-here-info .drop-here-indicator {
  height: 115px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(0, -50%);
}
.drop-here-info .drop-icons {
  display: inline-block;
  position: relative;
  width: 160px;
  transition: all 0.2s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .drop-here-info .drop-icons {
    transition: none;
  }
}
.drop-here-info .drop-icons {
  transition: none;
}

.drop-here-info .drop-icons span {
  border-radius: 3px;
  position: absolute;
  text-align: center;
  transition: all 0.3s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .drop-here-info .drop-icons span {
    transition: none;
  }
}
.drop-here-info .drop-icons span {
  transition: none;
}

.drop-here-info .drop-icons span:nth-of-type(1) {
  box-shadow: 5px 4px 0 0 rgba(0, 0, 0, 0.08);
  height: 60px;
  left: 0;
  line-height: 60px;
  opacity: 0;
  top: 10px;
  transform: rotate(25deg);
  width: 60px;
}
.drop-here-info .drop-icons span:nth-of-type(2) {
  background: #00c2ff;
  color: #fff;
  height: 80px;
  left: 40px;
  line-height: 80px;
  width: 80px;
  z-index: 2;
}
.drop-here-info .drop-icons span:nth-of-type(3) {
  box-shadow: -5px 4px 0 0 rgba(0, 0, 0, 0.08);
  display: block;
  font-size: 45px;
  height: 70px;
  left: 90px;
  line-height: 70px;
  opacity: 0;
  position: relative;
  top: 8px;
  transform: rotate(-25deg);
  width: 70px;
  z-index: 1;
}
.drop-here-info .drop-icons span:nth-of-type(1), .drop-here-info .drop-icons span:nth-of-type(3) {
  background: #e8e6e8;
  color: #a5a6ac;
}
.drop-here-info .drop-text {
  color: #fff;
  display: block;
  font-size: 20px;
  margin-left: 0;
  margin-top: 20px;
}
.drop-active .drop-here-info {
  background-color: rgba(0, 0, 0, 0.6);
  opacity: 1;
  visibility: visible;
  z-index: 100;
}
.drop-active .drop-here-info .drop-icons span:nth-of-type(1), .drop-active .drop-here-info .drop-icons span:nth-of-type(3) {
  opacity: 1;
}
.drop-active .drop-here-info span:nth-of-type(1) {
  transform: rotate(-20deg);
}
.drop-active .drop-here-info span:nth-of-type(2) {
  transform: scale(1);
}
.drop-active .drop-here-info span:nth-of-type(3) {
  transform: rotate(15deg);
}

.taglib-empty-result-message.sheet {
  margin-bottom: 24px;
}
.taglib-empty-result-message .taglib-empty-result-message-description {
  color: #6c757d;
  margin-top: 8px;
}
.taglib-empty-result-message .taglib-empty-result-message-header,
.taglib-empty-result-message .taglib-empty-result-message-header-has-plus-btn,
.taglib-empty-result-message .taglib-empty-search-result-message-header {
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100%;
  margin-left: auto;
  margin-right: auto;
}
.taglib-empty-result-message .taglib-empty-result-message-header,
.taglib-empty-result-message .taglib-empty-result-message-header-has-plus-btn {
  max-width: 200px;
  padding-top: 250px;
}
.taglib-empty-result-message .taglib-empty-result-message-header,
.taglib-empty-result-message .taglib-empty-result-message-header-has-plus-btn {
  background-image: url(../images/states/empty_state.svg);
}
@media (prefers-reduced-motion: reduce) {
  .taglib-empty-result-message .taglib-empty-result-message-header,
  .taglib-empty-result-message .taglib-empty-result-message-header-has-plus-btn {
    background-image: url(../images/states/empty_state_reduced_motion.svg);
  }
}
.c-prefers-reduced-motion .taglib-empty-result-message .taglib-empty-result-message-header,
.c-prefers-reduced-motion .taglib-empty-result-message .taglib-empty-result-message-header-has-plus-btn {
  background-image: url(../images/states/empty_state_reduced_motion.svg);
}
.taglib-empty-result-message .taglib-empty-search-result-message-header {
  background-image: url(../images/states/search_state.svg);
  max-width: 210px;
  padding-top: 232px;
}
@media (prefers-reduced-motion: reduce) {
  .taglib-empty-result-message .taglib-empty-search-result-message-header {
    background-image: url(../images/states/search_state_reduced_motion.svg);
  }
}
.c-prefers-reduced-motion .taglib-empty-result-message .taglib-empty-search-result-message-header {
  background-image: url(../images/states/search_state_reduced_motion.svg);
}
.taglib-empty-result-message .taglib-empty-state {
  background-image: url(../images/states/empty_state.svg);
  margin: auto;
  max-width: 250px;
  padding-top: 250px;
}
@media (prefers-reduced-motion: reduce) {
  .taglib-empty-result-message .taglib-empty-state {
    background-image: url(../images/states/empty_state_reduced_motion.svg);
  }
}
.c-prefers-reduced-motion .taglib-empty-result-message .taglib-empty-state {
  background-image: url(../images/states/empty_state_reduced_motion.svg);
}
.taglib-empty-result-message .taglib-success-state {
  background-image: url(../images/states/success_state.svg);
  margin: auto;
  max-width: 250px;
  padding-top: 250px;
}
@media (prefers-reduced-motion: reduce) {
  .taglib-empty-result-message .taglib-success-state {
    background-image: url(../images/states/success_state_reduced_motion.svg);
  }
}
.c-prefers-reduced-motion .taglib-empty-result-message .taglib-success-state {
  background-image: url(../images/states/success_state_reduced_motion.svg);
}
.taglib-empty-result-message .taglib-search-state {
  background-image: url(../images/states/search_state.svg);
  margin: auto;
  max-width: 250px;
  padding-top: 250px;
}
@media (prefers-reduced-motion: reduce) {
  .taglib-empty-result-message .taglib-search-state {
    background-image: url(../images/states/search_state_reduced_motion.svg);
  }
}
.c-prefers-reduced-motion .taglib-empty-result-message .taglib-search-state {
  background-image: url(../images/states/search_state_reduced_motion.svg);
}
.taglib-empty-result-message .taglib-empty-result-message-title {
  font-size: 1rem;
  margin-top: 48px;
}
.taglib-empty-result-message .taglib-empty-result-message-description {
  font-size: 0.875rem;
}
.taglib-empty-result-message .taglib-empty-result-message-header + .taglib-empty-result-message-title,
.taglib-empty-result-message .taglib-empty-search-result-message-header + .taglib-empty-result-message-title,
.taglib-empty-result-message .taglib-empty-state + .taglib-empty-result-message-title,
.taglib-empty-result-message .taglib-success-state + .taglib-empty-result-message-title,
.taglib-empty-result-message .taglib-search-state + .taglib-empty-result-message-title {
  font-size: 1.25rem;
  font-weight: bold;
  text-align: center;
}
.taglib-empty-result-message .taglib-empty-result-message-header ~ .taglib-empty-result-message-description, .taglib-empty-result-message .taglib-empty-result-message-header ~ .taglib-empty-result-message-actions,
.taglib-empty-result-message .taglib-empty-search-result-message-header ~ .taglib-empty-result-message-description,
.taglib-empty-result-message .taglib-empty-search-result-message-header ~ .taglib-empty-result-message-actions,
.taglib-empty-result-message .taglib-empty-state ~ .taglib-empty-result-message-description,
.taglib-empty-result-message .taglib-empty-state ~ .taglib-empty-result-message-actions,
.taglib-empty-result-message .taglib-success-state ~ .taglib-empty-result-message-description,
.taglib-empty-result-message .taglib-success-state ~ .taglib-empty-result-message-actions,
.taglib-empty-result-message .taglib-search-state ~ .taglib-empty-result-message-description,
.taglib-empty-result-message .taglib-search-state ~ .taglib-empty-result-message-actions {
  font-size: 1rem;
  text-align: center;
}

.field-wrapper.form-inline .control-label {
  display: inline-block;
}

.field-wrapper-html .input-localized .input-group-item {
  flex-wrap: nowrap;
}

.taglib-header {
  border-bottom: 1px solid #c8c9ca;
  color: #555;
  margin-bottom: 1em;
  padding-bottom: 10px;
}
.taglib-header .header-title {
  display: inline-block;
  margin: 0.1em;
  max-width: 100%;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
  word-wrap: normal;
}
.taglib-header .header-back-to {
  display: inline-block;
  vertical-align: middle;
}
.taglib-header .header-back-to a {
  display: block;
  font-weight: bold;
  padding: 0 0.3em 0 0;
  text-decoration: none;
}

.taglib-icon {
  text-decoration: none;
}
.taglib-icon:not(.btn):hover .taglib-text, .taglib-icon:not(.btn):focus .taglib-text {
  text-decoration: underline;
}
.taglib-icon[lang] > img {
  vertical-align: baseline;
  width: 16px;
}

.taglib-icon-help {
  color: #6c757d !important;
}
.taglib-icon-help:hover, .taglib-icon-help:active {
  color: #343a40 !important;
}

.icon-monospaced {
  color: inherit;
  display: inline-block;
  height: 2rem;
  line-height: 34px;
  text-align: center;
  width: 2rem;
}
.icon-monospaced.lexicon-icon {
  padding: 8px;
}

.taglib-icon-list li {
  float: left;
  margin-right: 1em;
}
.taglib-icon-list:after {
  clear: both;
  content: "";
  display: block;
  height: 0;
  visibility: hidden;
}

.lfr-icon-menu .lfr-icon-menu-icon {
  max-width: none;
}
@media (max-width: 767.98px) {
  .table-cell.last .lfr-icon-menu .dropdown-toggle {
    text-align: center;
  }
  .table-cell.last .lfr-icon-menu .dropdown-toggle > img,
  .table-cell.last .lfr-icon-menu .dropdown-toggle .lfr-icon-menu-text {
    display: none;
  }
}

.lfr-menu-list {
  float: none;
  overflow-y: auto;
  position: relative;
}
.lfr-menu-list.direction-right {
  margin: 0 2px;
}
.lfr-menu-list.dropdown-menu {
  float: none;
  position: relative;
}
@media (max-width: 991.98px) {
  .lfr-menu-list.dropdown-menu > li > a {
    font-size: 22px;
    line-height: 40px;
    white-space: normal;
  }
  .lfr-menu-list.dropdown-menu > li > a img {
    margin-bottom: 3px;
  }
}
.lfr-menu-list.dropdown-menu .search-panel {
  margin-bottom: 0;
}
.lfr-menu-list.dropdown-menu .search-panel .form-group {
  margin: 0 16px;
}
.lfr-menu-list.dropdown-menu .search-panel .menu-item-filter {
  width: auto;
}
body > .lfr-menu-list ul {
  border-radius: 4px;
}

.lfr-icon-menu-open:after {
  clear: both;
  content: "";
  display: table;
}
.lfr-icon-menu-open .dropdown-menu {
  position: static;
}

.input-localized.input-localized-editor .form-control {
  border-width: 0;
  height: 100%;
  padding: 0;
}
.input-localized .input-group-item {
  flex-direction: column;
}
.input-localized .input-localized-content {
  margin-left: 6px;
}
.input-group .input-localized .input-localized-content {
  margin-top: 3px;
}
.input-localized .lfr-input-localized .lfr-input-localized-state {
  background-color: #ddd;
}
.input-localized .lfr-input-localized .lfr-input-localized-state.lfr-input-localized-state-error {
  background-color: #ff0047;
}
.input-localized .lfr-input-localized-default a {
  margin-right: 14px;
}
.input-localized .lfr-input-localized-state {
  height: 4px;
  margin: 3px 5px;
  width: 4px;
}
.input-localized .palette-item-inner .lfr-input-localized-flag {
  font-size: 16px;
  opacity: 0.5;
}
.input-localized .palette-item,
.input-localized .palette-item-hover,
.input-localized .palette-item-hover .palette-item-inner {
  border-color: transparent;
}
.input-localized .palette-item-inner {
  border-color: #666;
  display: block;
  height: 16px;
  width: 16px;
}
.input-localized .palette-item-selected .lfr-input-localized-state {
  background: #27c1f2;
}

.input-localized-palette-container .palette-items-container {
  font-size: 0;
  margin: 0;
  white-space: normal;
}
.input-localized-palette-container .palette-item {
  border-width: 0;
  padding: 0.5rem 1.25rem;
}
.input-localized-palette-container .palette-item-inner {
  border: 1px solid;
  margin-right: 4px;
  width: 16px;
}
.input-localized-palette-container .palette-item-inner img {
  display: block;
}

.taglib-move-boxes {
  margin-bottom: 1em;
}
.taglib-move-boxes label {
  border-bottom: 1px solid transparent;
  display: block;
  margin-bottom: 5px;
  padding: 5px;
}
.taglib-move-boxes .toolbar {
  text-align: center;
}
.taglib-move-boxes .arrow-button img {
  border-width: 0;
  height: 16px;
  width: 16px;
}
.taglib-move-boxes .choice-selector {
  width: 100%;
}
.taglib-move-boxes .choice-selector label {
  background: #ebf1f9;
  border-bottom-color: #8db2f3;
}
.taglib-move-boxes .field-content {
  margin-bottom: 0;
}
.taglib-move-boxes .move-arrow-buttons {
  margin-top: 5em;
}
.taglib-move-boxes .move-arrow-buttons .arrow-button {
  display: block;
}
.taglib-move-boxes .sortable-container {
  margin-top: 10px;
}
.taglib-move-boxes .sortable-container .btn.edit-selection {
  margin-bottom: 10px;
}
.taglib-move-boxes .sortable-container .move-option {
  background-color: transparent;
  border-top: 1px solid #ddd;
  display: none;
  margin: 2px 0;
  padding: 2px;
  position: relative;
}
.taglib-move-boxes .sortable-container .move-option.selected {
  display: block;
}
.taglib-move-boxes .sortable-container .move-option.move-option-dragging {
  background-color: #fafafa;
}
.taglib-move-boxes .sortable-container .move-option .checkbox,
.taglib-move-boxes .sortable-container .move-option .handle {
  position: absolute;
}
.taglib-move-boxes .sortable-container .move-option .checkbox {
  display: none;
  margin: 7px 0 0 5px;
}
.taglib-move-boxes .sortable-container .move-option .handle {
  color: #999;
  cursor: pointer;
  font-size: 1.5em;
  padding: 6px;
}
.taglib-move-boxes .sortable-container .move-option .title {
  font-size: 1.2em;
  margin: 1px 0 1px 30px;
}
.taglib-move-boxes .sortable-container.edit-list-active .move-option {
  display: block;
}
.taglib-move-boxes .sortable-container.edit-list-active .move-option .checkbox {
  display: inline-block;
}
.taglib-move-boxes .sortable-container.edit-list-active .move-option .handle {
  display: none;
}
.mobile .taglib-move-boxes .selector-container {
  display: none;
}

.item-selector .card-row > .autofit-col-expand {
  padding-top: 4px;
}
.item-selector .drop-zone {
  background-color: #f1f2f5;
  margin-top: 1rem;
}
.item-selector .input-file {
  height: 0.1px;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  width: 0.1px;
  z-index: -1;
}
.item-selector .input-file + label {
  position: relative;
}
.item-selector .input-file + label::before {
  border-radius: 4px;
  bottom: -2px;
  content: "";
  display: block;
  left: -2px;
  position: absolute;
  right: -2px;
  top: -2px;
  transition: box-shadow 0.15s ease-in-out;
}
.item-selector .input-file:focus + label::before {
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px #75b8ff;
}
.item-selector .item-selector-list-row:hover {
  background-color: #e5f2ff;
  cursor: pointer;
}

.lfr-map {
  border: 1px solid #ccc;
  min-height: 400px;
  width: 100%;
}
.lfr-map .home-button {
  margin: 5px;
}
@media (max-width: 575.98px) {
  .lfr-map .home-button {
    height: 35px;
    width: 45px;
  }
}
.lfr-map .search-controls {
  font-size: 15px;
  margin-top: 5px;
  width: 100%;
}
@media (min-width: 576px) {
  .lfr-map .search-controls {
    width: 50%;
  }
}
.lfr-map .search-controls .search-input {
  width: 100%;
}

.navbar .navbar-collapse {
  max-height: none;
}
.navbar .navbar-collapse:after, .navbar .navbar-collapse:before {
  display: inline;
}
@media (max-width: 767.98px) {
  .navbar .navbar-search {
    background-color: #f3f3f3;
    border-top-width: 0;
    width: 100%;
  }
}
.navbar .navbar-search .form-search {
  margin: 8px 0;
}
@media (min-width: 768px) {
  .navbar .navbar-search .form-search {
    float: right;
    max-width: 275px;
  }
}
@media (max-width: 767.98px) {
  .navbar .navbar-search .form-search .input-group {
    width: 100%;
  }
}
@media (max-width: 991.98px) {
  .navbar .container .navbar-btn,
  .navbar .container-fluid .navbar-btn {
    margin-bottom: 5px;
    width: 45px;
  }
  .navbar .container .navbar-collapse.open,
  .navbar .container-fluid .navbar-collapse.open {
    border-width: 0;
    display: block;
    height: auto;
    overflow: visible;
  }
}

.taglib-portlet-preview.show-borders {
  border: 1px solid #828f95;
  margin-bottom: 1em;
  padding: 3px 3px 1em;
}
.taglib-portlet-preview.show-borders .title {
  background-color: #d3dadd;
  font-size: 1.4em;
  font-weight: bold;
  padding: 0.5em;
}
.taglib-portlet-preview .preview {
  margin: 1em;
  min-height: 90px;
}

.lfr-search-container .entry-action {
  width: 1px;
}
.lfr-search-container .entry-action .taglib-icon {
  white-space: nowrap;
}

.lfr-search-container-wrapper.lfr-search-container-fixed-first-column {
  position: relative;
}
@media (min-width: 576px) {
  .lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive {
    margin-left: 375px;
    width: auto;
  }
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table {
  position: static;
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table .lfr-search-iterator-fixed-header {
  left: 12px;
  position: fixed;
  right: 12px;
  top: -1px;
  z-index: 1020;
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table .lfr-search-iterator-fixed-header > th {
  display: block;
  padding: 0;
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table .lfr-search-iterator-fixed-header > th .lfr-search-iterator-fixed-header-inner-wrapper {
  overflow-x: hidden;
}
@media (min-width: 576px) {
  .lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table .lfr-search-iterator-fixed-header > th .lfr-search-iterator-fixed-header-inner-wrapper {
    margin-left: 375px;
  }
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table .lfr-search-iterator-fixed-header > th .lfr-search-iterator-fixed-header-inner-wrapper table {
  border-collapse: collapse;
  width: 100%;
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table .lfr-search-iterator-fixed-header > th .lfr-search-iterator-fixed-header-inner-wrapper table th {
  border-radius: 0;
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table td,
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table th {
  width: auto;
}
@media (min-width: 576px) {
  .lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table td:first-child,
  .lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table th:first-child {
    background-color: #fff;
    left: 0;
    position: absolute;
    right: 15px;
  }
}
.lfr-search-container-wrapper.lfr-search-container-fixed-first-column .table-responsive .table th {
  height: auto;
}
.lfr-search-container-wrapper a:not(.btn):not(.component-action):not(.page-link) {
  color: #495057;
  font-weight: 500;
  text-decoration: underline;
}
.lfr-search-container-wrapper a:not(.btn):not(.component-action):not(.page-link):focus, .lfr-search-container-wrapper a:not(.btn):not(.component-action):not(.page-link):hover {
  color: #000;
}
.lfr-search-container-wrapper .dropdown-action .dropdown-toggle {
  color: #6c757d;
}
.lfr-search-container-wrapper .dropdown-action .dropdown-toggle:hover {
  color: #343a40;
}
.lfr-search-container-wrapper .lfr-icon-menu > .dropdown-toggle {
  color: #6c757d;
}
.lfr-search-container-wrapper .lfr-icon-menu > .dropdown-toggle:active, .lfr-search-container-wrapper .lfr-icon-menu > .dropdown-toggle:focus, .lfr-search-container-wrapper .lfr-icon-menu > .dropdown-toggle:hover {
  background-color: #f7f8f9;
  border-radius: 4px;
  color: #343a40;
}
.lfr-search-container-wrapper .lfr-search-container-list .list-group:last-child .list-group-item:nth-last-child(2) {
  border-bottom-left-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
}
.lfr-search-container-wrapper .lfr-search-container-list + .taglib-search-iterator-page-iterator-bottom {
  margin-top: 20px;
}
.lfr-search-container-wrapper .list-group {
  margin-bottom: 0;
}
.lfr-search-container-wrapper .list-group + .list-group .list-group-header:first-child,
.lfr-search-container-wrapper .list-group + .list-group .list-group-item:first-child {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.lfr-search-container-wrapper .list-group .list-group-item .h4,
.lfr-search-container-wrapper .list-group .list-group-item h4 {
  font-size: 0.875rem;
  line-height: 1.5;
  margin-bottom: 0;
}
.lfr-search-container-wrapper .list-group .list-group-item .h5,
.lfr-search-container-wrapper .list-group .list-group-item .h6,
.lfr-search-container-wrapper .list-group .list-group-item h5,
.lfr-search-container-wrapper .list-group .list-group-item h6 {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 0;
}
.lfr-search-container-wrapper .list-group .list-group-item span + h2.h5 {
  font-weight: 600;
}
.lfr-search-container-wrapper .list-group .list-group-item .h6 + .h5,
.lfr-search-container-wrapper .list-group .list-group-item h6 + h5 {
  font-weight: 600;
}
.lfr-search-container-wrapper .table-list tbody tr:nth-last-child(2) td:first-child,
.lfr-search-container-wrapper .table-list tbody tr:nth-last-child(2) th:first-child {
  border-bottom-left-radius: 0.25rem;
}
.lfr-search-container-wrapper .table-list tbody tr:nth-last-child(2) td:last-child,
.lfr-search-container-wrapper .table-list tbody tr:nth-last-child(2) th:last-child {
  border-bottom-right-radius: 0.25rem;
}

.user-info {
  display: flex;
}
.user-info .sticker {
  align-self: center;
}
.user-info .user-details {
  margin-left: 1rem;
}
.user-info .user-name {
  color: #343a40;
  font-weight: 600;
}
.user-info .date-info {
  color: #6c757d;
}

.user-status-tooltip .user-status-avatar {
  float: left;
  margin-right: 5px;
}
.user-status-tooltip .user-status-avatar .user-status-avatar-image {
  width: 27px;
}
.user-status-tooltip .user-status-info {
  display: inline-block;
  overflow: hidden;
}
.user-status-tooltip .user-status-info .user-status-date {
  font-size: 11px;
}

.lfr-search-container {
  margin-top: 1.5em;
  overflow: auto;
}
@media (max-width: 767.98px) {
  .lfr-search-container .selector-button {
    width: auto;
  }
}
.touch .lfr-search-container {
  -webkit-overflow-scrolling: touch;
}
.touch .lfr-search-container .searchcontainer-content .table {
  max-width: none;
}

.taglib-page-iterator {
  clear: both;
  height: auto;
  width: auto;
}
.taglib-page-iterator .lfr-pagination-buttons {
  float: right;
  margin: 0;
}
@media (max-width: 991.98px) {
  .taglib-page-iterator .lfr-pagination-buttons {
    width: 100%;
  }
}
@media (max-width: 991.98px) and (max-width: 767.98px) {
  .taglib-page-iterator .lfr-pagination-buttons {
    float: none;
    margin-top: 20px;
  }
}
@media (max-width: 991.98px) {
  .taglib-page-iterator .lfr-pagination-buttons > li {
    display: inline-block;
    width: 50%;
  }
  .taglib-page-iterator .lfr-pagination-buttons > li.first, .taglib-page-iterator .lfr-pagination-buttons > li.last {
    display: none;
  }
  .taglib-page-iterator .lfr-pagination-buttons > li > a {
    line-height: 20px;
    padding: 11px 19px;
  }
}
.taglib-page-iterator .lfr-pagination-config {
  float: left;
  line-height: 46px;
}
@media (max-width: 767.98px) {
  .taglib-page-iterator .lfr-pagination-config {
    float: none;
  }
  .taglib-page-iterator .lfr-pagination-config .current-page-menu {
    display: block;
  }
  .taglib-page-iterator .lfr-pagination-config .current-page-menu .btn {
    display: block;
  }
}
.taglib-page-iterator .lfr-pagination-config .lfr-pagination-delta-selector,
.taglib-page-iterator .lfr-pagination-config .lfr-pagination-page-selector {
  display: inline;
}
.taglib-page-iterator .lfr-pagination-config .lfr-pagination-delta-selector {
  float: none;
}
@media (max-width: 991.98px) {
  .taglib-page-iterator .lfr-pagination-config .lfr-pagination-delta-selector {
    display: none;
  }
}
.taglib-page-iterator .search-results {
  float: left;
  line-height: 46px;
  margin-left: 10px;
}
@media (max-width: 991.98px) {
  .taglib-page-iterator .search-results {
    display: none;
  }
}

@media (max-width: 991.98px) {
  ul.pagination ul.inline-scroller {
    max-height: inherit;
  }
}
.taglib-search-toggle .form-search {
  position: relative;
}
.taglib-search-toggle .form-search .input-group-btn {
  position: absolute;
}
@media (min-width: 992px) {
  .taglib-search-toggle .form-search .input-group-btn {
    position: static;
  }
}
.taglib-search-toggle .toggle-advanced {
  color: inherit;
  margin-left: 10px;
  position: absolute;
  top: 8px;
}
.taglib-search-toggle .toggle-advanced, .taglib-search-toggle .toggle-advanced:hover, .taglib-search-toggle .toggle-advanced:focus {
  text-decoration: none;
}

.taglib-search-toggle-advanced-wrapper .taglib-search-toggle-advanced {
  background-color: #fcfcfc;
  border: solid #ddd;
  border-width: 0 1px 1px;
  margin-top: 0;
  padding: 15px 15px 0;
}
.navbar-search .taglib-search-toggle-advanced-wrapper .taglib-search-toggle-advanced {
  border-width: 1px 0 0;
}
.taglib-search-toggle-advanced-wrapper .taglib-search-toggle-advanced .taglib-search-toggle-advanced-content {
  position: relative;
}
.taglib-search-toggle-advanced-wrapper .taglib-search-toggle-advanced .taglib-search-toggle-advanced-content .match-fields {
  margin-bottom: 0;
}
.taglib-search-toggle-advanced-wrapper .taglib-search-toggle-advanced .taglib-search-toggle-advanced-content .match-fields-legend {
  color: #999;
  font-size: 13px;
}
.taglib-search-toggle-advanced-wrapper .btn.close {
  margin-right: 5px;
  position: relative;
  z-index: 1;
}

.taglib-user-display {
  padding: 0.5em;
}
.taglib-user-display .avatar {
  background: no-repeat center;
  background-size: 60px;
  display: block;
  height: 60px;
  margin: 0 auto;
  width: 60px;
}
.taglib-user-display .avatar.author:after {
  background: rgba(50, 168, 230, 0.5);
  border-radius: 50%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}
.taglib-user-display .user-details {
  margin-top: 1em;
}
.taglib-user-display .user-name {
  font-size: 1.1em;
  font-weight: bold;
}
.taglib-user-display a .user-name {
  text-decoration: underline;
}
.taglib-user-display.display-style-1 .user-profile-image {
  float: left;
  margin-right: 24px;
}
.taglib-user-display.display-style-1 .user-name {
  display: inline-block;
  margin-top: 10px;
}
.taglib-user-display.display-style-1 .user-details {
  margin-top: 0;
}
.taglib-user-display.display-style-2 .user-profile-image,
.taglib-user-display.display-style-2 .user-name {
  clear: both;
  display: block;
  min-height: 20px;
  text-align: center;
}
.taglib-user-display.display-style-3 {
  padding: 0;
}
.taglib-user-display.display-style-3 .user-profile-image {
  display: inline-block;
  vertical-align: middle;
}

.taglib-workflow-status .workflow-id,
.taglib-workflow-status .workflow-version,
.taglib-workflow-status .workflow-status {
  color: #999;
}
.table-cell .taglib-workflow-status {
  margin: 0;
}
.table-cell .taglib-workflow-status .workflow-status {
  padding-left: 0;
}

.lfr-autocomplete-input-list .yui3-aclist-list {
  margin: 0;
}

.portal-popup .sheet > .lfr-nav {
  margin-top: -24px;
}
.portal-popup .contacts-portlet .portlet-configuration-container .form {
  position: static;
}
.portal-popup .lfr-form-content {
  padding: 24px 12px;
}
.portal-popup .portlet-body,
.portal-popup .portlet-boundary,
.portal-popup .portlet-column,
.portal-popup .portlet-layout {
  height: 100%;
}
.portal-popup .portlet-column {
  position: static;
}
.portal-popup .dialog-body > .container-fluid-max-xl,
.portal-popup .dialog-body .container-view,
.portal-popup .export-dialog-tree > .container-fluid-max-xl,
.portal-popup .export-dialog-tree .container-view,
.portal-popup .lfr-dynamic-uploader > .container-fluid-max-xl,
.portal-popup .lfr-dynamic-uploader .container-view,
.portal-popup .lfr-form-content > .container-fluid-max-xl,
.portal-popup .lfr-form-content .container-view,
.portal-popup .portlet-configuration-body-content > .container-fluid-max-xl,
.portal-popup .portlet-configuration-body-content .container-view,
.portal-popup .process-list > .container-fluid-max-xl,
.portal-popup .process-list .container-view,
.portal-popup .roles-selector-body > .container-fluid-max-xl,
.portal-popup .roles-selector-body .container-view {
  padding-top: 20px;
}
.portal-popup .dialog-body > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .dialog-body .container-view .nav-tabs-underline,
.portal-popup .export-dialog-tree > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .export-dialog-tree .container-view .nav-tabs-underline,
.portal-popup .lfr-dynamic-uploader > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .lfr-dynamic-uploader .container-view .nav-tabs-underline,
.portal-popup .lfr-form-content > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .lfr-form-content .container-view .nav-tabs-underline,
.portal-popup .portlet-configuration-body-content > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .portlet-configuration-body-content .container-view .nav-tabs-underline,
.portal-popup .process-list > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .process-list .container-view .nav-tabs-underline,
.portal-popup .roles-selector-body > .container-fluid-max-xl .nav-tabs-underline,
.portal-popup .roles-selector-body .container-view .nav-tabs-underline {
  margin-left: -15px;
  margin-right: -15px;
  margin-top: -20px;
}
.portal-popup .dialog-body > .lfr-nav + .container-fluid-max-xl,
.portal-popup .export-dialog-tree > .lfr-nav + .container-fluid-max-xl,
.portal-popup .lfr-dynamic-uploader > .lfr-nav + .container-fluid-max-xl,
.portal-popup .lfr-form-content > .lfr-nav + .container-fluid-max-xl,
.portal-popup .portlet-configuration-body-content > .lfr-nav + .container-fluid-max-xl,
.portal-popup .process-list > .lfr-nav + .container-fluid-max-xl,
.portal-popup .roles-selector-body > .lfr-nav + .container-fluid-max-xl {
  padding-top: 0;
}
.portal-popup .login-container {
  padding: 1rem;
}
.portal-popup .navbar ~ .portlet-configuration-setup,
.portal-popup .portlet-export-import-container {
  height: calc(100% - 48px);
  position: relative;
}
@media (min-width: 576px) {
  .portal-popup .navbar ~ .portlet-configuration-setup,
  .portal-popup .portlet-export-import-container {
    height: calc(100% - 48px);
  }
}
.portal-popup .panel-group .panel {
  border-left-width: 0;
  border-radius: 0;
  border-right-width: 0;
}
.portal-popup .panel-group .panel + .panel {
  border-top-width: 0;
  margin-top: 0;
}
.portal-popup .panel-heading {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.portal-popup .portlet-configuration-setup .lfr-nav {
  margin-left: auto;
  margin-right: auto;
  max-width: 1280px;
  padding-left: 3px;
  padding-right: 3px;
}
@media (min-width: 576px) {
  .portal-popup .portlet-configuration-setup .lfr-nav {
    padding-left: 8px;
    padding-right: 8px;
  }
}
.portal-popup .lfr-dynamic-uploader,
.portal-popup .process-list {
  bottom: 0;
  display: block;
  left: 0;
  overflow: auto;
  position: absolute;
  right: 0;
  top: 48px;
  -webkit-overflow-scrolling: touch;
}
@media (min-width: 576px) {
  .portal-popup .lfr-dynamic-uploader,
  .portal-popup .process-list {
    top: 48px;
  }
}
.portal-popup .portlet-export-import-publish-processes {
  top: 0;
}
.portal-popup .dialog-footer {
  background-color: #fff;
  border-top: 1px solid #dee2e6;
  bottom: 0;
  display: flex;
  flex-direction: row-reverse;
  left: 0;
  margin: 0;
  padding: 10px 24px;
  width: 100%;
  z-index: 1020;
}
@media (min-width: 768px) {
  .portal-popup .dialog-footer {
    position: fixed;
  }
}
.portal-popup .dialog-footer .btn {
  margin-left: 1rem;
  margin-right: 0;
}
.portal-popup .dialog-footer.dialog-footer-not-reverse {
  flex-direction: initial;
  justify-content: flex-end;
}
@media (min-width: 768px) {
  .portal-popup .dialog-body:not(:last-child),
  .portal-popup .lfr-dynamic-uploader:not(:last-child),
  .portal-popup .lfr-form-content:not(:last-child),
  .portal-popup .portlet-configuration-body-content:not(:last-child),
  .portal-popup .roles-selector-body:not(:last-child) {
    padding-bottom: 60px;
  }
}
.portal-popup .lfr-dynamic-uploader {
  display: table;
  table-layout: fixed;
  width: 100%;
}
.portal-popup .lfr-dynamic-uploader.hide-dialog-footer {
  bottom: 0;
}
.portal-popup .lfr-dynamic-uploader.hide-dialog-footer + .dialog-footer {
  display: none;
}
.portal-popup .portlet-configuration-edit-permissions .portlet-configuration-body-content {
  display: flex;
  flex-direction: column;
  overflow: visible;
}
.portal-popup .portlet-configuration-edit-permissions .portlet-configuration-body-content > form {
  flex-grow: 1;
  max-width: none;
  overflow: auto;
}
.portal-popup .portlet-configuration-edit-templates .portlet-configuration-body-content {
  bottom: 0;
}
.portal-popup:not(.article-preview) #main-content,
.portal-popup:not(.article-preview) #wrapper {
  bottom: 0;
  left: 0;
  overflow: auto;
  padding: 0;
  position: absolute;
  right: 0;
  top: 0;
  -webkit-overflow-scrolling: touch;
}
@media print {
  .portal-popup:not(.article-preview) #main-content,
  .portal-popup:not(.article-preview) #wrapper {
    position: initial;
  }
}
.portal-popup .columns-max > .portlet-layout.row {
  margin-left: 0;
  margin-right: 0;
}
.portal-popup .columns-max > .portlet-layout.row > .portlet-column {
  padding-left: 0;
  padding-right: 0;
}

html:not(#__):not(#___) .portlet-layout.dragging {
  border-collapse: separate;
}
html:not(#__):not(#___) .drop-area {
  background-color: #d3dadd;
}
html:not(#__):not(#___) .active-area {
  background: #ffc;
}
html:not(#__):not(#___) .portlet-boundary.yui3-dd-dragging {
  opacity: 0.6;
}
html:not(#__):not(#___) .portlet-boundary.yui3-dd-dragging .portlet {
  border: 2px dashed #ccc;
}
html:not(#__):not(#___) .sortable-layout-proxy {
  opacity: 1;
}
html:not(#__):not(#___) .sortable-layout-proxy .portlet-topper {
  background-image: none;
}
html:not(#__):not(#___) .proxy {
  cursor: move;
  opacity: 0.65;
  position: absolute;
}
html:not(#__):not(#___) .proxy.generic-portlet {
  height: 200px;
  width: 300px;
}
html:not(#__):not(#___) .proxy.generic-portlet .portlet-title {
  padding: 10px;
}
html:not(#__):not(#___) .proxy.not-intersecting .forbidden-action {
  background: url(../images/application/forbidden_action.png) no-repeat;
  display: block;
  height: 32px;
  position: absolute;
  right: -15px;
  top: -15px;
  width: 32px;
}
html:not(#__):not(#___) .resizable-proxy {
  border: 1px dashed #828f95;
  position: absolute;
  visibility: hidden;
}
html:not(#__):not(#___) .sortable-proxy {
  background: #727c81;
  margin-top: 1px;
}
html:not(#__):not(#___) .sortable-layout-drag-target-indicator {
  margin: 2px 0;
}
html:not(#__):not(#___) .yui3-dd-proxy {
  z-index: 1110 !important;
}

.portlet-layout.dragging {
  border-collapse: separate;
}

.drop-area {
  background-color: #d3dadd;
}

.active-area {
  background: #ffc;
}

.portlet-boundary.yui3-dd-dragging {
  opacity: 0.6;
  transform: scale(0.8);
  transition: transform 0.3s ease;
}
@media (prefers-reduced-motion: reduce) {
  .portlet-boundary.yui3-dd-dragging {
    transition: none;
  }
}
.c-prefers-reduced-motion .portlet-boundary.yui3-dd-dragging {
  transition: none;
}
.portlet-boundary.yui3-dd-dragging .portlet {
  border: 2px dashed #ccc;
}

.sortable-layout-proxy {
  opacity: 1;
}
.sortable-layout-proxy .portlet-topper {
  background-image: none;
}

.proxy {
  cursor: move;
  opacity: 0.65;
  position: absolute;
}
.proxy.generic-portlet {
  height: 200px;
  width: 300px;
}
.proxy.generic-portlet .portlet-title {
  padding: 10px;
}
.proxy.not-intersecting .forbidden-action {
  background: url(../images/application/forbidden_action.png) no-repeat;
  display: block;
  height: 32px;
  position: absolute;
  right: -15px;
  top: -15px;
  width: 32px;
}

.resizable-proxy {
  border: 1px dashed #828f95;
  position: absolute;
  visibility: hidden;
}

.sortable-proxy {
  background: #727c81;
  margin-top: 1px;
}

.sortable-layout-drag-target-indicator {
  margin: 2px 0;
}

.yui3-dd-proxy {
  z-index: 1110 !important;
}

.portlet-column-content.empty {
  padding: 50px;
}

.lfr-portlet-title-editable {
  margin-top: 0;
  z-index: 9999;
}
.lfr-portlet-title-editable .lfr-portlet-title-editable-content {
  padding: 0;
}
.lfr-portlet-title-editable .lfr-portlet-title-editable-content .field-input {
  margin-bottom: 0;
}
.lfr-portlet-title-editable .lfr-portlet-title-editable-content .textfield-label {
  display: none;
}
.lfr-portlet-title-editable .lfr-portlet-title-editable-content .btn-toolbar-content {
  display: inline-block;
  vertical-align: bottom;
}
.lfr-portlet-title-editable .lfr-portlet-title-editable-content .btn-group {
  margin-top: 0;
}
.lfr-portlet-title-editable .lfr-portlet-title-editable-content .btn {
  display: inline-block;
  float: none;
  margin-top: 0;
  width: auto;
}

.lfr-source-editor {
  border: solid 0 #ccc;
  border-bottom-width: 2px;
  position: relative;
}
.lfr-source-editor .ace_editor {
  height: 100%;
}
.lfr-source-editor .lfr-source-editor-toolbar li > .btn {
  background-color: #fff;
  border: transparent;
  color: #717383;
  outline: 0;
}
.lfr-source-editor .lfr-source-editor-code {
  background-color: #fff;
  color: #2b4259;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter {
  background-color: #ededef;
  color: #868896;
  overflow: hidden;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_fold-widget {
  font-family: fontawesome-alloy;
  text-align: center;
  vertical-align: middle;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_fold-widget.ace_open, .lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_fold-widget.ace_closed {
  background-image: none;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_fold-widget.ace_open:before {
  content: "▾";
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_fold-widget.ace_closed:before {
  content: "▸";
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_gutter-active-cell {
  color: #fff;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_gutter-active-line {
  background-color: #717383;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_gutter-layer {
  border-right: solid 1px #ccc;
}
.lfr-source-editor .lfr-source-editor-code .ace_gutter .ace_info {
  background-image: none;
}
.lfr-source-editor .lfr-source-editor-code .ace_content .ace_active-line {
  background-color: #ededef;
}
.lfr-source-editor .lfr-source-editor-code .ace_content .ace_constant {
  color: #34adab;
}
.lfr-source-editor .lfr-source-editor-code .ace_content .ace_tag {
  color: #1d5ec7;
}
.lfr-source-editor .lfr-source-editor-code .ace_content .ace_string {
  color: #ff6c58;
}
.lfr-source-editor .lfr-source-editor-code .ace_content .ace_string.ace_regex {
  color: #f00;
}
.lfr-source-editor.ace_dark .lfr-source-editor-code {
  background-color: #47474f;
  color: #fff;
}
.lfr-source-editor.ace_dark .lfr-source-editor-code .ace_gutter {
  background: #54555e;
  color: #fff;
}
.lfr-source-editor.ace_dark .lfr-source-editor-code .ace_gutter .ace_gutter-active-line {
  background-color: #009aed;
}
.lfr-source-editor.ace_dark .lfr-source-editor-code .ace_content .ace_active-line {
  background-color: #11394e;
}
.lfr-source-editor.ace_dark .lfr-source-editor-code .ace_content .ace_cursor {
  color: #fff;
}
.lfr-source-editor.ace_dark .lfr-source-editor-code .ace_content .ace_tag {
  color: #4d91ff;
}

.lfr-fullscreen-source-editor {
  height: 100%;
  overflow: hidden;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-header {
  height: 40px;
  margin-right: 4px;
  margin-top: 4px;
  min-height: 40px;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content {
  height: 95%;
  position: relative;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content .panel-splitter {
  border: 1px solid #ccc;
  position: absolute;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content .preview-panel {
  display: inline-block;
  overflow-y: auto;
  padding-left: 20px;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content .source-panel {
  display: inline-block;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.vertical .source-panel,
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.vertical .preview-panel {
  height: 100%;
  width: 50%;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.vertical .panel-splitter {
  height: 100%;
  left: 50%;
  top: 0;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.horizontal .source-panel,
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.horizontal .preview-panel {
  height: 50%;
  width: 100%;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.horizontal .panel-splitter {
  top: 50%;
  width: 100%;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.simple .panel-splitter,
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.simple .preview-panel {
  display: none;
}
.lfr-fullscreen-source-editor .lfr-fullscreen-source-editor-content.simple .source-panel {
  height: 100%;
  width: 100%;
}

.lfr-fulscreen-source-editor-dialog .modal-footer {
  text-align: left;
}

.file-icon-color-0 {
  background-color: #fff;
  color: #6c757d;
}

.file-icon-color-1 {
  background-color: #fff;
  color: #6c757d;
}

.file-icon-color-2 {
  background-color: #fff;
  color: #24a892;
}

.file-icon-color-3 {
  background-color: #fff;
  color: #ff4d4d;
}

.file-icon-color-4 {
  background-color: #fff;
  color: #ff6200;
}

.file-icon-color-5 {
  background-color: #fff;
  color: #bf66ff;
}

.file-icon-color-6 {
  background-color: #fff;
  color: #0099e6;
}

.file-icon-color-7 {
  background-color: #fff;
  color: #ff4db2;
}

.lfr-item-viewer.uploading > div:not(.progress-container) {
  opacity: 0.3;
}
.lfr-item-viewer.uploading > .progress-container {
  visibility: visible;
}
.lfr-item-viewer .aspect-ratio a.item-preview {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 100%;
  position: absolute;
  width: 100%;
}
.lfr-item-viewer .image-viewer-base-image-list {
  padding-top: 35px;
}
.lfr-item-viewer .item-preview:hover {
  cursor: pointer;
}
.lfr-item-viewer .progress-container {
  background-color: #fff;
  left: 0;
  margin: 0 auto;
  padding: 20px 30px;
  position: absolute;
  right: 0;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
  visibility: hidden;
  width: 80%;
  z-index: 1000;
}
.lfr-item-viewer .progress-container a {
  position: absolute;
  right: 30px;
}
.lfr-item-viewer .progress-container .progress {
  margin-top: 10px;
}
.lfr-item-viewer .search-info {
  background-color: #d3e8f1;
}
.lfr-item-viewer .search-info .keywords {
  font-size: 1.4em;
  font-weight: bold;
}
.lfr-item-viewer .search-info .change-search-folder {
  font-size: 0.8em;
  font-weight: normal;
}
.lfr-item-viewer .upload-view {
  display: table;
  height: 400px;
  margin-top: 20px;
  width: 100%;
}
.lfr-item-viewer .upload-view > div {
  display: table-cell;
  vertical-align: middle;
}
.lfr-item-viewer .yui3-widget-bd {
  position: relative;
}

.lfr-menu-expanded li a:focus {
  background-color: #5b677d;
  color: #fff;
  text-shadow: -1px -1px #2c2f34;
}

.lfr-url-error {
  display: inline-block;
  white-space: normal;
  overflow-wrap: break-all;
  word-wrap: break-all;
}

.lfr-page-layouts {
  padding: 0;
}
.lfr-page-layouts input[type=radio] {
  opacity: 0;
  position: absolute;
}
.lfr-page-layouts input[type=radio]:checked + .card-horizontal {
  cursor: default;
}
.lfr-page-layouts input[type=radio]:checked + .card-horizontal::after {
  bottom: -0.0625rem;
  content: "";
  left: -0.0625rem;
  position: absolute;
  right: -0.0625rem;
  transition: height 0.15s ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .lfr-page-layouts input[type=radio]:checked + .card-horizontal::after {
    transition: none;
  }
}
.lfr-page-layouts input[type=radio]:checked + .card-horizontal::after {
  transition: none;
}

.lfr-page-layouts .card-horizontal {
  cursor: pointer;
  outline: 0;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .lfr-page-layouts .card-horizontal {
    transition: none;
  }
}
.lfr-page-layouts .card-horizontal {
  transition: none;
}

.lfr-page-layouts .card-horizontal::after {
  border-radius: 0 0 0.25rem 0.25rem;
  bottom: -0.0625rem;
  content: "";
  height: 0;
  left: -0.0625rem;
  position: absolute;
  right: -0.0625rem;
  transition: height 0.15s ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .lfr-page-layouts .card-horizontal::after {
    transition: none;
  }
}
.lfr-page-layouts .card-horizontal::after {
  transition: none;
}

.modal-body.dialog-iframe-bd {
  overflow: hidden;
  padding: 0;
}

.modal-dialog:not(.dialog-iframe-modal):not(.modal-full-screen) {
  position: relative;
}
.modal-dialog.dialog-iframe-modal {
  max-width: none;
}
.modal-dialog.modal-dialog-sm {
  max-width: 500px;
}
.modal-dialog .yui3-resize-handles-wrapper {
  pointer-events: all;
}
.modal-dialog .yui3-resize-handles-wrapper .yui3-resize-handle-inner-br {
  bottom: 0;
  right: 0;
}

.modal-open .modal {
  display: block;
}

.sheet > .panel-group .sheet-footer {
  margin-bottom: 0;
}

.sheet-footer .btn {
  margin-right: 0.5rem;
}
.sheet-footer .btn:last-child {
  margin-right: 0;
}

.tag-items {
  list-style: none;
  margin: 0 1em 0 0;
  padding: 0 1em 0.5em;
  white-space: normal;
}
.tag-items li {
  display: inline-block;
  margin: 0 1em 0 0;
  max-width: 100%;
}

.tag-selected {
  color: #000;
  font-weight: bold;
  text-decoration: none;
}

.tag-cloud .tag-popularity-1 {
  font-size: 1em;
}
.tag-cloud .tag-popularity-2 {
  font-size: 1.3em;
}
.tag-cloud .tag-popularity-3 {
  font-size: 1.6em;
}
.tag-cloud .tag-popularity-4 {
  font-size: 1.9em;
}
.tag-cloud .tag-popularity-5 {
  font-size: 2.2em;
}
.tag-cloud .tag-popularity-6 {
  font-size: 2.5em;
}

.lfr-portal-tooltip {
  display: inline-flex;
}
.lfr-portal-tooltip,
.lfr-portal-tooltip a {
  -webkit-touch-callout: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
}

.tree-node .icon-check {
  padding-right: 2px;
}
.tree-node .tree-node-checked .icon-check {
  padding-right: 0;
}
.tree-node [class^=icon-] {
  margin-right: 5px;
}
.tree-node .tree-node-checkbox-container {
  margin-right: 0;
}
.tree-node .tree-node-selected .tree-label {
  background: none;
}

.tree-node-content .tree-hitarea {
  color: #999;
  font-size: 10px;
  padding-right: 6px;
}
.tree-node-content .tree-label {
  margin-left: 3px;
}
.tree-node-content .tree-node-hidden-hitarea {
  visibility: hidden;
}

.tree-node-selected .tree-label {
  background-color: transparent;
}

.tree-view li.tree-node .tree-node-content svg.lexicon-icon {
  pointer-events: none;
}

.user-icon-color-0 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #6c757d;
}

.user-icon-color-1 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #66abff;
}

.user-icon-color-2 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #ff6200;
}

.user-icon-color-3 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #ff4d4d;
}

.user-icon-color-4 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #24a892;
}

.user-icon-color-5 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #ff4db2;
}

.user-icon-color-6 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #53a117;
}

.user-icon-color-7 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #bf66ff;
}

.user-icon-color-8 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #b38900;
}

.user-icon-color-9 {
  background-color: #fff;
  box-shadow: 0 0 0 1px #dee2e6;
  color: #0099e6;
}

/* ==================================================
   LAYOUT COMPONENTS FROM ORIGINAL STYLE.CSS
   ================================================== */
/* Main Homepage Container */
.homepage {
  position: relative;
  width: 100%;
  max-width: var(--container-width, 1920px);
  min-height: 100vh;
  background: var(--color-white, #FFFFFF);
  border-radius: 1.875rem;
  margin: 0 auto;
}

/* Hero Section */
.hero-slider {
  position: relative;
  width: 100%;
  max-width: var(--content-width, 1640px);
  height: 46.875rem;
  margin: 9.375rem auto 0;
  border-radius: 1.875rem;
  overflow: hidden;
}

/* Featured Cards Grid */
.featured-section {
  padding: 6.25rem 0;
}

.featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(21.875rem, 1fr));
  gap: 1.25rem;
  max-width: var(--content-width, 1640px);
  margin: 0 auto;
  padding: 0 1rem;
}

.featured-card {
  height: 15.625rem;
  background: var(--color-white, #FFFFFF);
  border-radius: 1rem;
  box-shadow: 0 2px 0.625rem rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: all 0.3s ease;
}
.featured-card:hover {
  box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.15);
  transform: translateY(-0.25rem);
}

.featured-card-image {
  width: 100%;
  height: 9.375rem;
  background: linear-gradient(135deg, #f5f5f5, #e8e8e8);
}

.featured-card-content {
  padding: 1rem;
}

.featured-card-title {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-bold, 700);
  font-size: var(--font-size-lg, 18px);
  color: var(--color-text-primary, #0D0D0D);
  margin-bottom: 0.5rem;
}

.featured-card-text {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-normal, 400);
  font-size: var(--font-size-sm, 14px);
  color: var(--color-text-muted, #808080);
  line-height: 1.6;
}

/* Communications List */
.communications-list {
  padding: 2rem 0;
}

.communication-card {
  background: var(--color-white, #FFFFFF);
  border: 1px solid #E5E5E5;
  border-radius: 1rem;
  overflow: hidden;
  transition: all 0.3s ease;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.communication-card:hover {
  transform: translateY(-0.25rem);
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.12);
  border-color: var(--color-primary, #7F0723);
}
.communication-card .card-header {
  padding: 1rem;
  border-bottom: 1px solid #F5F5F5;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.communication-card .date {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  color: var(--color-text-secondary, #D6D6D6);
  font-weight: var(--font-weight-medium, 500);
}
.communication-card .card-body {
  padding: 1rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}
.communication-card .card-title {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-text-primary, #0D0D0D);
  margin-bottom: 0.75rem;
  line-height: 1.4;
}
.communication-card .card-excerpt {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  color: var(--color-text-muted, #808080);
  line-height: 1.6;
  margin-bottom: 1rem;
  flex-grow: 1;
}
.communication-card .card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  color: var(--color-text-secondary, #D6D6D6);
}
.communication-card .author {
  font-weight: var(--font-weight-medium, 500);
}
.communication-card .views {
  font-weight: var(--font-weight-normal, 400);
}
.communication-card .card-footer {
  padding: 1rem;
  background-color: #FAFAFA;
  border-top: 1px solid #F5F5F5;
}
.communication-card .read-more {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-primary, #7F0723);
  text-decoration: none;
  transition: all 0.3s ease;
}
.communication-card .read-more:hover {
  color: var(--color-dark, #0D0D0D);
  text-decoration: none;
}

/* Footer */
.footer-section {
  background: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  padding: 4rem 2rem;
  margin-top: 4rem;
}

/* Footer Logo */
.footer-logo-img {
  height: 3.75rem;
  opacity: 0.5;
}

/* Footer Headings */
.footer-heading {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-white, #FFFFFF);
  margin-bottom: 0.75rem;
}

/* Footer Description */
.footer-description {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  line-height: 1.6;
  margin-bottom: 1rem;
}

/* Read More Link */
.footer-read-more {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  display: block;
  margin-bottom: 1rem;
  transition: 0.3s ease-in-out;
}
.footer-read-more:hover {
  color: var(--color-white, #FFFFFF);
  text-decoration: underline;
}

/* Social Links */
.footer-social {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
}

.footer-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-social-link:hover {
  background-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  transform: translateY(-2px);
}

/* Copyright */
.footer-copyright-text {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0;
}

.footer-legal-links {
  display: flex;
  align-items: center;
}

.footer-legal-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-legal-link:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

.footer-separator {
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0 0.25rem;
}

/* Government Links */
.footer-gov-row {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.footer-gov-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-gov-link:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

/* Contact Info */
.footer-phone {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0 0 0.25rem 0;
  text-decoration: none;
  display: block;
  transition: 0.3s ease-in-out;
}
.footer-phone:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

/* Location */
.footer-address {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0 0 0.25rem 0;
}

/* Languages */
.footer-lang-links {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
}

.footer-lang-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-lang-link.active {
  opacity: 1;
  color: var(--color-white, #FFFFFF);
}
.footer-lang-link:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

/* Search Overlay */
.search-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity all 0.3s ease;
}
.search-overlay.show {
  display: flex;
  opacity: 1;
}

.search-form {
  position: relative;
  max-width: 37.5rem;
  width: 100%;
  background: var(--color-white, #FFFFFF);
  border-radius: 0.75rem;
  padding: 1.25rem;
  transform: translateY(-1.25rem);
  transition: transform all 0.3s ease;
}

.search-overlay.show .search-form {
  transform: translateY(0);
}

.search-close {
  position: absolute;
  top: -0.625rem;
  right: -0.625rem;
  background-color: var(--color-white, #FFFFFF);
  border-radius: 50%;
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 0.5rem rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}
.search-close:hover {
  background-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
}

/* Footer Styles for List Page */
.site-footer {
  background-color: var(--color-dark, #0D0D0D);
  color: var(--color-white, #FFFFFF);
  padding: 2rem 0 1rem;
}
.site-footer h4 {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-semibold, 600);
  margin-bottom: 1rem;
}
.site-footer p {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  line-height: 1.6;
  color: var(--color-text-secondary, #D6D6D6);
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-links li {
  margin-bottom: 0.5rem;
}
.footer-links a {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  color: var(--color-text-secondary, #D6D6D6);
  text-decoration: none;
  transition: all 0.3s ease;
}
.footer-links a:hover {
  color: var(--color-white, #FFFFFF);
}

.social-links {
  display: flex;
  gap: 0.75rem;
}
.social-links .social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  color: var(--color-white, #FFFFFF);
  font-size: var(--font-size-sm, 14px);
  text-decoration: none;
  transition: all 0.3s ease;
}
.social-links .social-link:hover {
  background-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 1rem;
  margin-top: 2rem;
  text-align: center;
}
.footer-bottom p {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  color: var(--color-text-secondary, #D6D6D6);
  margin: 0;
}

/* ==================================================
   FOOTER RESPONSIVE STYLES
   ================================================== */
/* 1200px Breakpoint */
@media (max-width: 1200px) {
  .footer-section {
    padding: 3rem 1.5rem;
    margin-top: 3rem;
  }
  .footer-logo-img {
    height: 3rem;
  }
  .footer-heading {
    font-size: 1rem;
    margin-bottom: 0.625rem;
  }
  .footer-description,
  .footer-read-more,
  .footer-phone,
  .footer-address,
  .footer-gov-link,
  .footer-legal-link,
  .footer-lang-link,
  .footer-copyright-text {
    font-size: 0.8125rem;
  }
  .footer-gov-row {
    gap: 0.75rem;
  }
  .footer-social-link,
  .social-link {
    width: 2.25rem;
    height: 2.25rem;
  }
}
/* 992px Breakpoint - Tablet */
@media (max-width: 992px) {
  .footer-section {
    padding: 2.5rem 1.25rem;
  }
  .footer-section .col-md-6 {
    width: 100%;
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6:first-child {
    text-align: center;
  }
  .footer-section .col-md-6.text-right {
    text-align: center;
  }
  .footer-gov-row {
    justify-content: center;
  }
  .footer-lang-links {
    justify-content: center;
  }
}
/* 768px Breakpoint - Mobile */
@media (max-width: 768px) {
  .footer-section {
    padding: 2.5rem 1rem;
  }
  .footer-section .row {
    flex-direction: column;
    gap: 2rem;
  }
  .footer-section .col-md-6 {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 0;
  }
  .footer-section .col-md-6:first-child {
    text-align: center;
  }
  .footer-section .col-md-6:first-child .footer-logo {
    justify-content: center;
    margin-bottom: 1.25rem;
  }
  .footer-section .col-md-6:first-child .social-icons {
    justify-content: center;
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6:first-child .footer-description {
    text-align: center;
    margin-bottom: 1rem;
    line-height: 1.5;
  }
  .footer-section .col-md-6:first-child .footer-read-more {
    text-align: center;
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6:first-child .footer-copyright {
    margin-top: 1.5rem;
  }
  .footer-section .col-md-6:first-child .footer-copyright-text,
  .footer-section .col-md-6:first-child .footer-legal-links {
    text-align: center;
    display: flex;
    justify-content: center;
  }
  .footer-section .col-md-6.text-right {
    text-align: center !important;
  }
  .footer-section .col-md-6.text-right .footer-gov-links {
    margin-bottom: 2rem;
  }
  .footer-section .col-md-6.text-right .footer-gov-row {
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
  .footer-section .col-md-6.text-right .footer-contact,
  .footer-section .col-md-6.text-right .footer-location {
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6.text-right .footer-phone-numbers {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: center;
  }
  .footer-section .col-md-6.text-right .footer-lang-links {
    justify-content: center;
  }
  .footer-logo-img {
    height: 2.75rem;
  }
  .footer-heading {
    font-size: 1rem;
    margin-bottom: 0.875rem;
    font-weight: 700;
  }
  .footer-description {
    font-size: 0.8125rem;
    line-height: 1.5;
  }
  .footer-phone,
  .footer-address {
    font-size: 0.8125rem;
  }
  .footer-gov-link {
    flex: 1 1 calc(50% - 0.25rem);
    min-width: 120px;
    text-align: center;
    font-size: 0.75rem;
    padding: 0.375rem 0.5rem;
  }
  .footer-copyright-text,
  .footer-legal-link,
  .footer-lang-link {
    font-size: 0.75rem;
  }
}
/* 576px Breakpoint - Small Mobile */
@media (max-width: 576px) {
  .footer-section {
    padding: 2rem 1rem;
  }
  .footer-section .row {
    gap: 1.5rem;
  }
  .footer-logo-img {
    height: 2.5rem;
  }
  .footer-heading {
    font-size: 0.9375rem;
    margin-bottom: 0.75rem;
  }
  .footer-description {
    font-size: 0.75rem;
    line-height: 1.5;
    margin-bottom: 0.875rem;
  }
  .footer-read-more {
    font-size: 0.75rem;
    margin-bottom: 1.25rem;
  }
  .footer-phone,
  .footer-address {
    font-size: 0.75rem;
  }
  .footer-gov-link {
    font-size: 0.6875rem;
    min-width: 100px;
    padding: 0.25rem 0.375rem;
  }
  .footer-copyright-text,
  .footer-legal-link,
  .footer-lang-link {
    font-size: 0.6875rem;
  }
  .footer-social-link,
  .social-link {
    width: 2.25rem;
    height: 2.25rem;
    font-size: 0.75rem;
  }
  .footer-gov-links,
  .footer-contact,
  .footer-location {
    margin-bottom: 1.25rem;
  }
}
.collapse.open {
  display: block;
}

.navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox='0%200%2016%2016'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20class='lexicon-icon-outline'%20d='M15%203H1a1%201%200%200%201%200-2h14a1%201%200%200%201%200%202Zm0%206H1a1%201%200%200%201%200-2h14a1%201%200%200%201%200%202ZM1%2015h14a1%201%200%200%200%200-2H1a1%201%200%200%200%200%202Z'%20fill='%23212529'/%3E%3C/svg%3E");
  height: 1em;
  width: 1em;
}

.navbar-nav .nav-item.hover:after {
  bottom: -0.125rem;
  content: "";
  height: 0.125rem;
  left: 0;
  position: absolute;
  width: 100%;
}

.navbar .navbar-toggler .c-inner {
  max-width: none;
}

html:not(#__):not(#___) .cadmin.portlet-topper {
  position: relative;
}
html:not(#__):not(#___) .cadmin.portlet-topper .portlet-topper-toolbar .portlet-icon-back {
  background: url(../images/arrows/12_left.png) no-repeat 0 50%;
  padding: 5px 5px 5px 18px;
}
html:not(#__):not(#___) .cadmin.portlet-topper .portlet-topper-toolbar .portlet-options .lfr-icon-menu-text {
  display: none;
}
html:not(#__):not(#___) .cadmin .component-action.portlet-options {
  color: white;
}

body.portlet {
  border-width: 0;
}

.portlet-icon-back {
  margin-top: -2px;
}
.portlet-topper .portlet-topper-toolbar .portlet-icon-back {
  background: url(../images/arrows/12_left.png) no-repeat 0 50%;
  padding: 5px 5px 5px 18px;
}

.portlet-options-dropdown {
  z-index: 1035;
}

.portlet-topper {
  position: relative;
}
.portlet-topper .portlet-topper-toolbar .portlet-options .lfr-icon-menu-text {
  display: none;
}
.portlet-draggable .portlet-topper {
  cursor: move;
}

.portlet-title-editable {
  cursor: pointer;
}

.portlet-title-text {
  display: inline-block;
  margin-top: 0;
  max-width: 95%;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: top;
  white-space: nowrap;
}
.panel-page-body .portlet-title-text, .panel-page-content .portlet-title-text {
  cursor: auto;
}

.portlet-minimized .portlet-content {
  padding: 0;
}

.portlet-nested-portlets .portlet-boundary {
  left: 0 !important;
  position: relative !important;
  top: 0 !important;
}

.portlet-layout .portlet-header {
  margin-bottom: 1rem;
}

@media (min-width: 576px) {
  .portlet .visible-interaction {
    display: none;
  }
}
@media (max-width: 767.98px) {
  .controls-hidden .portlet .visible-interaction {
    display: none;
  }
}
.portlet:hover .visible-interaction, .portlet.open .visible-interaction, .portlet.focus .visible-interaction {
  display: block;
}

.controls-hidden .lfr-meta-actions,
.controls-hidden .lfr-configurator-visibility {
  display: none;
}
.controls-hidden .portlet-title-editable {
  pointer-events: none;
}
.controls-hidden .portlet-topper {
  display: none !important;
}
.controls-hidden .portlet-topper-toolbar {
  display: none !important;
}

html:not(#__):not(#___) .cadmin.portlet-topper {
  background-color: #f7f7f7;
  border-color: transparent;
  border-radius: 0 0;
  border-style: solid;
  border-width: 1px 1px 1px 1px;
  color: rgba(0, 0, 0, 0.5);
  display: box;
  display: flex;
  height: 28px;
  padding: 3px 12px 3px 24px;
  position: relative;
}
html:not(#__):not(#___) .cadmin.portlet-topper .lexicon-icon {
  height: 12px;
  width: 12px;
}
html:not(#__):not(#___) .cadmin.portlet-topper .lexicon-icon.lexicon-icon-drag {
  height: 16px;
  width: 16px;
}
html:not(#__):not(#___) .portlet > .cadmin.portlet-topper {
  display: none;
}
@media (min-width: 768px) {
  html:not(#__):not(#___) .portlet > .cadmin.portlet-topper {
    display: flex;
    left: 0;
    opacity: 0;
    position: absolute;
    right: 0;
    transform: translateY(-97%);
    transition: opacity 0.15s;
    top: 0;
  }
}
@media (min-width: 768px) and (prefers-reduced-motion: reduce) {
  html:not(#__):not(#___) .portlet > .cadmin.portlet-topper {
    transition: none;
  }
}
@media (min-width: 768px) {
  html:not(#__):not(#___) .portlet > .c-prefers-reduced-motion .cadmin.portlet-topper {
    transition: none;
  }
}
html:not(#__):not(#___) .cadmin .portlet-actions {
  float: right;
}
html:not(#__):not(#___) .cadmin .portlet-options {
  display: inline-block;
}
html:not(#__):not(#___) .cadmin .portlet-title-menu {
  flex: 0 1 auto;
}
html:not(#__):not(#___) .cadmin .portlet-title-menu > span > a {
  display: inline-block;
  text-decoration: none;
}
html:not(#__):not(#___) .cadmin .portlet-topper-toolbar {
  margin: 0;
  padding-left: 0;
}
html:not(#__):not(#___) .cadmin .portlet-topper-toolbar > a,
html:not(#__):not(#___) .cadmin .portlet-topper-toolbar > span > a,
html:not(#__):not(#___) .cadmin .portlet-topper-toolbar .lfr-icon-menu > a {
  color: rgba(0, 0, 0, 0.5);
}
html:not(#__):not(#___) .cadmin .portlet-topper-toolbar > a:focus, html:not(#__):not(#___) .cadmin .portlet-topper-toolbar > a:hover {
  text-decoration: none;
}
html:not(#__):not(#___) .cadmin .portlet-name-text {
  font-size: 12px;
  font-weight: 600;
  margin-left: 4px;
}
html:not(#__):not(#___) .cadmin .portlet-title-default {
  flex: 1 1 auto;
  line-height: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (min-width: 576px) {
  html:not(#__):not(#___) .lfr-configurator-visibility .portlet:hover .portlet-topper, html:not(#__):not(#___) .lfr-configurator-visibility .portlet.focus .portlet-topper, html:not(#__):not(#___) .lfr-configurator-visibility .portlet.open .portlet-topper {
    opacity: 0.5;
  }
}
@media (min-width: 768px) {
  html:not(#__):not(#___) .controls-visible .portlet:hover > .portlet-content-editable, html:not(#__):not(#___) .controls-visible .portlet.open > .portlet-content-editable, html:not(#__):not(#___) .controls-visible .portlet.focus > .portlet-content-editable {
    border-color: transparent;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }
}
@media (min-width: 768px) {
  html:not(#__):not(#___) .controls-visible .portlet:hover > .cadmin.portlet-topper, html:not(#__):not(#___) .controls-visible .portlet.open > .cadmin.portlet-topper, html:not(#__):not(#___) .controls-visible .portlet.focus > .cadmin.portlet-topper {
    opacity: 1;
  }
}
@media (min-width: 768px) {
  html:not(#__):not(#___) .controls-visible .portlet.open > .cadmin.portlet-topper {
    transition-duration: 0ms;
  }
}
@media (max-width: 767.98px) {
  html:not(#__):not(#___) .controls-visible .cadmin.portlet-topper {
    align-items: center;
    display: box;
    display: flex;
  }
}
html:not(#__):not(#___) .controls-visible .cadmin .portlet-topper-toolbar {
  display: block;
}

.portlet {
  margin-bottom: 10px;
  position: relative;
}
@media (min-width: 768px) {
  .controls-visible .portlet:hover > .portlet-content-editable, .controls-visible .portlet.open > .portlet-content-editable, .controls-visible .portlet.focus > .portlet-content-editable {
    border-color: transparent;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }
}
@media (min-width: 768px) {
  .controls-visible .portlet:hover > .portlet-topper, .controls-visible .portlet.open > .portlet-topper, .controls-visible .portlet.focus > .portlet-topper {
    opacity: 1;
  }
}
@media (min-width: 576px) {
  .lfr-configurator-visibility .portlet:hover .portlet-topper, .lfr-configurator-visibility .portlet.focus .portlet-topper, .lfr-configurator-visibility .portlet.open .portlet-topper {
    opacity: 0.5;
  }
}

.portlet-content-editable {
  border-color: transparent;
  border-radius: 0 0;
  border-style: solid;
  border-width: 2px 2px 2px 2px;
  transition: border-color 0.15s ease;
}
.portlet > .portlet-content-editable {
  border-color: transparent;
}
@media (max-width: 767.98px) {
  .controls-visible .portlet-content-editable {
    border-color: transparent;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }
}

.portlet-options {
  display: inline-block;
}

.portlet-title-default {
  flex: 1 1 auto;
  line-height: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.portlet-title-menu {
  flex: 0 1 auto;
}
.portlet-title-menu > span > a {
  display: inline-block;
  text-decoration: none;
}

.portlet-topper {
  background-color: #f7f7f7;
  border-color: transparent;
  border-radius: 0 0;
  border-style: solid;
  border-width: 1px 1px 1px 1px;
  color: rgba(0, 0, 0, 0.5);
  display: box;
  display: flex;
  padding: 3px 12px 3px 24px;
  position: relative;
}
.portlet > .portlet-topper {
  display: none;
}
@media (min-width: 768px) {
  .portlet > .portlet-topper {
    display: flex;
    left: 0;
    opacity: 0;
    position: absolute;
    right: 0;
    transition: opacity 0.15s;
    top: 0;
  }
}
@media (min-width: 768px) and (prefers-reduced-motion: reduce) {
  .portlet > .portlet-topper {
    transition: none;
  }
}
@media (min-width: 768px) {
  .portlet > .portlet-topper {
    transition: none;
  }
}
@media (max-width: 767.98px) {
  .controls-visible .portlet-topper {
    display: box;
    display: flex;
  }
}

.portlet-topper-toolbar {
  margin: 0;
  padding-left: 0;
}
.portlet-topper-toolbar > a,
.portlet-topper-toolbar > span > a,
.portlet-topper-toolbar .lfr-icon-menu > a {
  color: rgba(0, 0, 0, 0.5);
}
.portlet-topper-toolbar > a:focus, .portlet-topper-toolbar > a:hover {
  text-decoration: none;
}
.controls-visible .portlet-topper-toolbar {
  display: block;
}

.lfr-panel-page .portlet-title {
  font-size: 13px;
}

.portlet-borderless .portlet-content {
  padding: 1rem;
}
.portlet-decorate .portlet-content {
  background: #fff;
  border-color: transparent;
  border-style: solid;
  border-width: 2px 2px 2px 2px;
  padding: 1rem;
  word-wrap: break-word;
}
.portlet-barebone .portlet-content {
  padding: 0;
}

.portlet-dynamic-data-lists-display .lfr-ddm-field-group,
.portlet-dynamic-data-lists .lfr-ddm-field-group {
  margin-bottom: 10px;
  margin-top: 10px;
  padding: 28px 24px;
}

.breadcrumb.breadcrumb-vertical {
  display: inline-block;
  text-align: center;
}
.breadcrumb.breadcrumb-vertical li {
  display: block;
}
.breadcrumb.breadcrumb-vertical li.last, .breadcrumb.breadcrumb-vertical li.only {
  background: none;
}
.breadcrumb.breadcrumb-vertical .divider {
  background: url(../images/arrows/07_down.png) no-repeat 50% 100%;
  display: block;
  height: 10px;
  overflow: hidden;
  text-indent: 101%;
  white-space: nowrap;
}

.navbar form {
  margin: 0;
}

:not(.inline-item) > .loading-animation {
  margin-bottom: 20px;
  margin-top: 20px;
}
.product-menu .loading-animation {
  margin-top: 160px;
}

@keyframes lfr-drop-active {
  0% {
    background-color: #ebebeb;
    border-color: #ddd;
  }
  50% {
    background-color: #ddedde;
    border-color: #7d7;
    transform: scale(1.1);
  }
  75% {
    background-color: #ddedde;
    border-color: #7d7;
  }
  100% {
    background-color: #ebebeb;
    border-color: #ddd;
  }
}
.lfr-upload-container .progress-bar,
.lfr-upload-container .progress {
  border-radius: 10px;
}
.lfr-upload-container .upload-file,
.lfr-upload-container .upload-target {
  border-radius: 5px;
}
.upload-drop-active .lfr-upload-container .upload-target {
  animation: none;
}
.upload-drop-intent .lfr-upload-container .upload-target {
  animation: lfr-drop-active 1s ease 0.2s infinite;
}

.select-files {
  border-radius: 5px;
}

.taglib-form-navigator > .form-steps > ul.form-navigator.list-group {
  box-shadow: none;
}
.taglib-form-navigator > .form-steps > ul.form-navigator.list-group .tab .tab-label:hover .number, .taglib-form-navigator > .form-steps > ul.form-navigator.list-group .tab .tab-label:focus .number {
  box-shadow: 0 0 5px 0 #333;
  transition-duration: 0.25s;
  transition-property: box-shadow;
  transition-timing-function: ease-out;
}
.taglib-form-navigator > .form-steps > ul.form-navigator.list-group .tab .tab-label .number {
  border-radius: 50%;
}

@keyframes progress-bar-stripes {
  from {
    background-position: 40px 0;
  }
  to {
    background-position: 0 0;
  }
}
.lfr-progress-active .progress-bar-status,
.lfr-upload-container .file-uploading .progress-bar .progress {
  animation: progress-bar-stripes 0.5s linear infinite;
  background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.3) 25%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0.3) 50%, rgba(255, 255, 255, 0.3) 75%, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 0));
  background-size: 40px 40px;
  transition: width, 0.5s, ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .lfr-progress-active .progress-bar-status,
  .lfr-upload-container .file-uploading .progress-bar .progress {
    transition: none;
  }
}
.c-prefers-reduced-motion .lfr-progress-active .progress-bar-status,
.c-prefers-reduced-motion .lfr-upload-container .file-uploading .progress-bar .progress {
  transition: none;
}

@keyframes highlight-animation {
  from {
    background-color: #ffc;
  }
  to {
    background-color: transparent;
  }
}
.highlight-animation {
  animation: highlight-animation 0.7s;
}

.portlet-options.btn-group .dropdown-toggle, .portlet-options.btn-group.open .dropdown-toggle {
  box-shadow: none;
}

.form-group.form-inline.input-boolean-wrapper label, .form-group.form-inline.input-checkbox-wrapper label {
  gap: 0.3125rem;
}

/* ==================================================
   PGS PORTAL - FIGMA DESIGN SYSTEM
   Based on Figma CSS Export
   ================================================== */
/* Import Urbanist Font */
/* ==================================================
   GLOBAL STYLES
   ================================================== */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

/* Screen reader only content */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Focus management */
.focus-trap:focus {
  outline: 2px solid var(--color-primary, #7F0723);
  outline-offset: 2px;
}

body {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-base, 16px);
  font-weight: var(--font-weight-normal, 400);
  line-height: 1.5;
  color: var(--color-text-primary, #0D0D0D);
  background-color: var(--color-background, #FFFFFF);
  margin: 0;
  padding: 0;
  overflow-x: hidden; /* Prevent horizontal overflow from fixed elements */
}

/* Container */
.container {
  max-width: var(--container-width, 1920px) !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

.content-container {
  max-width: var(--content-width, 1640px);
  margin: 0 auto;
  padding: 0 var(--content-offset, 140px);
}

.text-uppercase {
  text-transform: uppercase;
}

/* ==================================================
   TYPOGRAPHY
   ================================================== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-bold, 700);
  line-height: 1.2;
  margin-bottom: 1rem;
  color: var(--color-text-primary, #0D0D0D);
}

h1 {
  font-size: var(--font-size-4xl, 36px);
}

h2 {
  font-size: var(--font-size-3xl, 30px);
}

h3 {
  font-size: var(--font-size-2xl, 24px);
}

h4 {
  font-size: var(--font-size-xl, 20px);
}

h5 {
  font-size: var(--font-size-lg, 18px);
}

h6 {
  font-size: var(--font-size-base, 16px);
}

p {
  margin-bottom: 1rem;
  color: var(--color-text-primary, #0D0D0D);
  line-height: 1.6;
}

/* ==================================================
   HEADER STYLES
   ================================================== */
/* Header */
.header {
  width: 100%;
  height: 5rem;
  margin-top: 1.25rem;
  margin-bottom: 1.5625rem;
  overflow: visible;
}

.header-container {
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 2rem;
  justify-content: space-between;
  overflow: visible;
}

/* Logo section */
.logo-section {
  display: flex;
  align-items: center;
  gap: 1rem;
  z-index: 1030;
  position: relative;
}
.logo-section a {
  display: flex;
  vertical-align: middle;
}
.logo-section a img {
  height: 4.25rem;
}

/* Header accent - red diagonal shape */
.header-accent {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  background: var(--color-primary, #7F0723);
  clip-path: polygon(4% 0%, 100% 0%, 100% 100%, 0% 100%);
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2rem 0 7.5rem;
}

/* Navigation styles */
.header-nav {
  z-index: 1030;
  position: relative;
}

.main-nav {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0;
}
.main-nav li {
  position: relative;
  display: flex;
  align-items: center;
}
.main-nav li:not(:last-child):after {
  content: "/";
  color: var(--color-white, #FFFFFF);
  font-weight: var(--font-weight-normal, 400);
  font-size: var(--font-size-sm, 14px);
  opacity: 0.5;
  margin: 0 1rem;
  display: flex;
  align-items: center;
}
.main-nav li a {
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  font-weight: var(--font-weight-black, 900);
  font-size: var(--font-size-sm, 14px);
  text-transform: uppercase;
  padding: 0.5rem 0;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  transition: 0.3s ease-in-out;
  opacity: 0.5;
}
.main-nav li a:hover {
  opacity: 1;
  text-decoration: none;
}
.main-nav li a.active {
  opacity: 1;
  color: var(--color-white, #FFFFFF);
}

/* Dropdown arrow */
.dropdown-toggle::after {
  display: none;
}

.dropdown.active .dropdown-arrow {
  transform: rotate(180deg);
}

/* Dropdown menu */
.dropdown-menu {
  position: fixed;
  background: var(--color-white, #FFFFFF);
  min-width: 12.5rem;
  box-shadow: 0 0.625rem 0.9375rem rgba(0, 0, 0, 0.1);
  border-radius: 0.5rem;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.625rem);
  transition: 0.3s ease-in-out;
  z-index: 9999;
  pointer-events: none;
}
.dropdown-menu.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.dropdown-menu li {
  margin: 0;
  border-bottom: 1px solid #F0F0F0;
}
.dropdown-menu li:last-child {
  border-bottom: none;
}
.dropdown-menu li a {
  color: var(--color-text-primary, #0D0D0D);
  padding: 0.75rem 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: var(--font-weight-black, 900);
  font-size: var(--font-size-sm, 14px);
  border-radius: 0;
  transition: 0.3s ease-in-out;
  text-decoration: none;
  text-transform: uppercase;
}
.dropdown-menu li a::after {
  content: "";
  background-image: url('data:image/svg+xml,<svg width="10" height="10" viewBox="0 0 10 10" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M3 1.5C2.72386 1.5 2.5 1.27614 2.5 1C2.5 0.723858 2.72386 0.5 3 0.5H9C9.27614 0.5 9.5 0.723858 9.5 1V7C9.5 7.27614 9.27614 7.5 9 7.5C8.72386 7.5 8.5 7.27614 8.5 7V2.20711L1.35355 9.35355C1.15829 9.54882 0.841709 9.54882 0.646447 9.35355C0.451184 9.15829 0.451184 8.84171 0.646447 8.64645L7.79289 1.5H3Z" fill="%23BF284B"/></svg>');
  width: 10px;
  height: 9px;
  background-repeat: no-repeat;
}
.dropdown-menu li a:hover {
  background-color: var(--color-background-light, #F9F9FB);
  color: var(--color-primary, #7F0723);
}
.dropdown-menu li a:hover::after {
  border-left-color: var(--color-primary, #7F0723);
}

/* Header actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  z-index: 1030;
  position: relative;
}
.header-actions .notification-container button,
.header-actions .search-container button {
  background-color: transparent;
}

/* User Profile Section */
.user-profile {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: 0.5rem;
  cursor: pointer;
  transition: all 0.3s ease;
}
.user-profile:hover {
  opacity: 0.9;
}

.user-avatar {
  position: relative;
}

.user-profile-image {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(255, 255, 255, 0.2);
  transition: all 0.3s ease;
}
.user-profile-image:hover {
  border-color: rgba(255, 255, 255, 0.4);
  transform: scale(1.05);
}

.user-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.user-name {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: 1rem;
  font-weight: 700 !important;
  color: var(--color-white, #FFFFFF) !important;
  line-height: 1.2;
  margin: 0;
}

.user-designation {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: 0.75rem;
  font-weight: 500;
  color: #D6D6D6;
  line-height: 1.2;
  margin: 0;
}

/* Search and Notification Buttons */
.search-btn {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: 0.3s ease-in-out;
}
.search-btn:hover {
  background: rgba(255, 255, 255, 0.3);
  border-color: rgba(255, 255, 255, 0.5);
  transform: translateY(-1px);
}
.search-btn img {
  width: 1.25rem;
  height: 1.25rem;
}

.notification-btn {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: 0.3s ease-in-out;
  position: relative;
}
.notification-btn:hover {
  background: rgba(255, 255, 255, 0.3);
  border-color: rgba(255, 255, 255, 0.5);
  transform: translateY(-1px);
}
.notification-btn img {
  width: 1.25rem;
  height: 1.25rem;
}

.notification-badge {
  position: absolute;
  top: -0.3125rem;
  right: -0.3125rem;
  background: var(--btn-primary, #BF284B);
  color: var(--color-white, #FFFFFF);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-bold, 700);
  min-width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  z-index: 1;
}

.search-container {
  position: relative;
}

/* Date Display */
.date-display {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-style: normal;
  font-weight: var(--font-weight-bold, 700);
  font-size: var(--font-size-base, 16px);
  line-height: 1.1875rem;
  text-transform: uppercase;
  color: var(--color-text-secondary, #D6D6D6);
}

/* Profile Dropdown */
.profile-dropdown {
  position: fixed;
  background: var(--color-white, #FFFFFF);
  min-width: 12.5rem;
  box-shadow: 0 0.625rem 0.9375rem rgba(0, 0, 0, 0.1);
  border-radius: 0.5rem;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.625rem);
  transition: all 0.3s ease;
  pointer-events: none;
}
.profile-dropdown.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.profile-dropdown-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1.5rem;
  color: var(--color-text-primary, #0D0D0D);
  text-decoration: none;
  font-family: var(--font-primary);
  font-weight: 900;
  font-size: 0.875rem;
  transition: all 0.3s ease;
  border-bottom: 1px solid #F0F0F0;
}
.profile-dropdown-item:last-child {
  border-bottom: none;
}
.profile-dropdown-item:hover {
  background-color: var(--color-background-light, #F9F9FB);
  color: var(--color-primary, #7F0723);
  text-decoration: none;
}
.profile-dropdown-item:hover i {
  color: var(--color-primary, #7F0723);
  transform: translateX(0.1875rem);
}
.profile-dropdown-item i {
  font-size: 0.875rem;
  color: var(--color-text-primary, #0D0D0D);
  transition: all 0.3s ease;
}

/* Search Popup Overlay */
.search-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Search Popup */
.search-popup {
  position: fixed;
  top: -100%;
  left: 0;
  width: 100%;
  background: #FFFFFF;
  z-index: 9999;
  transition: top 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0.625rem 1.25rem rgba(0, 0, 0, 0.1);
}
.search-popup.open {
  top: 0;
}
.search-popup.open ~ .search-overlay {
  opacity: 1;
  visibility: visible;
}

.search-popup-close {
  position: absolute;
  top: 2.5rem;
  right: 8.75rem;
  width: 1.875rem;
  height: 1.875rem;
  background: transparent;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 10;
}
.search-popup-close i {
  font-size: 1.5rem;
  color: #0D0D0D;
}
.search-popup-close:hover {
  transform: scale(1.1);
}
.search-popup-close:hover i {
  color: var(--btn-primary, #BF284B);
}

.search-popup-content {
  padding: 6.875rem 0;
  max-width: 71.875rem;
  margin: 0 auto;
}

.search-popup-title {
  color: #0D0D0D;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.75rem;
  margin-bottom: 1.5rem;
}

.search-popup-form {
  width: 100%;
}

.search-input-wrapper {
  position: relative;
  width: 100%;
}
.search-input-wrapper .btn-primary:hover {
  transform: translateY(-50%) !important;
}

.search-popup-input {
  width: 100%;
  border: 1px solid #D6D6D6;
  border-radius: 6.25rem;
  padding: 1.5rem 13.125rem 1.5rem 2.5rem;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.125rem;
  color: #0D0D0D;
}
.search-popup-input::placeholder {
  color: #808080;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.125rem;
}
.search-popup-input:focus {
  outline: none;
  border-color: var(--btn-primary, #BF284B);
}

.search-popup-btn {
  position: absolute;
  right: 1.0625rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 0.3125rem;
  font-size: 1rem;
  padding: 0.5rem 1.5rem;
}
.search-popup-btn i {
  font-size: 1rem;
  color: #FFFFFF;
}

/* Notification Popup Overlay */
.notification-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Notification Popup (Right Sidebar) */
.notification-popup {
  position: fixed;
  top: 0;
  right: -40.6875rem;
  width: 40.6875rem;
  height: 100vh;
  background: #FFFFFF;
  border-radius: 1.875rem 0 0 1.875rem;
  padding: 3.75rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}
.notification-popup.open {
  right: 0;
}
.notification-popup.open ~ .notification-overlay {
  opacity: 1;
  visibility: visible;
}

.notification-popup-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 1.375rem;
  border-bottom: 1px solid #D6D6D6;
  margin-bottom: 2.5rem;
}

.notification-popup-title {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.75rem;
  line-height: 100%;
  letter-spacing: -0.02em;
  margin: 0;
  color: #0D0D0D;
}

.notification-popup-close {
  width: 1.875rem;
  height: 1.875rem;
  background: transparent;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}
.notification-popup-close i {
  font-size: 1.5rem;
  color: #0D0D0D;
}
.notification-popup-close:hover {
  transform: scale(1.1);
}
.notification-popup-close:hover i {
  color: var(--btn-primary, #BF284B);
}

.notification-popup-content {
  flex: 1;
  overflow-y: auto;
}

.notification-popup-item {
  padding: 0;
}

.notification-popup-item-title {
  color: #0D0D0D;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1rem;
  margin: 1rem 0 0 0;
}

.notification-divider {
  border: none;
  height: 1px;
  background: #D6D6D6;
  margin: 1.5rem 0;
}

/* Search Filter Button */
.search-filter-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1.5rem 2rem;
  background: var(--btn-primary, #BF284B);
  color: #FFFFFF;
  border: none;
  border-radius: 6.25rem;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.125rem;
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.search-filter-btn:hover {
  background: #a0213d;
  transform: translateY(-2px);
}
.search-filter-btn i {
  font-size: 1rem;
}

/* Mobile Menu Toggle - Hidden by default on desktop */
.mobile-menu-toggle {
  display: none;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  align-items: center;
  justify-content: center;
}

/* ==================================================
   HEADER RESPONSIVE STYLES
   ================================================== */
/* 1200px Breakpoint - Scaling from 1920px */
@media (max-width: 1200px) {
  .header {
    height: 4rem;
    margin-top: 1rem;
    margin-bottom: 1.25rem;
  }
  .header-container {
    padding: 0 1.5rem;
  }
  .logo-section a img {
    height: 3.5rem;
  }
  .header-accent {
    padding: 0 1.5rem 0 5rem;
  }
  .main-nav li a {
    font-size: 0.8125rem;
  }
  .main-nav li:not(:last-child):after {
    margin: 0 0.75rem;
  }
  .search-btn,
  .notification-btn {
    width: 3rem;
    height: 3rem;
  }
  .search-btn img,
  .notification-btn img {
    width: 1.125rem;
    height: 1.125rem;
  }
  .user-profile-image {
    width: 2.25rem;
    height: 2.25rem;
  }
  .user-name {
    font-size: 0.9375rem;
  }
  .user-designation {
    font-size: 0.6875rem;
  }
  .search-popup {
    padding: 2.5rem 2rem;
  }
  .search-popup-title {
    font-size: 1.75rem;
    margin-bottom: 1.5rem;
  }
  .search-popup-input {
    font-size: 1rem;
    padding: 1rem 1.25rem;
  }
  .search-popup-btn {
    padding: 1rem 2rem;
    font-size: 0.875rem;
  }
  .notification-popup {
    width: 32rem;
  }
  .notification-popup-title {
    font-size: 1.25rem;
  }
  .notification-popup-item-title {
    font-size: 0.9375rem;
  }
  .profile-dropdown,
  .dropdown-menu {
    min-width: 11rem;
  }
  .dropdown-menu li a,
  .profile-dropdown-item {
    padding: 0.625rem 1.25rem;
    font-size: 0.8125rem;
  }
}
/* 992px Breakpoint - Tablet */
@media (max-width: 992px) {
  .header {
    height: 3.5rem;
  }
  .logo-section a img {
    height: 3rem;
  }
  .header-accent {
    padding: 0 1.25rem 0 4rem;
  }
  .main-nav li a {
    font-size: 0.75rem;
  }
  .main-nav li:not(:last-child):after {
    margin: 0 0.625rem;
  }
  .search-btn,
  .notification-btn {
    width: 2.75rem;
    height: 2.75rem;
  }
  .user-name {
    font-size: 0.875rem;
  }
}
/* 768px Breakpoint - Mobile */
@media (max-width: 768px) {
  .header {
    height: auto;
    margin-top: 0.75rem;
    margin-bottom: 1rem;
  }
  .header-container {
    flex-direction: column;
    padding: 0.75rem 1rem;
    gap: 0.75rem;
  }
  .logo-section {
    width: 100%;
    justify-content: center;
  }
  .logo-section a img {
    height: 2.5rem;
  }
  .header-accent {
    position: relative;
    width: 100%;
    clip-path: none;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
  }
  .header-nav {
    display: none;
  }
  /* Mobile nav open state */
  body.mobile-nav-open .header-nav {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-primary, #7F0723);
    z-index: 10000;
    flex-direction: column;
    padding: 1.5rem;
    justify-content: flex-start;
  }
  body.mobile-nav-open .header-nav .main-nav {
    flex-direction: column;
    gap: 0;
    width: 100%;
    margin-top: 4rem;
  }
  body.mobile-nav-open .header-nav .main-nav li {
    width: 100%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
  body.mobile-nav-open .header-nav .main-nav li:not(:last-child):after {
    display: none;
  }
  body.mobile-nav-open .header-nav .main-nav li a {
    padding: 1rem 0;
    width: 100%;
    font-size: 1.125rem;
    opacity: 1;
  }
  /* Mobile menu close button */
  body.mobile-nav-open .header-nav::before {
    content: "×";
    position: absolute;
    top: 1.5rem;
    right: 1.5rem;
    font-size: 2.5rem;
    color: white;
    cursor: pointer;
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 0.375rem;
  }
  body.mobile-nav-open {
    overflow: hidden;
  }
  .header-actions {
    gap: 0.5rem;
    width: 100%;
    justify-content: space-between;
  }
  .search-btn,
  .notification-btn {
    width: 2.5rem;
    height: 2.5rem;
  }
  .search-btn img,
  .notification-btn img {
    width: 1rem;
    height: 1rem;
  }
  .user-profile {
    gap: 0.5rem;
  }
  .user-profile .user-profile-image {
    width: 2rem;
    height: 2rem;
  }
  .user-info {
    display: none;
  }
  .mobile-menu-toggle {
    display: flex !important;
    width: 2.5rem;
    height: 2.5rem;
    background: rgba(255, 255, 255, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 0.375rem;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    cursor: pointer;
    padding: 0.5rem;
  }
  .mobile-menu-toggle .hamburger {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    width: 100%;
  }
  .mobile-menu-toggle .hamburger span {
    display: block;
    width: 100%;
    height: 2px;
    background: white;
    transition: all 0.3s ease;
  }
  .mobile-menu-toggle.active .hamburger span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
  }
  .mobile-menu-toggle.active .hamburger span:nth-child(2) {
    opacity: 0;
  }
  .mobile-menu-toggle.active .hamburger span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
  }
  .search-popup {
    width: 100%;
    padding: 1.5rem 1rem;
  }
  .search-popup-title {
    font-size: 1.25rem;
    margin-bottom: 1rem;
  }
  .search-popup-input {
    font-size: 0.875rem;
    padding: 0.75rem 1rem;
  }
  .search-popup-btn {
    padding: 0.75rem 1.5rem;
    font-size: 0.8125rem;
  }
  .notification-popup {
    width: 100%;
    max-width: calc(100% - 2rem);
  }
}
/* 576px Breakpoint - Small Mobile */
@media (max-width: 576px) {
  .header-container {
    padding: 0.625rem 0.75rem;
  }
  .logo-section a img {
    height: 2.25rem;
  }
  .header-accent {
    padding: 0.625rem 0.75rem;
  }
  .search-btn,
  .notification-btn,
  .mobile-menu-toggle {
    width: 2.25rem;
    height: 2.25rem;
  }
  .user-profile-image {
    width: 1.75rem;
    height: 1.75rem;
  }
  .search-popup {
    padding: 1.25rem 0.75rem;
  }
  .search-popup-title {
    font-size: 1.125rem;
  }
  .search-popup-input {
    font-size: 0.8125rem;
    padding: 0.625rem 0.875rem;
  }
  .search-popup-btn {
    padding: 0.625rem 1.25rem;
    font-size: 0.75rem;
  }
}
/* ==================================================
   COMPONENTS FROM ORIGINAL STYLE.CSS
   ================================================== */
/* Notifications */
.notification-container {
  position: relative;
}

.notification-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  width: 21.875rem;
  background: var(--color-white, #FFFFFF);
  border-radius: 0.75rem;
  box-shadow: 0 0.625rem 0.9375rem rgba(0, 0, 0, 0.1);
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.625rem);
  transition: 0.3s ease-in-out;
  pointer-events: none;
}
.notification-dropdown.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.notification-header {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid #eee;
}
.notification-header h4 {
  margin: 0;
  color: var(--color-text-primary, #0D0D0D);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-semibold, 600);
}

.notification-list {
  max-height: 18.75rem;
  overflow-y: auto;
}

.notification-item {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--color-background-light, #F9F9FB);
  transition: 0.3s ease-in-out;
}
.notification-item:hover {
  background-color: var(--color-background-light, #F9F9FB);
}
.notification-item:last-child {
  border-bottom: none;
}

.notification-content h5 {
  margin: 0 0 0.25rem 0;
  color: var(--color-text-primary, #0D0D0D);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-semibold, 600);
}
.notification-content p {
  margin: 0 0 0.5rem 0;
  color: var(--color-text-muted, #808080);
  font-size: var(--font-size-xs, 12px);
  line-height: 1.4;
}

.notification-time {
  color: var(--color-text-secondary, #D6D6D6);
  font-size: var(--font-size-xs, 12px);
}

.notification-footer {
  padding: 1rem 1.5rem;
  border-top: 1px solid #eee;
  text-align: center;
}

.view-all-btn {
  color: var(--color-primary, #7F0723);
  text-decoration: none;
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-medium, 500);
  transition: 0.3s ease-in-out;
}
.view-all-btn:hover {
  color: var(--color-dark, #0D0D0D);
  text-decoration: none;
}

/* Hero Components */
.hero-image {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: linear-gradient(135deg, #f0f0f0, #e0e0e0);
  background-size: cover;
  background-position: center;
}

.hero-meta {
  position: absolute;
  height: 22.9375rem;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(8, 9, 13, 0) 0%, rgba(8, 9, 13, 0.9) 80.37%);
  backdrop-filter: blur(1px);
}

.hero-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 0 1rem 0 0;
  gap: 1rem;
  position: absolute;
  width: 53.375rem;
  max-width: calc(100% - 5rem);
  left: 2.5rem;
  top: 5.75rem;
}

.hero-meta-info {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 0;
  gap: 0.75rem;
  width: 20.75rem;
  max-width: 100%;
  height: 2.1875rem;
}

.hero-date {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-style: normal;
  font-weight: var(--font-weight-bold, 700);
  font-size: var(--font-size-base, 16px);
  line-height: 1.1875rem;
  text-transform: uppercase;
  color: var(--color-text-secondary, #D6D6D6);
}

.hero-separator {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 0;
  width: 0.3125rem;
  height: 1.25rem;
}

.hero-separator-text {
  width: 0.3125rem;
  height: 1.25rem;
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-style: normal;
  font-weight: var(--font-weight-normal, 400);
  font-size: var(--font-size-sm, 14px);
  line-height: 1.25rem;
  color: var(--color-text-secondary, #D6D6D6);
}

/* Badge */
.badge-big {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 0.5rem 1rem;
  gap: 0.5rem;
  width: 12.1875rem;
  height: 2.1875rem;
  background: var(--color-primary, #7F0723);
  border-radius: 50%;
}

.badge-icon {
  width: 1.1875rem;
  height: 1.1875rem;
  font-size: var(--font-size-lg, 18px);
}

.badge-text {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-style: normal;
  font-weight: var(--font-weight-bold, 700);
  font-size: var(--font-size-sm, 14px);
  line-height: 1.0625rem;
  text-align: center;
  text-transform: uppercase;
  color: var(--color-white, #FFFFFF);
}

/* Buttons */
.btn-primary {
  background: var(--btn-primary, #BF284B);
  border: 2px solid var(--btn-primary, #BF284B);
  border-radius: 2rem;
  color: var(--color-white, #FFFFFF);
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-semibold, 600);
  font-size: var(--font-size-sm, 14px);
  padding: 0.75rem 2.25rem;
  transition: all 0.3s ease;
  text-decoration: none;
  display: inline-flex;
  text-transform: uppercase;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.btn-primary:hover {
  background: var(--color-primary, #7F0723);
  border-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  transform: translateY(-1px);
  box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.15);
  opacity: 0.9;
  text-decoration: none;
}

.btn-secondary {
  background: transparent;
  border: 2px solid var(--color-primary, #7F0723);
  border-radius: 0.25rem;
  color: var(--color-primary, #7F0723);
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-semibold, 600);
  font-size: var(--font-size-sm, 14px);
  padding: 0.75rem 1.25rem;
  transition: all 0.3s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.btn-secondary:hover {
  background: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
}

/* Category Badges */
.category-badge {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  font-weight: var(--font-weight-semibold, 600);
  padding: 0.25rem 0.5rem;
  border-radius: 50%;
  text-transform: uppercase;
  letter-spacing: 0.03125rem;
}
.category-badge.avisos {
  background-color: #FEF3C7;
  color: #92400E;
}
.category-badge.procedimentos {
  background-color: #DBEAFE;
  color: #1E40AF;
}
.category-badge.normativas {
  background-color: #D1FAE5;
  color: #065F46;
}
.category-badge.comunicados {
  background-color: #FEE2E2;
  color: #991B1B;
}

/* Filter Components */
.filters-bar {
  display: flex;
  gap: 1rem;
  align-items: flex-end;
  flex-wrap: wrap;
}

.filter-group {
  display: flex;
  flex-direction: column;
  min-width: 9.375rem;
}
.filter-group label {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-medium, 500);
  color: var(--color-text-primary, #0D0D0D);
  margin-bottom: 0.25rem;
}
.filter-group .form-control {
  border: 1px solid #D6D6D6;
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
}
.filter-group .btn {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-medium, 500);
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
}

/* Search Bar */
.search-bar .form-control {
  border: 1px solid #D6D6D6;
  border-radius: 0.5rem 0 0 0.5rem;
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
}

.search-bar .btn {
  background-color: var(--color-primary, #7F0723);
  border-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  border-radius: 0 0.5rem 0.5rem 0;
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-medium, 500);
}

/* Pagination */
.pagination .page-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-medium, 500);
  color: var(--color-text-primary, #0D0D0D);
  border: 1px solid #D6D6D6;
  padding: 0.5rem 0.75rem;
  margin: 0 0.25rem;
  border-radius: 0.5rem;
}

.pagination .page-item.active .page-link {
  background-color: var(--color-primary, #7F0723);
  border-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
}

.pagination .page-link:hover {
  background-color: var(--color-background-light, #F9F9FB);
  border-color: var(--color-primary, #7F0723);
  color: var(--color-primary, #7F0723);
}

/* ==================================================
   FALLBACK IMAGE STYLES
   ================================================== */
/* Fallback image for all module cards - centered and resizable */
img[src*="/documents/d/global/fallback"],
img[src*="/documents/d/global/pdf"],
img[src*="/documents/d/global/doc"] {
  background-color: #F1F1F1;
  object-fit: contain !important;
  object-position: center;
  padding: 1rem;
}

/* Fallback for background images */
[style*=url][style*="/documents/d/global/fallback"] {
  background-color: #F1F1F1 !important;
  background-size: contain !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

/* ==================================================
   LAYOUT COMPONENTS FROM ORIGINAL STYLE.CSS
   ================================================== */
/* Main Homepage Container */
.homepage {
  position: relative;
  width: 100%;
  max-width: var(--container-width, 1920px);
  min-height: 100vh;
  background: var(--color-white, #FFFFFF);
  border-radius: 1.875rem;
  margin: 0 auto;
}

/* Hero Section */
.hero-slider {
  position: relative;
  width: 100%;
  max-width: var(--content-width, 1640px);
  height: 46.875rem;
  margin: 9.375rem auto 0;
  border-radius: 1.875rem;
  overflow: hidden;
}

/* Featured Cards Grid */
.featured-section {
  padding: 6.25rem 0;
}

.featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(21.875rem, 1fr));
  gap: 1.25rem;
  max-width: var(--content-width, 1640px);
  margin: 0 auto;
  padding: 0 1rem;
}

.featured-card {
  height: 15.625rem;
  background: var(--color-white, #FFFFFF);
  border-radius: 1rem;
  box-shadow: 0 2px 0.625rem rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: all 0.3s ease;
}
.featured-card:hover {
  box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.15);
  transform: translateY(-0.25rem);
}

.featured-card-image {
  width: 100%;
  height: 9.375rem;
  background: linear-gradient(135deg, #f5f5f5, #e8e8e8);
}

.featured-card-content {
  padding: 1rem;
}

.featured-card-title {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-bold, 700);
  font-size: var(--font-size-lg, 18px);
  color: var(--color-text-primary, #0D0D0D);
  margin-bottom: 0.5rem;
}

.featured-card-text {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: var(--font-weight-normal, 400);
  font-size: var(--font-size-sm, 14px);
  color: var(--color-text-muted, #808080);
  line-height: 1.6;
}

/* Communications List */
.communications-list {
  padding: 2rem 0;
}

.communication-card {
  background: var(--color-white, #FFFFFF);
  border: 1px solid #E5E5E5;
  border-radius: 1rem;
  overflow: hidden;
  transition: all 0.3s ease;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.communication-card:hover {
  transform: translateY(-0.25rem);
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.12);
  border-color: var(--color-primary, #7F0723);
}
.communication-card .card-header {
  padding: 1rem;
  border-bottom: 1px solid #F5F5F5;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.communication-card .date {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  color: var(--color-text-secondary, #D6D6D6);
  font-weight: var(--font-weight-medium, 500);
}
.communication-card .card-body {
  padding: 1rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}
.communication-card .card-title {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-text-primary, #0D0D0D);
  margin-bottom: 0.75rem;
  line-height: 1.4;
}
.communication-card .card-excerpt {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  color: var(--color-text-muted, #808080);
  line-height: 1.6;
  margin-bottom: 1rem;
  flex-grow: 1;
}
.communication-card .card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  color: var(--color-text-secondary, #D6D6D6);
}
.communication-card .author {
  font-weight: var(--font-weight-medium, 500);
}
.communication-card .views {
  font-weight: var(--font-weight-normal, 400);
}
.communication-card .card-footer {
  padding: 1rem;
  background-color: #FAFAFA;
  border-top: 1px solid #F5F5F5;
}
.communication-card .read-more {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-primary, #7F0723);
  text-decoration: none;
  transition: all 0.3s ease;
}
.communication-card .read-more:hover {
  color: var(--color-dark, #0D0D0D);
  text-decoration: none;
}

/* Footer */
.footer-section {
  background: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  padding: 4rem 2rem;
  margin-top: 4rem;
}

/* Footer Logo */
.footer-logo-img {
  height: 3.75rem;
  opacity: 0.5;
}

/* Footer Headings */
.footer-heading {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-white, #FFFFFF);
  margin-bottom: 0.75rem;
}

/* Footer Description */
.footer-description {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  line-height: 1.6;
  margin-bottom: 1rem;
}

/* Read More Link */
.footer-read-more {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  display: block;
  margin-bottom: 1rem;
  transition: 0.3s ease-in-out;
}
.footer-read-more:hover {
  color: var(--color-white, #FFFFFF);
  text-decoration: underline;
}

/* Social Links */
.footer-social {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
}

.footer-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-social-link:hover {
  background-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
  text-decoration: none;
  transform: translateY(-2px);
}

/* Copyright */
.footer-copyright-text {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0;
}

.footer-legal-links {
  display: flex;
  align-items: center;
}

.footer-legal-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-legal-link:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

.footer-separator {
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0 0.25rem;
}

/* Government Links */
.footer-gov-row {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.footer-gov-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-gov-link:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

/* Contact Info */
.footer-phone {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0 0 0.25rem 0;
  text-decoration: none;
  display: block;
  transition: 0.3s ease-in-out;
}
.footer-phone:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

/* Location */
.footer-address {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  margin: 0 0 0.25rem 0;
}

/* Languages */
.footer-lang-links {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
}

.footer-lang-link {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  font-weight: var(--font-weight-normal, 400);
  color: var(--color-white, #FFFFFF);
  opacity: 0.5;
  text-decoration: none;
  transition: 0.3s ease-in-out;
}
.footer-lang-link.active {
  opacity: 1;
  color: var(--color-white, #FFFFFF);
}
.footer-lang-link:hover {
  color: var(--color-white, #FFFFFF);
  opacity: 1;
  text-decoration: none;
}

/* Search Overlay */
.search-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity all 0.3s ease;
}
.search-overlay.show {
  display: flex;
  opacity: 1;
}

.search-form {
  position: relative;
  max-width: 37.5rem;
  width: 100%;
  background: var(--color-white, #FFFFFF);
  border-radius: 0.75rem;
  padding: 1.25rem;
  transform: translateY(-1.25rem);
  transition: transform all 0.3s ease;
}

.search-overlay.show .search-form {
  transform: translateY(0);
}

.search-close {
  position: absolute;
  top: -0.625rem;
  right: -0.625rem;
  background-color: var(--color-white, #FFFFFF);
  border-radius: 50%;
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 0.5rem rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}
.search-close:hover {
  background-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
}

/* Footer Styles for List Page */
.site-footer {
  background-color: var(--color-dark, #0D0D0D);
  color: var(--color-white, #FFFFFF);
  padding: 2rem 0 1rem;
}
.site-footer h4 {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-lg, 18px);
  font-weight: var(--font-weight-semibold, 600);
  margin-bottom: 1rem;
}
.site-footer p {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  line-height: 1.6;
  color: var(--color-text-secondary, #D6D6D6);
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-links li {
  margin-bottom: 0.5rem;
}
.footer-links a {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-sm, 14px);
  color: var(--color-text-secondary, #D6D6D6);
  text-decoration: none;
  transition: all 0.3s ease;
}
.footer-links a:hover {
  color: var(--color-white, #FFFFFF);
}

.social-links {
  display: flex;
  gap: 0.75rem;
}
.social-links .social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  color: var(--color-white, #FFFFFF);
  font-size: var(--font-size-sm, 14px);
  text-decoration: none;
  transition: all 0.3s ease;
}
.social-links .social-link:hover {
  background-color: var(--color-primary, #7F0723);
  color: var(--color-white, #FFFFFF);
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 1rem;
  margin-top: 2rem;
  text-align: center;
}
.footer-bottom p {
  font-family: var(--font-primary, "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-size: var(--font-size-xs, 12px);
  color: var(--color-text-secondary, #D6D6D6);
  margin: 0;
}

/* ==================================================
   FOOTER RESPONSIVE STYLES
   ================================================== */
/* 1200px Breakpoint */
@media (max-width: 1200px) {
  .footer-section {
    padding: 3rem 1.5rem;
    margin-top: 3rem;
  }
  .footer-logo-img {
    height: 3rem;
  }
  .footer-heading {
    font-size: 1rem;
    margin-bottom: 0.625rem;
  }
  .footer-description,
  .footer-read-more,
  .footer-phone,
  .footer-address,
  .footer-gov-link,
  .footer-legal-link,
  .footer-lang-link,
  .footer-copyright-text {
    font-size: 0.8125rem;
  }
  .footer-gov-row {
    gap: 0.75rem;
  }
  .footer-social-link,
  .social-link {
    width: 2.25rem;
    height: 2.25rem;
  }
}
/* 992px Breakpoint - Tablet */
@media (max-width: 992px) {
  .footer-section {
    padding: 2.5rem 1.25rem;
  }
  .footer-section .col-md-6 {
    width: 100%;
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6:first-child {
    text-align: center;
  }
  .footer-section .col-md-6.text-right {
    text-align: center;
  }
  .footer-gov-row {
    justify-content: center;
  }
  .footer-lang-links {
    justify-content: center;
  }
}
/* 768px Breakpoint - Mobile */
@media (max-width: 768px) {
  .footer-section {
    padding: 2.5rem 1rem;
  }
  .footer-section .row {
    flex-direction: column;
    gap: 2rem;
  }
  .footer-section .col-md-6 {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 0;
  }
  .footer-section .col-md-6:first-child {
    text-align: center;
  }
  .footer-section .col-md-6:first-child .footer-logo {
    justify-content: center;
    margin-bottom: 1.25rem;
  }
  .footer-section .col-md-6:first-child .social-icons {
    justify-content: center;
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6:first-child .footer-description {
    text-align: center;
    margin-bottom: 1rem;
    line-height: 1.5;
  }
  .footer-section .col-md-6:first-child .footer-read-more {
    text-align: center;
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6:first-child .footer-copyright {
    margin-top: 1.5rem;
  }
  .footer-section .col-md-6:first-child .footer-copyright-text,
  .footer-section .col-md-6:first-child .footer-legal-links {
    text-align: center;
    display: flex;
    justify-content: center;
  }
  .footer-section .col-md-6.text-right {
    text-align: center !important;
  }
  .footer-section .col-md-6.text-right .footer-gov-links {
    margin-bottom: 2rem;
  }
  .footer-section .col-md-6.text-right .footer-gov-row {
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
  .footer-section .col-md-6.text-right .footer-contact,
  .footer-section .col-md-6.text-right .footer-location {
    margin-bottom: 1.5rem;
  }
  .footer-section .col-md-6.text-right .footer-phone-numbers {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: center;
  }
  .footer-section .col-md-6.text-right .footer-lang-links {
    justify-content: center;
  }
  .footer-logo-img {
    height: 2.75rem;
  }
  .footer-heading {
    font-size: 1rem;
    margin-bottom: 0.875rem;
    font-weight: 700;
  }
  .footer-description {
    font-size: 0.8125rem;
    line-height: 1.5;
  }
  .footer-phone,
  .footer-address {
    font-size: 0.8125rem;
  }
  .footer-gov-link {
    flex: 1 1 calc(50% - 0.25rem);
    min-width: 120px;
    text-align: center;
    font-size: 0.75rem;
    padding: 0.375rem 0.5rem;
  }
  .footer-copyright-text,
  .footer-legal-link,
  .footer-lang-link {
    font-size: 0.75rem;
  }
}
/* 576px Breakpoint - Small Mobile */
@media (max-width: 576px) {
  .footer-section {
    padding: 2rem 1rem;
  }
  .footer-section .row {
    gap: 1.5rem;
  }
  .footer-logo-img {
    height: 2.5rem;
  }
  .footer-heading {
    font-size: 0.9375rem;
    margin-bottom: 0.75rem;
  }
  .footer-description {
    font-size: 0.75rem;
    line-height: 1.5;
    margin-bottom: 0.875rem;
  }
  .footer-read-more {
    font-size: 0.75rem;
    margin-bottom: 1.25rem;
  }
  .footer-phone,
  .footer-address {
    font-size: 0.75rem;
  }
  .footer-gov-link {
    font-size: 0.6875rem;
    min-width: 100px;
    padding: 0.25rem 0.375rem;
  }
  .footer-copyright-text,
  .footer-legal-link,
  .footer-lang-link {
    font-size: 0.6875rem;
  }
  .footer-social-link,
  .social-link {
    width: 2.25rem;
    height: 2.25rem;
    font-size: 0.75rem;
  }
  .footer-gov-links,
  .footer-contact,
  .footer-location {
    margin-bottom: 1.25rem;
  }
}
/* ==================================================
   BREADCRUMB STYLES - PGS PORTAL
   ================================================== */
.breadcrumb-section {
  margin-bottom: 2.5rem !important;
  padding-bottom: 1.875rem !important;
  border-bottom: 1px solid #D6D6D6 !important;
  background: unset;
}

.breadcrumb-content {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.breadcrumb-left {
  display: flex;
  flex-direction: column;
}

.page-title {
  font-size: 3.125rem;
  font-weight: 500;
  color: #0D0D0D;
  margin: 0;
  line-height: 1.1;
}

.breadcrumb-nav {
  display: flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 500;
}

.breadcrumb-link {
  color: var(--btn-primary, #BF284B);
  text-decoration: none;
}
.breadcrumb-link:hover {
  text-decoration: underline;
}

.breadcrumb-arrow {
  color: #808080;
  font-size: 0.875rem;
  margin: 0 0.5rem;
}

.breadcrumb-pagination {
  color: #808080;
}

.breadcrumb-right {
  display: flex;
  gap: 0.625rem;
  justify-content: flex-end;
}

/* Breadcrumb Category */
.breadcrumb-category {
  margin-bottom: 0.75rem;
}

.category-tag {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--color-black);
  background-color: var(--color-white);
  border: 1px solid #D6D6D6;
  border-radius: 1.25rem;
  padding: 0.5rem 1rem;
  letter-spacing: 0.03125rem;
}

/* Bootstrap Breadcrumb Navigation */
.breadcrumb {
  background: transparent;
  padding: 0;
  margin: 0;
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
}

.breadcrumb-item {
  color: var(--color-text-muted);
}
.breadcrumb-item + .breadcrumb-item {
  padding-left: 1.25rem;
}
.breadcrumb-item + .breadcrumb-item::before {
  color: var(--color-text-muted);
  padding: 0 0.5rem;
  top: 45%;
  background-size: 0.75rem;
  bottom: 0;
  height: 0.875rem;
  width: 0.875rem;
}
.breadcrumb-item a {
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.3s ease;
}
.breadcrumb-item a:hover {
  color: var(--color-primary);
  text-decoration: none;
}
.breadcrumb-item.active {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-bold);
}

/* Last Modified Info */
.last-modified {
  text-align: right;
}

.last-modified-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: 500;
  color: #616161;
  font-style: italic;
}

.last-modified-date {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
}

/* Responsive Design */
@media (max-width: 992px) {
  .breadcrumb-section {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}
@media (max-width: 768px) {
  .breadcrumb-section {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
  .breadcrumb-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.25rem;
  }
  .breadcrumb-right {
    align-self: flex-end;
  }
  .page-title {
    font-size: 2.5rem;
  }
  .breadcrumb-section .container .row {
    flex-direction: column;
    gap: 1rem;
  }
  .last-modified {
    text-align: left;
  }
  .category-tag {
    font-size: 0.75rem;
    padding: 0.375rem 0.75rem;
    border-radius: 1rem;
  }
  .breadcrumb {
    font-size: var(--font-size-xs);
  }
  .last-modified-label {
    font-size: 0.625rem;
  }
  .last-modified-date {
    font-size: var(--font-size-sm);
  }
}
@media (max-width: 576px) {
  .breadcrumb-section {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }
  .page-title {
    font-size: 2rem;
  }
}
/* ==================================================
   FEATURE IMAGE SECTION
   ================================================== */
.feature-image-section {
  margin-top: 2.5rem;
  margin-bottom: 3.75rem;
}

.feature-image-container {
  position: relative;
  width: 100%;
  height: 31.25rem;
  border-radius: 1.875rem;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}

.feature-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1.875rem;
}

.feature-controls {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  display: flex;
  gap: 0.75rem;
  z-index: 2;
}

.read-time-btn,
.favorite-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  border: none;
  border-radius: 3.125rem;
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
  text-transform: uppercase;
}

.read-time-btn {
  background: rgba(0, 0, 0, 0.1490196078);
  color: var(--color-white);
  backdrop-filter: blur(0.625rem);
}

.read-time-btn:hover {
  background: rgba(0, 0, 0, 0.5);
}

.favorite-btn {
  background: var(--color-white);
  color: var(--color-text-primary);
}

.favorite-btn:hover {
  background: #f5f5f5;
  color: var(--color-primary);
}

.feature-content {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  right: 2rem;
  z-index: 2;
  max-width: 50%;
}

.feature-meta {
  margin-bottom: 1rem;
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-white);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.feature-date,
.feature-category {
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}

.feature-category {
  background: rgba(255, 255, 255, 0.1490196078);
  border-radius: 1.25rem;
  padding: 0.5rem 1rem;
}

.meta-separator {
  opacity: 0.7;
}

.feature-title {
  font-family: var(--font-primary);
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1.2;
  color: var(--color-white);
  margin: 0;
  text-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.3);
}

/* Add gradient overlay for better text readability */
.feature-image-container::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(8, 9, 13, 0) 0%, rgba(8, 9, 13, 0.9) 80.37%);
  border-radius: 1.875rem;
  z-index: 1;
  backdrop-filter: blur(0.125rem);
}

/* Responsive adjustments for feature image */
@media (max-width: 992px) {
  .feature-image-section {
    margin-top: 2rem;
    margin-bottom: 2rem;
  }
  .feature-content {
    max-width: 60%;
  }
  .feature-title {
    font-size: 2.25rem;
  }
}
@media (max-width: 768px) {
  .feature-image-section {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
  }
  .feature-image-container {
    height: 25rem;
    border-radius: 1.25rem;
  }
  .feature-image {
    border-radius: 1.25rem;
  }
  .feature-image-container::before {
    border-radius: 1.25rem;
  }
  .feature-controls {
    top: 1rem;
    right: 1rem;
    flex-direction: column;
    gap: 0.5rem;
  }
  .read-time-btn,
  .favorite-btn {
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-xs);
  }
  .feature-content {
    bottom: 1.5rem;
    left: 1.5rem;
    right: 1.5rem;
    max-width: 85%;
  }
  .feature-title {
    font-size: 1.75rem;
  }
  .feature-meta {
    font-size: var(--font-size-sm);
  }
}
@media (max-width: 576px) {
  .feature-image-container {
    height: 21.875rem;
    border-radius: 1rem;
  }
  .feature-image,
  .feature-image-container::before {
    border-radius: 1rem;
  }
  .feature-controls {
    top: 0.75rem;
    right: 0.75rem;
    gap: 0.375rem;
  }
  .read-time-btn,
  .favorite-btn {
    padding: 0.375rem 0.625rem;
    font-size: 0.625rem;
    gap: 0.25rem;
  }
  .feature-content {
    bottom: 1.25rem;
    left: 1.25rem;
    right: 1.25rem;
    max-width: 90%;
  }
  .feature-title {
    font-size: 1.5rem;
    line-height: 1.3;
  }
  .feature-meta {
    font-size: var(--font-size-xs);
    margin-bottom: 0.75rem;
  }
  .feature-date,
  .feature-category {
    font-size: var(--font-size-xs);
  }
}
@media (max-width: 480px) {
  .feature-controls {
    position: relative;
    top: auto;
    right: auto;
    margin: 0.75rem;
    justify-content: flex-end;
  }
  .feature-content {
    max-width: 100%;
  }
  .feature-title {
    font-size: 1.375rem;
  }
}
/* ==================================================
   NEWS ARTICLE CONTENT
   ================================================== */
.news-detail-page {
  padding: 0 0 3.75rem;
}

.news-article {
  max-width: 100%;
}

.article-content {
  margin-bottom: 2.5rem;
}

.article-intro {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-normal);
  line-height: 1.7;
  color: var(--color-text-primary);
  margin-bottom: 2.5rem;
}

.article-content h2 {
  font-family: var(--font-primary);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-top: 2.5rem;
  margin-bottom: 1.25rem;
  line-height: 1.3;
}

.article-content p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  line-height: 1.7;
  color: var(--color-text-primary);
  margin-bottom: 1.5rem;
}

.article-tags {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.tags-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-right: 0.5rem;
}

.tags-list {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.tag {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  color: var(--color-black);
  background-color: var(--color-white);
  border: 1px solid #D6D6D6;
  border-radius: 1.25rem;
  padding: 0.5rem 1rem;
  letter-spacing: 0.03125rem;
  cursor: pointer;
  transition: all 0.3s ease;
}

.tag:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* Responsive adjustments for article */
@media (max-width: 992px) {
  .news-detail-page {
    padding: 3.125rem 0;
  }
  .article-intro {
    font-size: var(--font-size-base);
    margin-bottom: 2.25rem;
  }
  .article-content h2 {
    font-size: var(--font-size-xl);
    margin-top: 2.25rem;
    margin-bottom: 1.125rem;
  }
}
@media (max-width: 768px) {
  .news-detail-page {
    padding: 2.5rem 0;
  }
  .news-detail-page .container {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
  .col-lg-8 {
    padding-left: 0;
    padding-right: 0;
  }
  .article-intro {
    font-size: var(--font-size-base);
    margin-bottom: 2rem;
    line-height: 1.6;
  }
  .article-content h2 {
    font-size: var(--font-size-xl);
    margin-top: 2rem;
    margin-bottom: 1rem;
    line-height: 1.4;
  }
  .article-content p {
    font-size: var(--font-size-sm);
    margin-bottom: 1.25rem;
    line-height: 1.6;
  }
  .article-tags {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    padding-top: 1.5rem;
  }
  .tags-label {
    margin-right: 0;
    font-size: var(--font-size-sm);
  }
  .tag {
    font-size: 0.75rem;
    padding: 0.375rem 0.75rem;
    border-radius: 1rem;
  }
}
@media (max-width: 576px) {
  .news-detail-page {
    padding: 2rem 0;
  }
  .news-detail-page .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .article-intro {
    font-size: var(--font-size-sm);
    margin-bottom: 1.75rem;
    line-height: 1.5;
  }
  .article-content h2 {
    font-size: var(--font-size-lg);
    margin-top: 1.75rem;
    margin-bottom: 0.875rem;
    line-height: 1.3;
  }
  .article-content p {
    font-size: 0.875rem;
    margin-bottom: 1.125rem;
    line-height: 1.5;
  }
  .article-tags {
    padding-top: 1.25rem;
    gap: 0.625rem;
  }
  .tags-label {
    font-size: 0.875rem;
  }
  .tag {
    font-size: 0.6875rem;
    padding: 0.3125rem 0.625rem;
    border-radius: 0.875rem;
  }
}
@media (max-width: 480px) {
  .news-detail-page .container {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
  .article-content h2 {
    font-size: var(--font-size-base);
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
  }
  .article-content p {
    font-size: 0.8125rem;
    margin-bottom: 1rem;
  }
  .article-intro {
    font-size: 0.875rem;
    margin-bottom: 1.5rem;
  }
}
/* ==================================================
   FORMS AND INPUT FIELDS - PGS PORTAL
   ================================================== */
/* Form Variables */
/* Form Groups */
.form-group {
  margin-bottom: 1.5rem;
  position: relative;
}

/* Form Controls */
.form-control {
  width: 100%;
  max-width: 33.125rem;
  height: 4.25rem;
  padding: 2rem 3.75rem 1rem 3.75rem;
  border: 1px solid #D6D6D6;
  border-radius: 0.75rem;
  font-family: var(--font-primary);
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 100%;
  letter-spacing: -2%;
  color: var(--color-text-primary);
  background: var(--color-white);
  transition: all 0.3s ease;
}

.form-control:focus {
  outline: none;
  border-color: var(--btn-primary, #BF284B);
  box-shadow: 0 0 0 0.2rem rgba(191, 40, 75, 0.25);
}

.form-control.disabled-input {
  background-color: #F5F5F5;
  color: var(--color-text-muted);
  border-color: #D6D6D6;
  cursor: not-allowed;
}

.form-control.filled + .form-label {
  top: 1.25rem;
  left: 3.5rem;
  transform: translateY(-50%);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 100%;
  letter-spacing: -2%;
  color: var(--color-text-muted);
  margin-bottom: 0;
}

/* Floating Labels */
.form-label {
  position: absolute;
  left: 3.75rem;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  pointer-events: none;
  transition: all 0.3s ease;
  background: transparent;
  padding: 0 0.25rem;
  z-index: 5;
}

.form-control:not(:placeholder-shown) + .form-label {
  left: 3.5rem;
  transform: translateY(-50%);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 100%;
  letter-spacing: -2%;
  color: var(--color-text-muted);
  margin-bottom: 0;
}

.form-control:focus + .form-label, .form-control.filled + .form-label {
  top: 1.25rem;
}

.form-control:focus + .form-label {
  color: var(--btn-primary, #BF284B);
}

/* Form Icons */
.form-icon {
  position: absolute;
  left: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.25rem;
  color: #666666;
  z-index: 6;
}

/* Password Toggle */
.password-toggle {
  position: absolute;
  right: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 1.25rem;
  color: #666666;
  cursor: pointer;
  transition: color 0.3s ease;
  z-index: 10;
}

.password-toggle:hover {
  color: var(--btn-primary, #BF284B);
}

/* Select Dropdown */
select.form-control {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 1.25rem center;
  background-repeat: no-repeat;
  background-size: 1rem 1rem;
  padding-right: 3.75rem;
  appearance: none;
}

select.form-control:focus {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23BF284B' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
}

/* Custom Checkbox */
.terms-checkbox, .custom-checkbox-wrapper {
  display: flex;
  align-items: center;
  margin-bottom: 1.875rem;
  max-width: 33.125rem;
}

.custom-checkbox {
  width: 1.25rem;
  height: 1.25rem;
  margin-right: 0.75rem;
  flex-shrink: 0;
}

.custom-checkbox input[type=checkbox] {
  display: none;
}

.checkmark {
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  background: var(--color-white);
  border: 2px solid #D6D6D6;
  border-radius: var(--border-radius-sm);
  position: relative;
  cursor: pointer;
  transition: all 0.3s ease;
}

.custom-checkbox input[type=checkbox]:checked + .checkmark {
  background: var(--btn-primary, #BF284B);
  border-color: var(--btn-primary, #BF284B);
}

.custom-checkbox input[type=checkbox]:checked + .checkmark:after {
  content: "✓";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: var(--color-white);
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
}

/* Terms Text */
.terms-text {
  font-family: var(--font-primary);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
  line-height: 100%;
  letter-spacing: -2%;
  color: var(--color-text-muted);
}

.terms-text a {
  font-family: var(--font-primary);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  line-height: 100%;
  letter-spacing: -2%;
  color: var(--btn-primary, #BF284B);
  text-decoration: none;
  transition: opacity 0.3s ease;
}

.terms-text a:hover {
  text-decoration: underline;
  opacity: 0.8;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .form-control {
    height: 3.75rem;
    padding: 1.25rem 1.25rem 1.25rem 3.125rem;
    max-width: 100%;
  }
  .form-icon {
    left: 1.25rem;
    font-size: 1.125rem;
  }
  .password-toggle {
    right: 1.25rem;
    font-size: 1.125rem;
  }
}
@media (max-width: 576px) {
  .form-control {
    height: 3.5rem;
    padding: 1.125rem 1.125rem 1.125rem 2.8125rem;
  }
  .form-icon {
    left: 1.125rem;
    font-size: 1rem;
  }
  .password-toggle {
    right: 1.125rem;
    font-size: 1rem;
  }
}
/* ==================================================
   PROFILE PAGE STYLES - PGS PORTAL
   ================================================== */
.profile-page {
  /* Profile Container */
  /* Left Sidebar */
  /* Form Styles */
  /* Customization Section */
  /* Profile Image Section */
  /* Notification Preferences Section */
  /* Toggle Switch Styles */
  /* Notification Items */
}
.profile-page .profile-container {
  margin-bottom: 7.5rem;
  padding-top: 1.875rem;
}
.profile-page .profile-sidebar {
  background: #F9F9FB;
  border-radius: 1.875rem;
  padding: 1.875rem 2.5rem;
  gap: 2.5rem;
  display: flex;
  flex-direction: column;
}
.profile-page .sidebar-heading {
  font-family: var(--font-primary);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 100%;
  letter-spacing: -2%;
  color: #0D0D0D;
  margin: 0 0 1.25rem 0;
}
.profile-page .profile-nav {
  display: flex;
  flex-direction: column;
}
.profile-page .profile-nav-link {
  font-family: var(--font-primary);
  font-weight: 900;
  font-size: 1rem;
  line-height: 100%;
  letter-spacing: 0%;
  color: #000000;
  text-decoration: none;
  padding: 0.9375rem 0;
  border-bottom: 1px solid transparent;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s ease;
}
.profile-page .profile-nav-link:hover {
  color: var(--btn-primary, #BF284B);
  text-decoration: none;
}
.profile-page .profile-nav-link:hover i {
  transform: translateX(0.1875rem);
}
.profile-page .profile-nav-link.active {
  color: var(--btn-primary, #BF284B);
}
.profile-page .profile-nav-link i {
  font-size: 0.875rem;
  transition: transform 0.3s ease;
}
.profile-page .section-heading {
  font-family: var(--font-primary);
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 100%;
  letter-spacing: -2%;
  color: #0D0D0D;
  margin-bottom: 0.25rem;
}
.profile-page .section-description {
  font-family: var(--font-primary);
  font-weight: 900;
  font-size: 0.875rem;
  line-height: 100%;
  letter-spacing: 5%;
  text-transform: uppercase;
  color: #616161;
  margin-bottom: 2.5rem;
}
.profile-page .profile-form,
.profile-page .password-form {
  margin-bottom: 3.75rem;
}
.profile-page .profile-page .password-form .form-group {
  max-width: 33.125rem;
}
.profile-page .profile-form .row:last-child {
  margin-bottom: 0;
}
.profile-page .favorites-section {
  max-width: 100%;
}
.profile-page .favorites-heading {
  color: #808080;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1rem;
  line-height: 100%;
  letter-spacing: -2%;
  margin-bottom: 1rem;
}
.profile-page .category-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}
.profile-page .category-tag {
  background: var(--btn-primary, #BF284B);
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 1.5625rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.875rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.profile-page .category-tag i {
  background: white;
  color: var(--btn-primary, #BF284B);
  border-radius: 50%;
  width: 0.875rem;
  height: 0.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  cursor: pointer;
}
.profile-page .section-divider {
  border: none;
  height: 1px;
  background: #D6D6D6;
  margin: 1.5rem 0;
}
.profile-page .add-categories-text {
  color: #0D0D0D;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 100%;
  letter-spacing: 0%;
  margin-bottom: 1.5rem;
}
.profile-page .profile-image-container {
  margin-bottom: 3.75rem;
}
.profile-page .current-profile-image {
  width: 22.5rem;
  height: 22.5rem;
  border-radius: 1rem;
  border: 1.25rem solid #F9F9FB;
  object-fit: cover;
}
.profile-page .profile-image-actions {
  display: flex;
  gap: 1.5rem;
  justify-content: flex-start;
}
.profile-page .profile-image-actions .btn-primary svg {
  margin-left: 5px;
  height: 13px;
}
.profile-page .notification-preferences-container {
  max-width: 100%;
}
.profile-page .notification-header-section {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid #E0E0E0;
}
.profile-page .notification-section-title {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.75rem;
  line-height: 100%;
  letter-spacing: -2%;
  color: #0D0D0D;
  margin: 0;
}
.profile-page .enable-all-container {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.profile-page .enable-all-label {
  font-family: var(--font-primary);
  font-weight: 700;
  font-size: 1rem;
  line-height: 100%;
  color: #0D0D0D;
}
.profile-page .toggle-switch {
  position: relative;
  width: 3.375rem; /* 54px */
  height: 1.875rem; /* 30px */
  background: #E0E0E0;
  border: none;
  border-radius: 1.875rem;
  cursor: pointer;
  transition: background-color 0.3s ease;
  padding: 0;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1) inset;
}
.profile-page .toggle-switch.active {
  background: #7CC040;
}
.profile-page .toggle-switch:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.profile-page .toggle-switch .toggle-slider {
  position: absolute;
  top: 0.1875rem; /* 3px */
  left: 0.1875rem; /* 3px */
  width: 1.5rem; /* 24px */
  height: 1.5rem; /* 24px */
  background: white;
  border-radius: 50%;
  transition: transform 0.3s ease;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.15);
}
.profile-page .toggle-switch.active .toggle-slider {
  transform: translateX(1.5rem); /* 24px */
}
.profile-page .toggle-switch-small {
  width: 2.25rem; /* 36px */
  height: 1.25rem; /* 20px */
  border-radius: 1.25rem;
}
.profile-page .toggle-switch-small .toggle-slider {
  top: 0.125rem; /* 2px */
  left: 0.125rem; /* 2px */
  width: 1rem; /* 16px */
  height: 1rem; /* 16px */
}
.profile-page .toggle-switch-small.active .toggle-slider {
  transform: translateX(1rem); /* 16px */
}
.profile-page .notification-items {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.profile-page .notification-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0;
  border-bottom: 1px solid #F0F0F0;
}
.profile-page .notification-item:last-child {
  border-bottom: none;
}
.profile-page .notification-item-content {
  flex: 1;
}
.profile-page .notification-item-title {
  font-family: var(--font-primary);
  font-weight: 700;
  font-size: 1.375rem; /* 22px */
  line-height: 120%;
  letter-spacing: -1%;
  color: #0D0D0D;
  margin: 0 0 0.5rem 0;
}
.profile-page .notification-item-description {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.875rem; /* 14px */
  line-height: 140%;
  color: #616161;
  margin: 0;
}

/* Responsive Design */
@media (max-width: 991.98px) {
  .profile-page .profile-container {
    margin-bottom: 5rem;
  }
  .profile-page .profile-sidebar {
    margin-bottom: 1.875rem;
    padding: 1.25rem 1.875rem;
  }
  .profile-page .section-heading {
    font-size: 2rem;
  }
  .profile-page .profile-form .row {
    margin-bottom: 0;
  }
  .profile-page .profile-form .col-md-6 {
    margin-bottom: 1.5rem;
  }
  .profile-page .profile-image-actions {
    justify-content: center;
  }
  .profile-page .category-tags {
    justify-content: center;
  }
  .profile-page .notification-header-section {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
  .profile-page .notification-section-title {
    font-size: 1.5rem;
  }
  .profile-page .profile-nav {
    border-radius: 0.9375rem;
    overflow: hidden;
  }
  .profile-page .profile-nav-link {
    background: white;
    margin-bottom: 2px;
    padding: 0.9375rem 1.25rem;
    border-radius: 0.5rem;
  }
  .profile-page .profile-nav-link:last-child {
    margin-bottom: 0;
  }
  .profile-page .profile-nav-link.active {
    background: var(--btn-primary, #BF284B);
    color: white;
  }
  .profile-page .profile-nav-link.active:hover {
    color: white;
  }
}
@media (max-width: 767px) {
  .profile-page .profile-container {
    margin-bottom: 3.75rem;
    padding-top: 1.25rem;
  }
  .profile-page .profile-sidebar {
    border-radius: 1.25rem;
    padding: 1.25rem 1.5625rem;
  }
  .profile-page .sidebar-heading {
    font-size: 1rem;
    margin-bottom: 0.9375rem;
  }
  .profile-page .profile-nav-link {
    font-size: 0.875rem;
    padding: 0.75rem 0;
  }
  .profile-page .section-heading {
    font-size: 1.75rem;
  }
  .profile-page .section-description {
    font-size: 0.75rem;
    margin-bottom: 1.875rem;
  }
  .profile-page .form-control {
    max-width: 100%;
  }
  .profile-page .profile-image-actions {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
  }
  .profile-page .btn {
    width: 100%;
    max-width: 18.75rem;
    justify-content: center;
  }
  .profile-page .current-profile-image {
    width: 9.375rem;
    height: 9.375rem;
    border-width: 0.9375rem;
  }
  .profile-page .notification-section-title {
    font-size: 1.375rem;
  }
  .profile-page .notification-item-title {
    font-size: 1.125rem;
  }
  .profile-page .notification-item-description {
    font-size: 0.8125rem;
  }
}
@media (max-width: 576px) {
  .profile-page .profile-sidebar {
    padding: 0.9375rem 1.25rem;
  }
  .profile-page .section-heading {
    font-size: 1.5rem;
  }
  .profile-page .favorites-heading {
    font-size: 0.875rem;
  }
  .profile-page .add-categories-text {
    font-size: 1rem;
  }
  .profile-page .category-tag {
    font-size: 0.75rem;
    padding: 0.375rem 0.75rem;
  }
  .profile-page .current-profile-image {
    width: 7.5rem;
    height: 7.5rem;
    border-width: 0.625rem;
  }
  .profile-page .notification-section-title {
    font-size: 1.125rem;
  }
  .profile-page .enable-all-label {
    font-size: 0.875rem;
  }
  .profile-page .notification-item-title {
    font-size: 1rem;
  }
  .profile-page .notification-item-description {
    font-size: 0.75rem;
  }
  .profile-page .notification-items {
    gap: 1rem;
  }
  .profile-page .notification-item {
    padding: 1rem 0;
  }
}
/* ==================================================
   LISTING PAGE STYLES - PGS PORTAL
   ================================================== */
/* News Card Styles */
.news-card {
  display: inline-block;
  vertical-align: top;
  margin-bottom: 1.875rem;
}

.card-image-container {
  position: relative;
  width: 100%;
  height: 15.625rem;
  border-radius: 1.5rem;
  margin-bottom: 1.5rem;
  overflow: hidden;
}

.card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.video-overlay {
  position: absolute;
  bottom: 0;
  left: 10%;
  transform: translate(-50%, -50%);
  width: 3.75rem;
  height: 3.75rem;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(0.52083rem);
  box-shadow: -0.01875rem 0.01875rem 0.01875rem -0.038125rem rgba(255, 255, 255, 0.35) inset;
  border: 0.42px solid;
  border-image-source: linear-gradient(202.36deg, rgba(255, 255, 255, 0.2) 8.26%, rgba(255, 255, 255, 0) 85.43%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.video-overlay i {
  font-size: 1.5rem;
  color: white;
  margin-left: 2px;
}

.card-meta {
  font-size: 0.75rem;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.card-date {
  color: #666;
}

.card-separator {
  color: #666;
}

.card-category {
  border: 1px solid #D6D6D6;
  border-radius: 1.5625rem;
  padding: 0.25rem 0.75rem;
  background: none;
  font-size: 0.75rem;
  text-transform: uppercase;
  font-weight: 700;
  color: #333;
  text-decoration: none;
  display: inline-block;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.card-category:hover {
  background-color: #f5f5f5;
}

.card-title {
  font-size: 1.375rem;
  font-weight: 700;
  margin: 0 0 0.5rem 0;
}
.card-title a {
  color: #333;
  text-decoration: none;
}
.card-title a:hover {
  text-decoration: underline;
}

.card-description {
  font-size: 0.875rem;
  font-weight: 500;
  color: #666;
  margin: 0;
  line-height: 1.4;
}

/* Loading and Error States */
.loading {
  text-align: center;
  padding: 2.5rem;
  font-size: 1rem;
  color: #666;
}

.error {
  text-align: center;
  padding: 2.5rem;
  font-size: 1rem;
  color: #d32f2f;
  background-color: #ffebee;
  border-radius: 0.5rem;
  margin: 1.25rem 0;
}

.no-results {
  text-align: center;
  padding: 3.75rem 1.25rem;
}

.taglib-empty-result-message-description {
  font-size: 1rem;
  color: #666;
}

/* Pagination Styles */
.pagination-section {
  border-top: 1px solid #D6D6D6;
  padding-top: 1.875rem;
  margin-top: 1.875rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pagination-controls {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

.pagination-btn {
  background: white;
  border: 1px solid #D6D6D6;
  color: #333;
  font-size: 1rem;
  font-weight: 600;
  padding: 0.5rem 0.75rem;
  border-radius: 0.25rem;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
}
.pagination-btn:hover:not(:disabled) {
  background-color: #f5f5f5;
}
.pagination-btn.active {
  background-color: var(--btn-primary, #BF284B);
  color: white;
  border-color: var(--btn-primary, #BF284B);
}
.pagination-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.results-per-page {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
}
.results-per-page select {
  font-size: 1rem;
  font-weight: 400;
  padding: 0.375rem 0.75rem;
  border: 1px solid #D6D6D6;
  border-radius: 0.5rem;
  background: white;
  cursor: pointer;
}

/* Breadcrumb Right Section */
.breadcrumb-right {
  display: flex;
  gap: 0.625rem;
}

.search-filter-btn {
  padding: 0.625rem 1.5rem;
  background: var(--btn-primary, #BF284B);
  color: white;
  border: none;
  border-radius: 1.5625rem;
  font-size: 1rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.search-filter-btn:hover {
  background: #a0213d;
}
.search-filter-btn i {
  font-size: 1rem;
}

.clear-filters-btn {
  padding: 0.625rem 1.5rem;
  background: #6c757d;
  color: white;
  border: none;
  border-radius: 1.5625rem;
  font-size: 1rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.clear-filters-btn:hover {
  background: #5a6268;
}
.clear-filters-btn i {
  font-size: 1rem;
}

/* Breadcrumb Pagination */
.breadcrumb-pagination {
  color: #808080;
}

.breadcrumb-arrow {
  color: var(--btn-primary, #BF284B);
  font-size: 0.875rem;
}

/* Responsive Design */
@media (max-width: 767px) {
  .search-result .result-found {
    flex-direction: column-reverse;
    align-items: flex-start;
    margin-top: 1.875rem;
    gap: 1.25rem;
  }
  .news-card {
    margin-bottom: 1.25rem;
  }
  .card-meta {
    font-size: 0.6875rem;
  }
  .card-category {
    font-size: 0.6875rem;
    max-width: 150px;
    padding: 0.1875rem 0.625rem;
  }
  .card-date {
    font-size: 0.6875rem;
  }
  .pagination-section {
    flex-direction: column;
    gap: 1.25rem;
    align-items: stretch;
  }
  .pagination-controls {
    justify-content: center;
  }
  .results-per-page {
    justify-content: center;
  }
  .breadcrumb-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.25rem;
  }
  .breadcrumb-right {
    align-self: flex-end;
    gap: 0.75rem;
  }
  .page-title {
    font-size: 2.5rem;
  }
}
@media (max-width: 576px) {
  .card-meta {
    font-size: 0.625rem;
    gap: 0.375rem;
  }
  .card-category {
    font-size: 0.625rem;
    max-width: 120px;
    padding: 0.125rem 0.5rem;
  }
  .card-date {
    font-size: 0.625rem;
  }
  .card-image-container {
    height: 12rem;
    margin-bottom: 1rem;
  }
  .card-title {
    font-size: 1.125rem;
    margin-bottom: 0.375rem;
  }
  .card-description {
    font-size: 0.8125rem;
  }
}
/* ==================================================
   NEWS SLIDER STYLES - PGS PORTAL
   ================================================== */
.news-slider-section {
  margin-bottom: 1.5rem;
  position: relative;
}

.slider-container {
  position: relative;
  width: 100%;
  height: 46.875rem;
  border-radius: 1.875rem;
  overflow: hidden;
}

.slider-track {
  display: flex;
  transition: transform 0.5s ease-in-out;
  height: 100%;
}

.slide {
  min-width: 100%;
  height: 100%;
  position: relative;
  background-size: cover;
  background-position: center;
}

.slide-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 50%;
  padding: 1.875rem 2.5rem 3.4375rem 2.5rem;
  backdrop-filter: blur(0.125rem);
  background: linear-gradient(180deg, rgba(8, 9, 13, 0) 0%, rgba(8, 9, 13, 0.9) 80.37%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.slide-top-controls {
  position: absolute;
  top: 1.25rem;
  right: 2.5rem;
  z-index: 10;
}

.read-time-badge {
  background: rgba(0, 0, 0, 0.7);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 1.25rem;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  gap: 0.375rem;
  backdrop-filter: blur(0.625rem);
}

.slide-content {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1.5rem;
}

.slide-info {
  flex: 1;
}

.slide-meta {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.875rem;
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-transform: uppercase;
  font-weight: 600;
}
.slide-meta .meta-separator {
  margin: 0 0.25rem;
}

.slide-title {
  color: white;
  font-size: 2rem;
  font-weight: 700;
  margin: 0;
  line-height: 1.3;
  max-width: 37.5rem;
}

.slide-cta {
  flex-shrink: 0;
}

.read-more-btn {
  background: white;
  color: #000;
  border: none;
  padding: 0.875rem 1.75rem;
  border-radius: 0.5rem;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.625rem;
  transition: all 0.3s ease;
  text-decoration: none;
}
.read-more-btn:hover {
  transform: translateY(-0.125rem);
  box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.2);
}
.read-more-btn i {
  font-size: 1.125rem;
}

.slider-dots {
  display: flex;
  gap: 0.5rem;
  position: absolute;
  bottom: 2.5rem;
  left: 2.5rem;
  z-index: 11;
}

.slider-dot {
  width: 3.75rem;
  height: 2px;
  border-radius: 0.3125rem;
  background: rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: all 0.3s ease;
}
.slider-dot.active {
  background: #FFFFFF;
}

.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 4rem;
  height: 6.5rem;
  border-radius: 1rem;
  background: white;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all 0.3s ease;
  padding: 2.5rem 1.25rem;
}
.slider-arrow:hover {
  transform: translateY(-50%) scale(1.05);
  box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.15);
}
.slider-arrow i {
  font-size: 1.5rem;
  color: #000000;
}
.slider-arrow.prev {
  left: 2.5rem;
}
.slider-arrow.next {
  right: 2.5rem;
}
.slider-arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.slider-loading {
  width: 100%;
  height: 46.875rem;
  border-radius: 1.875rem;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.125rem;
}

/* Responsive Design */
@media (max-width: 768px) {
  .slider-container {
    height: 37.5rem;
    border-radius: 1.25rem;
  }
  .slide-overlay {
    padding: 1.25rem 1.5rem 1.5rem 1.5rem;
  }
  .slide-top-controls {
    top: 1rem;
    right: 1.5rem;
  }
  .slide-content {
    flex-direction: column;
    align-items: flex-start;
  }
  .slide-title {
    font-size: 1.5rem;
  }
  .slider-arrow {
    width: 3rem;
    height: 5rem;
    padding: 1.875rem 1rem;
  }
  .slider-arrow.prev {
    left: 1.5rem;
  }
  .slider-arrow.next {
    right: 1.5rem;
  }
  .slider-dot {
    width: 2.5rem;
  }
  .slider-loading {
    height: 37.5rem;
  }
}
/* ==================================================
   NEWS/VIDEO DETAIL PAGE STYLES - PGS PORTAL
   ================================================== */
.article-content h2 {
  margin-top: unset !important;
}

/* Documents Section */
.documents-section {
  background: #F9F9FB;
  padding: 1.875rem 2.5rem;
  border-radius: 0.5rem;
}

.documents-heading {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
}

.document-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  height: 5rem;
}

.document-left {
  border: unset !important;
}

.document-icon {
  width: 2.5rem;
  height: 2.5rem;
}

.document-middle {
  flex: 1;
  margin: 0 0.75rem;
  display: flex;
  gap: 0.5rem;
  flex-direction: column;
  justify-content: space-between;
}

.document-meta {
  font-size: 0.75rem;
  color: #0D0D0D;
  margin-bottom: 0.25rem;
  font-weight: 700;
}
.document-meta .document-size {
  background: white;
  padding: 0.25rem 0.75rem;
  border: 1px solid #D6D6D6;
  border-radius: 0.9375rem;
}

.document-right, .document-left {
  border-radius: 1rem;
  padding: 1.25rem;
  padding-left: 1.25rem;
  border: 1px solid #D6D6D6;
  background: #FFFFFF;
}

.document-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: #222;
  line-height: 1.3;
}

.document-right i {
  font-size: 1.125rem;
  color: #444;
}

/* Video Player Styles */
.video-player-section {
  padding: 0;
  position: relative;
}

.video-player-container {
  position: relative;
  width: 100%;
  max-height: 48.75rem;
  background: #000;
  border-radius: 0.5rem;
  overflow: hidden;
}

.video-title-overlay {
  position: absolute;
  bottom: 1.875rem;
  left: 0;
  right: 5rem;
  z-index: 10;
  padding: 0.9375rem 1.25rem;
}

.video-title {
  color: white;
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0;
  line-height: 1.3;
}

.video-meta {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.875rem;
  margin-top: 0.5rem;
}
.video-meta .meta-separator {
  margin: 0 0.5rem;
}

.video-controls {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  z-index: 10;
  display: flex;
  gap: 0.75rem;
}

/* Custom Plyr Styles */
.plyr {
  width: 100%;
  max-height: 48.75rem;
}

.plyr__video-wrapper {
  background: #000;
}

.plyr--video {
  background: #000;
}

.plyr__controls {
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
  color: white;
}

.plyr__control {
  color: white;
}
.plyr__control:hover {
  background: rgba(255, 255, 255, 0.2);
}

.plyr__control--pressed {
  background: rgba(255, 255, 255, 0.3);
}

.plyr__progress {
  color: #fff;
}

.plyr__progress__buffer {
  color: rgba(255, 255, 255, 0.3);
}

.plyr__volume {
  color: white;
}

.plyr__time {
  color: white;
}

.plyr__poster {
  display: none;
}

/* Plyr Color Variables */
:root {
  --plyr-color-main: #7F0723;
  --plyr-video-control-background-hover: #7F0723;
}

/* Responsive Design */
@media (max-width: 768px) {
  .video-title-overlay {
    right: 1.25rem;
    left: 1.25rem;
  }
  .video-controls {
    position: relative;
    top: auto;
    right: auto;
    justify-content: center;
    margin-top: 0.9375rem;
  }
  .video-title {
    font-size: 1.125rem;
  }
}
.feature-date-box {
  background: #FFFFFF;
  padding: 20px;
  border-radius: 20px;
  width: 85px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.feature-date-box.listing-date {
  position: absolute;
  top: 16px;
  left: 30px;
}

.feature-date-day {
  font-family: Urbanist, sans-serif;
  font-weight: 300;
  font-size: 40px;
  line-height: 1;
  letter-spacing: 0%;
  text-align: center;
  text-transform: uppercase;
  color: #000000;
}

.feature-date-month-year {
  font-family: Urbanist, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0%;
  text-align: center;
  text-transform: uppercase;
  color: #000000;
}

.event-metadata-container {
  background: #FFFFFF;
  border-radius: 1rem;
  padding: 1.5rem;
}

.event-metadata-heading {
  font-family: Urbanist, sans-serif;
  font-weight: 700;
  font-size: 1.5rem;
  color: #0D0D0D;
  margin-bottom: 1.5rem;
}

.event-metadata-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.event-metadata-item {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.event-metadata-icon {
  flex-shrink: 0;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #121216;
  border: 18px solid white;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.event-metadata-icon i {
  color: #121216;
  font-size: 24px;
  background: white;
}

.event-metadata-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding-top: 0.25rem;
}

.event-metadata-title {
  font-family: Urbanist, sans-serif;
  font-weight: 700;
  font-size: 12px;
  line-height: 100%;
  letter-spacing: 0%;
  text-transform: uppercase;
  color: #616161;
}

.event-metadata-value {
  font-family: Urbanist, sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 1.4;
  color: #0D0D0D;
}

.event-metadata-link {
  color: #0D0D0D;
  text-decoration: none;
  transition: color 0.3s ease;
}
.event-metadata-link:hover {
  color: #0066CC;
  text-decoration: underline;
}

.event-metadata-action {
  margin-top: 1rem;
}

.event-interested-btn i {
  font-size: 1.125rem;
  margin-left: 16px;
}

.event-meta {
  align-items: flex-start;
  flex-direction: column;
}

@media (max-width: 768px) {
  .event-metadata-icon {
    width: 50px;
    height: 50px;
    border-width: 12px;
  }
  .event-metadata-icon i {
    font-size: 20px;
  }
  .event-metadata-value {
    font-size: 18px;
  }
}
/* ==================================================
   DOCUMENTS LISTING STYLES - PGS PORTAL
   ================================================== */
/* Old Document Listing Styles (existing HTML) */
.document-listing {
  width: 100%;
}

.document-list {
  margin-bottom: 1.875rem;
}

.document-item {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  padding: 0;
}

.document-left {
  position: relative;
  flex-shrink: 0;
}

.document-icon {
  width: 9.375rem;
  height: 9.375rem;
  object-fit: cover;
  display: block;
  border-radius: 0.5rem;
}

.document-type-badge {
  position: absolute;
  bottom: 1rem;
  left: 0.6875rem;
  right: 0.6875rem;
  background: white;
  padding: 0.5rem 1rem;
  border-radius: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #000000;
}
.document-type-badge i {
  font-size: 0.75rem;
}
.document-type-badge .document-type {
  font-weight: 700;
}
.document-type-badge .document-size {
  font-weight: 500;
}

.document-middle {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: 0;
}

.document-right {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
}
.document-right a {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: all 0.3s ease;
}
.document-right a i {
  font-size: 1.25rem;
  color: #000000;
}

/* New Document Client Extension Styles (React) */
.doc-list-item {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  padding: 0;
}

.doc-thumbnail {
  position: relative;
  flex-shrink: 0;
}

.doc-preview-image {
  width: 9.375rem;
  height: 9.375rem;
  object-fit: cover;
  display: block;
  border-radius: 0.5rem;
}

.doc-info-badge {
  position: absolute;
  bottom: 1rem;
  left: 0.6875rem;
  right: 0.6875rem;
  background: white;
  padding: 0.5rem 1rem;
  border-radius: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #000000;
}
.doc-info-badge i {
  font-size: 0.75rem;
}
.doc-info-badge .doc-format {
  font-weight: 700;
}
.doc-info-badge .doc-file-size {
  font-weight: 500;
}

.doc-details {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: 0;
}

.doc-metadata {
  font-size: 0.75rem;
  text-transform: uppercase;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.doc-publish-date {
  color: #666;
}

.doc-meta-divider {
  color: #666;
}

.doc-category-name {
  color: #333;
}

.doc-heading {
  font-size: 1.375rem;
  font-weight: 700;
  margin: 0;
}
.doc-heading a {
  color: #333;
  text-decoration: none;
}
.doc-heading a:hover {
  text-decoration: underline;
}

.doc-actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
}

.doc-download-btn {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: all 0.3s ease;
}
.doc-download-btn i {
  font-size: 1.25rem;
  color: white;
}

/* Responsive Design */
@media (max-width: 768px) {
  .document-item {
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1.875rem;
  }
  .document-left {
    width: 100%;
    display: flex;
    justify-content: center;
  }
  .document-icon {
    width: 7.5rem;
    height: 7.5rem;
  }
  .document-type-badge {
    bottom: 0.75rem;
    left: 50%;
    transform: translateX(-50%);
    right: auto;
    width: auto;
    min-width: 6.25rem;
  }
  .document-middle {
    text-align: center;
  }
  .document-right {
    align-self: center;
  }
  .doc-list-item {
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1.875rem;
    align-items: flex-start;
  }
  .doc-thumbnail {
    width: 100%;
    display: flex;
    justify-content: center;
  }
  .doc-preview-image {
    width: 7.5rem;
    height: 7.5rem;
  }
  .doc-info-badge {
    bottom: 0.75rem;
    left: 50%;
    transform: translateX(-50%);
    right: auto;
    width: auto;
    min-width: 6.25rem;
  }
  .doc-details {
    text-align: center;
  }
  .doc-metadata {
    justify-content: center;
  }
  .doc-actions {
    align-self: center;
  }
}
@media (max-width: 576px) {
  .document-item {
    gap: 0.75rem;
    margin-bottom: 1.5rem;
  }
  .document-icon {
    width: 6.25rem;
    height: 6.25rem;
  }
  .document-type-badge {
    font-size: 0.6875rem;
    padding: 0.375rem 0.75rem;
    bottom: 0.625rem;
  }
  .doc-list-item {
    gap: 0.75rem;
    margin-bottom: 1.5rem;
  }
  .doc-preview-image {
    width: 6.25rem;
    height: 6.25rem;
  }
  .doc-info-badge {
    font-size: 0.6875rem;
    padding: 0.375rem 0.75rem;
    bottom: 0.625rem;
  }
}
/* ==================================================
   FILTER SIDEBAR STYLES - PGS PORTAL
   ================================================== */
/* Filter Overlay */
.filter-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Filter Sidebar */
.filter-sidebar {
  position: fixed;
  top: 0;
  right: -40.6875rem;
  width: 40.6875rem;
  height: 100vh;
  background: #FFFFFF;
  border-radius: 1.875rem 0 0 1.875rem;
  padding: 3.75rem 3.75rem 3rem 3.75rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}
.filter-sidebar.open {
  right: 0;
}
.filter-sidebar.open ~ .filter-overlay {
  opacity: 1;
  visibility: visible;
}

/* Filter Header */
.filter-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 1.375rem;
  border-bottom: 1px solid #D6D6D6;
  margin-bottom: 2.5rem;
}

.filter-title {
  font-family: "Urbanist", sans-serif;
  font-weight: 600;
  font-size: 1.75rem;
  line-height: 100%;
  letter-spacing: -0.02em;
  margin: 0;
  color: #0D0D0D;
}

.filter-close-btn {
  width: 1.875rem;
  height: 1.875rem;
  background: transparent;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  flex-shrink: 0;
}
.filter-close-btn i {
  font-size: 1.5rem;
  color: #0D0D0D;
}
.filter-close-btn:hover {
  transform: scale(1.1);
}

/* Filter Content */
.filter-content {
  flex: 1;
  overflow-y: auto;
  padding-right: 0.625rem;
  margin-right: -0.625rem;
}
.filter-content .form-control {
  padding-left: 1rem !important;
}
.filter-content .form-control:not(:placeholder-shown) + .form-label {
  left: 1rem;
}
.filter-content input[type=date]::placeholder {
  opacity: 0;
  visibility: hidden;
}
.filter-content input[type=date]::-webkit-datetime-edit-text,
.filter-content input[type=date]::-webkit-datetime-edit-month-field,
.filter-content input[type=date]::-webkit-datetime-edit-day-field,
.filter-content input[type=date]::-webkit-datetime-edit-year-field {
  opacity: 0;
}
.filter-content input[type=date].filled::-webkit-datetime-edit-text,
.filter-content input[type=date].filled::-webkit-datetime-edit-month-field,
.filter-content input[type=date].filled::-webkit-datetime-edit-day-field,
.filter-content input[type=date].filled::-webkit-datetime-edit-year-field {
  opacity: 1;
}
.filter-content::-webkit-scrollbar {
  width: 0.375rem;
}
.filter-content::-webkit-scrollbar-track {
  background: #F9F9FB;
  border-radius: 0.1875rem;
}
.filter-content::-webkit-scrollbar-thumb {
  background: #D6D6D6;
  border-radius: 0.1875rem;
}
.filter-content::-webkit-scrollbar-thumb:hover {
  background: var(--btn-primary, #BF284B);
}

/* Filter Section Title */
.filter-section-title {
  font-family: "Urbanist", sans-serif;
  font-weight: 600;
  font-size: 1.75rem;
  line-height: 100%;
  letter-spacing: -0.02em;
  margin: 0 0 1.5rem 0;
  color: #0D0D0D;
}

/* Form Groups in Filter */
.filter-sidebar .form-group {
  margin-bottom: 2.5rem;
  position: relative;
}

.filter-section-title + .date-range-group {
  margin-top: 0;
}

/* Date Range Group */
.date-range-group {
  display: flex;
  flex-direction: row;
  gap: 0.625rem;
  margin-bottom: 1rem;
}
.date-range-group .form-group {
  margin-bottom: 0;
  flex: 1;
}
.date-range-group input[type=date]::-webkit-calendar-picker-indicator {
  display: none;
  -webkit-appearance: none;
}
.date-range-group input[type=date]::-webkit-inner-spin-button,
.date-range-group input[type=date]::-webkit-clear-button {
  display: none;
  -webkit-appearance: none;
}
.date-range-group input[type=date]::-moz-calendar-picker-indicator {
  display: none;
}

/* Calendar Toggle Button */
.calendar-toggle {
  position: absolute;
  right: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 2;
}
.calendar-toggle i {
  font-size: 1.25rem;
  color: #666;
}
.calendar-toggle:hover i {
  color: var(--btn-primary, #BF284B);
}

/* Select Dropdown Icon */
.form-select-icon {
  position: absolute;
  right: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  color: #666;
  pointer-events: none;
  z-index: 1;
}

/* Filter-specific dropdown styling */
.filter-sidebar select.form-control {
  appearance: none;
  cursor: pointer;
  padding-right: 3.125rem;
}
.filter-sidebar select.form-control[multiple] {
  height: auto;
  min-height: 7.5rem;
  max-height: 12.5rem;
  padding: 1rem 3.125rem 1rem 1.25rem;
  overflow-y: auto;
}
.filter-sidebar select.form-control[multiple]::-webkit-scrollbar {
  width: 0.375rem;
}
.filter-sidebar select.form-control[multiple]::-webkit-scrollbar-track {
  background: #F9F9FB;
  border-radius: 0.1875rem;
}
.filter-sidebar select.form-control[multiple]::-webkit-scrollbar-thumb {
  background: #D6D6D6;
  border-radius: 0.1875rem;
}
.filter-sidebar select.form-control[multiple]::-webkit-scrollbar-thumb:hover {
  background: var(--btn-primary, #BF284B);
}
.filter-sidebar select.form-control[multiple] option {
  padding: 0.625rem;
  border-radius: 0.25rem;
  margin-bottom: 0.25rem;
  cursor: pointer;
}
.filter-sidebar select.form-control[multiple] option:checked {
  background: #BF284B !important;
  color: white !important;
}
.filter-sidebar select.form-control[multiple] option:hover {
  background: #F9F9FB;
}
.filter-sidebar select.form-control[multiple] + .form-select-icon {
  display: none;
}

/* Filter Actions */
.filter-actions {
  display: flex;
  gap: 1rem;
  margin-top: auto;
  padding-top: 1.5rem;
  border-top: 1px solid #D6D6D6;
}
.filter-actions .btn {
  flex: 1;
  padding: 1rem 1.5rem;
  font-size: 1rem;
  font-weight: 700;
  border-radius: 1.875rem;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
}
.filter-actions .btn-primary {
  background: var(--btn-primary, #BF284B);
  color: white;
  border: none;
}
.filter-actions .btn-primary:hover {
  background: #a0213d;
  transform: translateY(-0.125rem);
}
.filter-actions .btn-secondary {
  background: transparent;
  color: var(--btn-primary, #BF284B);
  border: 2px solid var(--btn-primary, #BF284B);
}
.filter-actions .btn-secondary:hover {
  background: var(--btn-primary, #BF284B);
  color: white;
  transform: translateY(-0.125rem);
}

/* Active Filters Section */
.active-filters {
  margin-bottom: 2.5rem;
  display: flex;
  align-items: center;
}

.active-filters-title {
  font-family: "Urbanist", sans-serif;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 100%;
  letter-spacing: -0.02em;
  margin: 0 1rem 0 0;
  color: #0D0D0D;
}

.active-filters-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.filter-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: #F9F9FB;
  border: 1px solid #D6D6D6;
  border-radius: 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #0D0D0D;
  transition: all 0.3s ease;
}
.filter-badge:hover {
  background: #f0f0f0;
  border-color: var(--btn-primary, #BF284B);
}

.filter-badge-remove {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  transition: all 0.3s ease;
}
.filter-badge-remove i {
  font-size: 0.75rem;
  color: #666;
}
.filter-badge-remove:hover i {
  color: var(--btn-primary, #BF284B);
  transform: scale(1.2);
}

/* Responsive Design */
@media (max-width: 768px) {
  .filter-sidebar {
    right: auto;
    left: 0;
    bottom: -100vh;
    top: auto;
    width: 100%;
    height: 90vh;
    border-radius: 1.875rem 1.875rem 0 0;
    padding: 2.5rem 1.5rem 2rem 1.5rem;
    transition: bottom 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .filter-sidebar.open {
    right: auto;
    bottom: 0;
  }
  .filter-header {
    padding-bottom: 1rem;
    margin-bottom: 1.5rem;
  }
  .filter-title {
    font-size: 1.5rem;
  }
  .filter-section-title {
    font-size: 1.5rem;
    margin-bottom: 1.25rem;
  }
  .filter-sidebar .form-group {
    margin-bottom: 1.5rem;
  }
  .date-range-group {
    gap: 1rem;
    margin-bottom: 0.75rem;
  }
  .filter-actions {
    flex-direction: column;
  }
  .filter-actions .btn {
    width: 100%;
  }
}
@media (max-width: 576px) {
  .filter-sidebar {
    padding: 2rem 1.25rem 1.5rem 1.25rem;
  }
  .filter-title {
    font-size: 1.25rem;
  }
  .filter-section-title {
    font-size: 1.25rem;
  }
}
/* ==================================================
   SEARCH PAGE STYLES - PGS PORTAL
   ================================================== */
/* Search Bar Container */
.search-bar-container {
  margin-bottom: 1.5rem !important;
}

.search-bar-wrapper {
  display: flex;
  gap: 1.5rem;
  align-items: center;
}

.search-bar-form {
  flex: 1;
  position: relative;
}

/* Active Filters Container */
.active-filters-container {
  margin-bottom: 3.75rem !important;
}

/* Search Results Container */
.search-results-container {
  margin-bottom: 5rem;
}

.search-result-section {
  margin-bottom: 5rem;
}
.search-result-section.homepage-news-section {
  padding: unset !important;
}

.search-result-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.search-result-grid .video-slide .homepage-video-overlay {
  left: 14%;
}
.search-result-grid .homepage-news-slide:hover {
  text-decoration: unset !important;
}

/* Photo slide specific styling */
.photo-slide {
  position: relative;
}
.photo-slide .photo-count-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
}

/* Video slide specific styling */
.video-slide {
  position: relative;
}
.video-slide .homepage-video-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

/* No Results State */
.no-results {
  padding: 5rem 0;
  text-align: center;
}

/* Mobile Responsive */
@media (max-width: 991.98px) {
  .search-bar-wrapper {
    flex-direction: column;
    gap: 1rem;
  }
  .search-bar-form {
    width: 100%;
  }
  .search-filter-btn {
    width: 100%;
    justify-content: center;
  }
  .search-result-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
  .search-result-section {
    margin-bottom: 3.75rem;
  }
  .active-filters-container {
    margin-bottom: 2.5rem !important;
  }
}
@media (max-width: 767px) {
  .search-bar-container {
    margin-bottom: 1.25rem !important;
  }
  .search-result-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .search-result-section {
    margin-bottom: 2.5rem;
  }
  .active-filters-container {
    margin-bottom: 2rem !important;
  }
  .search-results-container {
    margin-bottom: 3rem;
  }
  .no-results {
    padding: 3rem 0;
  }
  /* Adjust homepage-news-slide for search results on mobile */
  .search-result-section .homepage-news-slide {
    max-width: 100%;
  }
  .search-result-section .homepage-news-slide-image {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
}
@media (max-width: 576px) {
  .search-bar-wrapper {
    gap: 0.75rem;
  }
  .search-filter-btn {
    padding: 1.25rem 1.5rem;
    font-size: 1rem;
  }
  .search-result-section {
    margin-bottom: 2rem;
  }
  .no-results {
    padding: 2rem 0;
  }
}
/* ==================================================
   CUSTOM CATEGORIES STYLES - PGS PORTAL
   ================================================== */
.custom-categories-container {
  background-color: var(--color-background-light, #F9F9FB);
  padding: 1.875rem 2.5rem;
  border-radius: 1.875rem;
  font-family: "Urbanist", sans-serif;
}

.categories-heading {
  font-family: "Urbanist", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.125rem;
  line-height: 100%;
  letter-spacing: -0.0225rem; /* -2% of 18px */
  color: #0D0D0D;
  margin: 0 0 2.5rem 0;
}

.categories-list {
  display: flex;
  flex-direction: column;
}

.category-item {
  position: relative;
}

.category-link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: all 0.2s ease;
}
.category-link:hover {
  text-decoration: none;
  color: inherit;
}

.category-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 1rem;
}

.category-name {
  font-family: "Urbanist", sans-serif;
  font-weight: 500;
  font-size: 1rem;
  color: #0D0D0D;
  flex: 1;
}

.category-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.category-count {
  background-color: var(--btn-primary, #BF284B);
  color: white;
  padding: 0 0.5rem;
  border-radius: 0.75rem;
  font-family: "Urbanist", sans-serif;
  font-weight: 600;
  font-size: 0.75rem;
  min-width: 1.25rem;
  text-align: center;
}

.category-arrow {
  color: var(--btn-primary, #BF284B);
  font-size: 0.875rem;
  transition: transform 0.2s ease;
  transform: rotate(45deg);
}

.category-divider {
  height: 1px;
  background-color: #F0F0F0;
  margin-bottom: 1rem;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .custom-categories-container {
    padding: 1.25rem 1.5rem;
    border-radius: 1.25rem;
  }
  .categories-heading {
    font-size: 1rem;
    margin-bottom: 1.5rem;
  }
  .category-name {
    font-size: 0.875rem;
  }
}
/* ==================================================
   HOMEPAGE REUSABLE COMPONENTS - PGS PORTAL
   Shared components across all homepage sections
   ================================================== */
/* Homepage Section Header */
.homepage-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-right: 5rem;
  padding-left: 4rem;
  padding-bottom: 1.875rem;
  border-bottom: 1px solid #D6D6D6;
  margin-bottom: 2.5rem;
}

.homepage-section-title-group {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.homepage-section-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 800;
  font-size: 2.5rem;
  letter-spacing: -0.02em;
  color: var(--color-text-primary, #0D0D0D);
  line-height: 100%;
  margin: 0;
}

.homepage-section-see-all {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 900;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  color: var(--btn-primary, #BF284B);
  text-transform: uppercase;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  transition: all 0.3s ease;
}
.homepage-section-see-all i {
  font-size: 0.75rem;
}
.homepage-section-see-all:hover {
  color: #a0213d;
  transform: translateX(0.25rem);
}

.homepage-section-header-right {
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
}

.homepage-section-last-updated-label {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-style: italic;
  font-size: 0.75rem;
  color: #616161;
  margin-bottom: 0.25rem;
}

.homepage-section-last-updated-date {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-text-primary, #0D0D0D);
}

/* Homepage Slide Card - Horizontal (Image Left) */
.homepage-slide-card {
  flex: 0 0 33.125rem;
  height: 7.5rem;
  display: flex;
  gap: 1rem;
  background: var(--color-background, #FFFFFF);
  border-radius: 0.75rem;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
}
.homepage-slide-card:hover {
  transform: translateY(-0.125rem);
}
.homepage-slide-card:hover .homepage-slide-card-image {
  opacity: 0.9;
}

.homepage-slide-card-image {
  width: 9.375rem;
  height: 7.5rem;
  border-radius: 0.75rem;
  object-fit: cover;
  flex-shrink: 0;
  transition: opacity 0.3s ease;
}

.homepage-slide-card-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  min-width: 0;
}

.homepage-slide-card-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-size: 1rem;
  color: var(--color-text-primary, #0D0D0D);
  line-height: 120%;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* Homepage Slide Card - Vertical (Image Top) */
.homepage-slide-card-vertical {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
}
.homepage-slide-card-vertical:hover {
  transform: translateY(-0.125rem);
}
.homepage-slide-card-vertical:hover .homepage-slide-card-image-top {
  opacity: 0.9;
}

.homepage-slide-card-image-top {
  width: 100%;
  height: 8rem;
  object-fit: cover;
  border-radius: 0.75rem;
  margin-bottom: 0.75rem;
  transition: opacity 0.3s ease;
}

/* Slider Controls */
.homepage-slider-controls {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  position: relative;
  z-index: 10;
}

.homepage-slider-arrow {
  border: 1px solid #D6D6D6;
  background: transparent;
  padding: 0.4375rem;
  cursor: pointer;
  font-size: 1rem;
  color: #000000;
  transition: all 0.3s ease;
  position: relative;
  z-index: 10;
}
.homepage-slider-arrow:hover:not(:disabled) {
  color: var(--btn-primary, #BF284B);
  border-color: var(--btn-primary, #BF284B);
}
.homepage-slider-arrow:disabled {
  color: #808080;
  cursor: not-allowed;
  opacity: 0.5;
}

.homepage-slider-dots {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  z-index: 10;
}

.homepage-slider-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: #F2F2F2;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  z-index: 10;
}
.homepage-slider-dot:hover {
  background: #D6D6D6;
}
.homepage-slider-dot:active {
  background: var(--btn-primary, #BF284B);
  transform: scale(1.2);
}

/* Video Overlay - Centered for Homepage */
.homepage-video-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 3.75rem;
  height: 3.75rem;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(0.52083rem);
  box-shadow: -0.01875rem 0.01875rem 0.01875rem -0.038125rem rgba(255, 255, 255, 0.35) inset;
  border: 0.42px solid rgba(255, 255, 255, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 1;
}
.homepage-video-overlay i {
  font-size: 1.5rem;
  color: white;
  margin-left: 0.125rem;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .homepage-section-header {
    padding-right: 3rem;
    padding-left: 3rem;
    padding-bottom: 1.5rem;
    margin-bottom: 2rem;
  }
  .homepage-slide-card {
    flex: 0 0 28rem;
  }
}
@media (max-width: 768px) {
  .homepage-section-header {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 1.5rem 1.5rem 1.5rem;
    margin-bottom: 1.5rem;
    gap: 1rem;
  }
  .homepage-section-header-right {
    align-items: flex-start;
    text-align: left;
  }
  .homepage-section-title {
    font-size: 2rem;
  }
  .homepage-slide-card {
    flex: 0 0 20rem;
    height: auto;
    flex-direction: column;
  }
  .homepage-slide-card-image {
    width: 100%;
    height: 12rem;
  }
  .homepage-slide-card-image-top {
    height: 10rem;
  }
}
@media (max-width: 576px) {
  .homepage-section-header {
    padding: 0 1rem 1rem 1rem;
  }
  .homepage-section-title {
    font-size: 1.75rem;
  }
  .homepage-slide-card {
    flex: 0 0 16rem;
  }
  .homepage-slide-card-image-top {
    height: 8rem;
  }
}
/* ==================================================
   HOMEPAGE NEWS SECTION STYLES - PGS PORTAL
   ================================================== */
.homepage-news-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-right: 1rem;
  padding-bottom: 1.875rem;
  border-bottom: 1px solid #D6D6D6;
  margin-bottom: 2.5rem;
}

.homepage-news-title-group {
  display: flex;
  flex-direction: column;
}

.homepage-news-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 800;
  font-size: 2.5rem;
  letter-spacing: -0.02em;
  color: var(--color-text-primary, #0D0D0D);
  line-height: 100%;
  margin: 0;
  margin-bottom: 4px;
}

.homepage-news-see-all {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 900;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  color: var(--btn-primary, #BF284B);
  text-transform: uppercase;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  transition: all 0.3s ease;
}
.homepage-news-see-all i {
  font-size: 0.75rem;
}
.homepage-news-see-all:hover {
  color: #a0213d;
  transform: translateX(0.25rem);
}

/* Controls */
.homepage-news-slider-controls {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.homepage-news-arrow {
  width: 30px;
  height: 30px;
  border: 1px solid #D6D6D6;
  background: transparent;
  cursor: pointer;
  border-radius: 50px;
  font-size: 1rem;
  color: #000000;
  transition: all 0.3s ease;
  display: flex;
  justify-content: center;
  align-items: center;
}
.homepage-news-arrow:hover:not(:disabled) {
  color: var(--btn-primary, #BF284B);
  border-color: var(--btn-primary, #BF284B);
}
.homepage-news-arrow:disabled {
  color: #808080;
  cursor: not-allowed;
  opacity: 0.5;
}
.homepage-news-arrow i {
  font-size: 13px;
}

.homepage-news-dots {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.homepage-news-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: #F2F2F2;
  cursor: pointer;
  transition: all 0.3s ease;
}
.homepage-news-dot:hover {
  background: #D6D6D6;
}
.homepage-news-dot.active {
  background: var(--btn-primary, #BF284B);
  transform: scale(1.2);
}

/* Header Right Side */
.homepage-news-header-right {
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
}

.homepage-news-last-updated-label {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-style: italic;
  font-size: 0.75rem;
  color: #616161;
  margin-bottom: 0;
}

.homepage-news-last-updated-date {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-text-primary, #0D0D0D);
}

.homepage-news-section {
  padding: 3.75rem 0 3.75rem 1rem;
  background: var(--color-background, #FFFFFF);
  /* Container */
  /* Slider */
}
.homepage-news-section .homepage-news-container {
  padding-right: 0;
  max-width: 100%;
}
.homepage-news-section .homepage-news-slider-wrapper {
  overflow: hidden;
  position: relative;
  margin-bottom: 2.5rem;
}
.homepage-news-section .homepage-news-slider {
  display: flex;
  gap: 1.5rem;
  transition: transform 0.4s ease;
}
.homepage-news-section .homepage-news-slide {
  flex: 0 0 33.125rem;
  height: 7.5rem;
  display: flex;
  gap: 1rem;
  background: var(--color-background, #FFFFFF);
  border-radius: 0.75rem;
}
.homepage-news-section .homepage-news-slide-image {
  width: 9.375rem;
  height: 7.5rem;
  border-radius: 0.75rem;
  object-fit: cover;
}
.homepage-news-section .homepage-news-slide-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.homepage-news-section .homepage-news-slide-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-size: 1rem;
  color: var(--color-text-primary, #0D0D0D);
  line-height: 100%;
  margin: 0;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .homepage-news-section {
    padding: 3rem 0 3rem 1rem;
  }
  .homepage-news-section .homepage-news-header {
    padding-right: 3rem;
    padding-left: 3rem;
    padding-bottom: 1.5rem;
    margin-bottom: 2rem;
  }
  .homepage-news-section .homepage-news-container {
    padding-left: 3rem;
  }
  .homepage-news-section .homepage-news-slide {
    flex: 0 0 28rem;
  }
}
@media (max-width: 768px) {
  .homepage-news-section {
    padding: 2.5rem 0 2.5rem 0;
  }
  .homepage-news-section .homepage-news-header {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 1.5rem 1.5rem 1.5rem;
    margin-bottom: 1.5rem;
    gap: 1rem;
  }
  .homepage-news-section .homepage-news-header-right {
    display: none !important;
  }
  .homepage-news-section .homepage-news-title {
    font-size: 2rem;
  }
  .homepage-news-section .homepage-news-container {
    padding-left: 1.5rem;
  }
  .homepage-news-section .homepage-news-slide {
    flex: 0 0 20rem;
    height: auto;
    flex-direction: column;
  }
  .homepage-news-section .homepage-news-slide-image {
    width: 100%;
    height: 12rem;
  }
  .homepage-news-section .homepage-news-slide-content {
    padding: 0.75rem 0;
  }
  .homepage-news-section .homepage-news-slide-title {
    font-size: 0.9375rem;
    line-height: 120%;
  }
  .homepage-news-section .homepage-news-slider-controls {
    padding-left: 1.5rem;
  }
}
@media (max-width: 576px) {
  .homepage-news-section {
    padding: 2rem 0;
  }
  .homepage-news-section .homepage-news-header {
    padding: 0 1rem 1rem 1rem;
  }
  .homepage-news-section .homepage-news-title {
    font-size: 1.75rem;
  }
  .homepage-news-section .homepage-news-container {
    padding-left: 1rem;
  }
  .homepage-news-section .homepage-news-slide {
    flex: 0 0 16rem;
  }
  .homepage-news-section .homepage-news-slide-image {
    height: 10rem;
  }
  .homepage-news-section .homepage-news-slide-content {
    padding: 0.5rem 0;
  }
  .homepage-news-section .homepage-news-slide-title {
    font-size: 0.875rem;
  }
  .homepage-news-section .homepage-news-slider-controls {
    padding-left: 1rem;
  }
}
@media (max-width: 480px) {
  .homepage-news-section {
    padding: 1.5rem 0;
  }
  .homepage-news-section .homepage-news-header {
    padding: 0 0.75rem 0.75rem 0.75rem;
    margin-bottom: 1rem;
  }
  .homepage-news-section .homepage-news-title {
    font-size: 1.5rem;
  }
  .homepage-news-section .homepage-news-see-all {
    font-size: 0.75rem;
  }
  .homepage-news-section .homepage-news-last-updated-label {
    font-size: 0.625rem;
  }
  .homepage-news-section .homepage-news-last-updated-date {
    font-size: 0.875rem;
  }
  .homepage-news-section .homepage-news-container {
    padding-left: 0.75rem;
  }
  .homepage-news-section .homepage-news-slide {
    flex: 0 0 14rem;
    gap: 0.75rem;
  }
  .homepage-news-section .homepage-news-slide-image {
    height: 9rem;
  }
  .homepage-news-section .homepage-news-slide-title {
    font-size: 0.875rem;
  }
  .homepage-news-section .homepage-news-slider-controls {
    padding-left: 0.75rem;
    gap: 0.5rem;
  }
  .homepage-news-section .homepage-news-arrow {
    width: 26px;
    height: 26px;
  }
  .homepage-news-section .homepage-news-arrow i {
    font-size: 11px;
  }
  .homepage-news-section .homepage-news-dots {
    gap: 0.375rem;
  }
  .homepage-news-section .homepage-news-dot {
    width: 0.375rem;
    height: 0.375rem;
  }
}
/* ==================================================
   HOMEPAGE PHOTOS SECTION STYLES - PGS PORTAL
   ================================================== */
.homepage-photo-section {
  padding-top: 3.75rem !important;
  padding-bottom: 3.75rem !important;
  background: var(--color-background-light, #F9F9FB);
  /* Reusing homepage-news-header classes for consistency */
  /* Center the slider controls */
  /* Slider Wrapper */
  /* All Slides - Default (Side Slides) */
  /* Center slide - Featured and Larger */
}
.homepage-photo-section .homepage-news-slider-controls {
  justify-content: center !important;
  margin-left: auto;
  margin-right: auto;
}
.homepage-photo-section .mb-40 {
  margin-top: 2.5rem;
}
.homepage-photo-section .homepage-photo-slider-wrapper {
  position: relative;
  width: 100%;
  height: 415px;
  margin: 0 auto;
  padding: 0;
  /* Essential Slick Slider Base Styles */
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  user-select: none;
  touch-action: pan-y;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-list {
  position: relative;
  display: block;
  overflow: visible;
  margin: 0;
  padding: 0;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-list:focus {
  outline: none;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: flex !important;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-track:before, .homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-track:after {
  display: table;
  content: "";
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-track:after {
  clear: both;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-slide.slick-center {
  width: 551px !important;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-slide > div {
  height: 100%;
}
.homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-initialized .slick-slide {
  display: block;
}
.homepage-photo-section .homepage-slide {
  padding: 0 0.75rem; /* 12px each side = 24px gap */
  outline: none;
  transition: all 0.5s ease;
  /* Hide center-only elements on side slides */
  /* Show side content below image */
}
.homepage-photo-section .homepage-slide:focus {
  outline: none;
}
.homepage-photo-section .homepage-slide .photo-slide-link {
  display: block;
  position: relative;
}
.homepage-photo-section .homepage-slide .photo-slide-image {
  width: 100%;
  height: 200px; /* Side slides height */
  border-radius: 0.9375rem;
  position: relative;
  overflow: hidden;
  transition: all 0.5s ease;
}
.homepage-photo-section .homepage-slide .favorite-btn-center,
.homepage-photo-section .homepage-slide .photo-count-badge-center,
.homepage-photo-section .homepage-slide .photo-slide-content-center {
  display: none;
}
.homepage-photo-section .homepage-slide .photo-slide-content-side {
  display: block;
  margin-top: 0.75rem;
}
.homepage-photo-section .homepage-slide .photo-slide-content-side .photo-slide-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 120%;
  color: var(--color-text-primary, #0D0D0D);
  margin: 0.5rem 0 0 0;
}
.homepage-photo-section .slick-center .homepage-slide {
  /* Show center badges on image */
  /* Hide side content on center slide */
  /* Show center content on image */
}
.homepage-photo-section .slick-center .homepage-slide .photo-slide-image {
  height: 400px !important;
  transform: scale(1.05);
  transition: transform 0.5s ease;
  position: relative;
  /* Gradient overlay for center slide */
}
.homepage-photo-section .slick-center .homepage-slide .photo-slide-image::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 100%);
  z-index: 1;
}
.homepage-photo-section .slick-center .homepage-slide .favorite-btn-center,
.homepage-photo-section .slick-center .homepage-slide .photo-count-badge-center {
  display: flex;
  z-index: 2;
  background: #FFFFFF;
  color: #000000;
  font-size: 14px !important;
  gap: 5px;
}
.homepage-photo-section .slick-center .homepage-slide .photo-slide-content-side {
  display: none;
}
.homepage-photo-section .slick-center .homepage-slide .photo-slide-content-center {
  display: block;
  position: absolute;
  bottom: 1.5rem;
  left: 1.5rem;
  right: 1.5rem;
  text-align: left;
  z-index: 2;
}
.homepage-photo-section .slick-center .homepage-slide .photo-slide-content-center .photo-slide-date {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 700;
  font-size: 0.75rem;
  line-height: 100%;
  text-transform: uppercase;
  color: var(--color-white, #FFFFFF);
}
.homepage-photo-section .slick-center .homepage-slide .photo-slide-content-center .photo-slide-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 120%;
  color: var(--color-white, #FFFFFF);
  margin: 0.5rem 0 0 0;
}
.homepage-photo-section .featured-photo {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 1.875rem;
  background-size: cover;
  background-position: center;
  padding: 1.875rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: var(--color-white, #FFFFFF);
  cursor: pointer;
  text-decoration: none;
}
.homepage-photo-section .favorite-btn {
  position: absolute;
  top: 1.875rem;
  left: 1.875rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 0.3125rem 0.75rem;
  border-radius: 0.3125rem;
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--color-white, #FFFFFF);
}
.homepage-photo-section .photo-count-badge {
  position: absolute;
  top: 1.875rem;
  left: 7.875rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 0.3125rem 0.75rem;
  border-radius: 0.3125rem;
  color: var(--color-white, #FFFFFF);
  font-size: 0.75rem;
  font-weight: 600;
}
.homepage-photo-section .photo-count-badge i {
  font-size: 0.875rem;
}
.homepage-photo-section .featured-photo-bottom {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.homepage-photo-section .featured-photo-date {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 700;
  font-size: 0.75rem;
  line-height: 100%;
  text-transform: uppercase;
  color: var(--color-white, #FFFFFF);
}
.homepage-photo-section .featured-photo-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 100%;
  color: var(--color-white, #FFFFFF);
  margin: 0;
}

@media (min-width: 1025px) {
  .homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-slide.slick-center {
    width: 551px !important;
  }
}
/* Responsive Design */
@media (max-width: 1024px) {
  .homepage-photo-section {
    padding: 3rem 0;
  }
  .homepage-photo-section .homepage-photo-slider-wrapper {
    padding: 0 1.5rem;
  }
  .homepage-photo-section .homepage-slide .photo-slide-image {
    height: 180px;
  }
  .homepage-photo-section .slick-center .photo-slide-image {
    height: 300px !important;
  }
  .homepage-photo-section .slick-center .photo-slide-title {
    font-size: 1.125rem;
  }
}
@media (max-width: 768px) {
  .homepage-photo-section {
    padding: 2.5rem 0;
  }
  .homepage-photo-section .homepage-photo-slider-wrapper {
    padding: 0 1rem;
    height: auto;
  }
  .homepage-photo-section .homepage-slide {
    padding: 0 0.5rem;
  }
  .homepage-photo-section .homepage-slide .photo-slide-image {
    width: 100% !important;
    height: 250px !important;
  }
  .homepage-photo-section .homepage-slide .photo-slide-content-side {
    display: block !important;
  }
  .homepage-photo-section .homepage-slide .favorite-btn-center,
  .homepage-photo-section .homepage-slide .photo-count-badge-center,
  .homepage-photo-section .homepage-slide .photo-slide-content-center {
    display: none !important;
  }
  .homepage-photo-section .homepage-slide .photo-slide-title {
    font-size: 0.875rem;
  }
  .homepage-photo-section .homepage-news-slider-controls {
    padding-left: 0 !important;
  }
}
@media (max-width: 576px) {
  .homepage-photo-section {
    padding: 2rem 0;
  }
  .homepage-photo-section .homepage-photo-slider-wrapper {
    padding: 0 0.5rem;
    height: auto;
  }
  .homepage-photo-section .homepage-photo-slider-wrapper .slick-slider .slick-track {
    gap: 10px;
  }
  .homepage-photo-section .homepage-slide {
    padding: 0 0.375rem;
  }
  .homepage-photo-section .homepage-slide .photo-slide-image {
    width: 100% !important;
    height: 220px !important;
    border-radius: 0.9375rem;
  }
  .homepage-photo-section .homepage-slide .photo-slide-content-side {
    display: block !important;
  }
  .homepage-photo-section .homepage-slide .favorite-btn-center,
  .homepage-photo-section .homepage-slide .photo-count-badge-center,
  .homepage-photo-section .homepage-slide .photo-slide-content-center {
    display: none !important;
  }
  .homepage-photo-section .homepage-slide .photo-slide-title {
    font-size: 0.75rem;
  }
  .homepage-photo-section .homepage-slide .card-date,
  .homepage-photo-section .homepage-slide .card-category {
    font-size: 0.625rem;
  }
  .homepage-photo-section .homepage-news-slider-controls {
    padding-left: 0 !important;
  }
}
/* ==================================================
   HOMEPAGE VIDEOS SECTION STYLES - PGS PORTAL
   ================================================== */
.homepage-video-section {
  padding-top: 3.75rem !important;
  padding-bottom: 3.75rem !important;
  /* Reusing homepage-news-header classes for consistency */
  /* Grid Layout */
  /* Featured Video Styles */
  /* Smaller video items - reusing homepage-news-slide classes */
  /* Reusing card-meta, card-date, card-separator, card-category from listing.scss */
  /* Reusing homepage-news-slide-title from homepage-news.scss */
}
.homepage-video-section .parent {
  display: grid;
  grid-template-columns: repeat(9, 1fr);
  grid-template-rows: repeat(4, 1fr);
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
}
.homepage-video-section .div1 {
  grid-area: 1/1/5/7;
}
.homepage-video-section .div2 {
  grid-area: 1/7/2/10;
}
.homepage-video-section .div3 {
  grid-area: 2/7/3/10;
}
.homepage-video-section .div4 {
  grid-area: 3/7/4/10;
}
.homepage-video-section .div5 {
  grid-area: 4/7/5/10;
}
.homepage-video-section .featured-video {
  position: relative;
  height: 100%;
  width: 100%;
  border-radius: 1.875rem;
  background-size: cover;
  background-position: center;
  padding: 1.875rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: var(--color-white, #FFFFFF);
  overflow: hidden;
  /* Dark overlay for better text readability */
}
.homepage-video-section .featured-video::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 100%);
  z-index: 1;
}
.homepage-video-section .featured-video > * {
  position: relative;
  z-index: 2;
}
.homepage-video-section .homepage-slide-card-vertical {
  position: relative;
}
.homepage-video-section .favorite-btn {
  position: absolute;
  top: 1.875rem;
  left: 1.875rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 0.3125rem 0.75rem;
  border-radius: 0.3125rem;
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--color-white, #FFFFFF);
  z-index: 3;
}
.homepage-video-section .featured-video-bottom {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.homepage-video-section .featured-video-date {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 700;
  font-size: 0.75rem;
  line-height: 100%;
  text-transform: uppercase;
  color: var(--color-white, #FFFFFF);
}
.homepage-video-section .featured-video-title {
  font-family: var(--font-primary, "Urbanist", sans-serif);
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 100%;
  color: var(--color-white, #FFFFFF);
  margin: 0;
}
.homepage-video-section .homepage-news-slide {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
  transition: transform 0.3s ease;
}
.homepage-video-section .homepage-news-slide:hover {
  transform: translateY(-0.25rem);
}
.homepage-video-section .homepage-news-slide:hover .homepage-news-slide-image {
  opacity: 0.9;
}
.homepage-video-section .homepage-news-slide-image {
  width: 100%;
  height: 8rem;
  object-fit: cover;
  border-radius: 0.75rem;
  margin-bottom: 0.75rem;
  transition: opacity 0.3s ease;
}
.homepage-video-section .homepage-news-slide-content {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

/* Responsive Design */
@media (max-width: 1200px) {
  .homepage-video-section .parent {
    grid-template-columns: repeat(8, 1fr);
    grid-column-gap: 1.25rem;
    grid-row-gap: 1.25rem;
  }
  .homepage-video-section .div1 {
    grid-area: 1/1/5/6;
  }
  .homepage-video-section .div2 {
    grid-area: 1/6/2/9;
  }
  .homepage-video-section .div3 {
    grid-area: 2/6/3/9;
  }
  .homepage-video-section .div4 {
    grid-area: 3/6/4/9;
  }
  .homepage-video-section .div5 {
    grid-area: 4/6/5/9;
  }
}
@media (max-width: 992px) {
  .homepage-video-section {
    padding: 3rem 0;
  }
  .homepage-video-section .parent {
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(5, 1fr);
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }
  .homepage-video-section .div1 {
    grid-area: 1/1/4/7;
  }
  .homepage-video-section .div2 {
    grid-area: 4/1/5/4;
  }
  .homepage-video-section .div3 {
    grid-area: 4/4/5/7;
  }
  .homepage-video-section .div4 {
    grid-area: 5/1/6/4;
  }
  .homepage-video-section .div5 {
    grid-area: 5/4/6/7;
  }
  .homepage-video-section .featured-video-title {
    font-size: 1.25rem;
  }
  .homepage-video-section .homepage-news-slide-image {
    height: 6rem;
  }
}
@media (max-width: 768px) {
  .homepage-video-section {
    padding: 2.5rem 0;
    /* Keep horizontal cards horizontal on mobile for video section */
  }
  .homepage-video-section .parent {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 1.5rem;
  }
  .homepage-video-section .div1,
  .homepage-video-section .div2,
  .homepage-video-section .div3,
  .homepage-video-section .div4,
  .homepage-video-section .div5 {
    grid-area: auto;
  }
  .homepage-video-section .featured-video {
    min-height: 20rem;
    padding: 1.5rem;
  }
  .homepage-video-section .favorite-btn {
    top: 1.5rem;
    left: 1.5rem;
    font-size: 0.625rem;
    padding: 0.25rem 0.5rem;
  }
  .homepage-video-section .featured-video-title {
    font-size: 1.125rem;
  }
  .homepage-video-section .homepage-news-slide-image {
    height: 12rem;
  }
  .homepage-video-section .homepage-slide-card {
    flex-direction: row !important;
    height: 7.5rem;
  }
  .homepage-video-section .homepage-slide-card .homepage-slide-card-image {
    width: 9.375rem;
    height: 7.5rem;
  }
}
@media (max-width: 576px) {
  .homepage-video-section {
    padding: 2rem 0;
    /* Keep horizontal cards horizontal on small mobile for video section */
  }
  .homepage-video-section .featured-video {
    min-height: 16rem;
    padding: 1.25rem;
  }
  .homepage-video-section .featured-video-title {
    font-size: 1rem;
  }
  .homepage-video-section .homepage-news-slide-image {
    height: 10rem;
  }
  .homepage-video-section .homepage-slide-card {
    flex-direction: row !important;
    height: 6rem;
  }
  .homepage-video-section .homepage-slide-card .homepage-slide-card-image {
    width: 7.5rem;
    height: 6rem;
  }
  .homepage-video-section .homepage-slide-card .homepage-slide-card-title {
    font-size: 0.875rem;
  }
}
.homepage-event-section {
  padding-top: 3.75rem !important;
  padding-bottom: 3.75rem !important;
  background-color: #F9F9FB;
}

.event-calendar {
  width: 100%;
  height: 100%;
  background: #FFFFFF;
  border-radius: 1rem;
  padding: 40px 24px;
  font-family: Urbanist, sans-serif;
}

.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid #D6D6D6;
}

.calendar-month-year {
  font-family: Urbanist, sans-serif;
  font-weight: 600;
  font-size: 18px;
  color: #0D0D0D;
  display: flex;
  align-items: center;
  gap: 8px;
  text-transform: capitalize;
}
.calendar-month-year i {
  font-size: 14px;
}

.calendar-nav {
  display: flex;
  gap: 8px;
}

.calendar-nav-btn {
  background: transparent;
  border: none;
  font-size: 20px;
  color: #0D0D0D;
  cursor: pointer;
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}
.calendar-nav-btn:hover {
  background: rgba(0, 0, 0, 0.05);
}

.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  margin-bottom: 1rem;
}

.calendar-weekday {
  font-family: Urbanist, sans-serif;
  font-weight: 700;
  font-size: 18px;
  line-height: 100%;
  text-align: center;
  color: #0D0D0D;
  padding: 0.5rem 0;
}

.calendar-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}

.calendar-day {
  font-family: Urbanist, sans-serif;
  font-weight: 500;
  font-size: 16px;
  color: #0D0D0D;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-radius: 30px;
}
.calendar-day:hover:not(.empty) {
  background: rgba(0, 0, 0, 0.05);
}
.calendar-day.empty {
  cursor: default;
}
.calendar-day.today {
  background: rgba(0, 102, 204, 0.1);
}
.calendar-day.has-event {
  background: #BF284B;
  font-weight: 700;
  color: white;
}

.event-home-content {
  display: grid;
  grid-template-columns: 400px 1fr;
  gap: 2rem;
  margin-top: 2rem;
}

.event-calendar-wrapper {
  width: 400px;
  height: 370px;
}

.event-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 1.5rem;
  height: 370px;
}

.no-events-message {
  grid-column: 1/3;
  grid-row: 1/3;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #F5F5F5;
  border-radius: 1.5rem;
  padding: 2rem;
}

.no-events-icon {
  font-size: 64px;
  color: #BF284B;
  margin-bottom: 1rem;
}

.no-events-text {
  font-family: Urbanist, sans-serif;
  font-weight: 500;
  font-size: 20px;
  color: #616161;
  margin: 0;
  text-align: center;
}

.event-home-card {
  position: relative;
  display: block;
  background-size: cover;
  background-position: center;
  border-radius: 1.5rem;
  overflow: hidden;
  text-decoration: none;
  color: white;
  transition: transform 0.3s ease;
}
.event-home-card:hover {
  transform: translateY(-4px);
}
.event-home-card.event-home-card-large {
  grid-column: 1;
  grid-row: 1/3;
}
.event-home-card.event-home-card-small {
  grid-column: 2;
}
.event-home-card.event-home-card-small:first-of-type {
  grid-row: 1;
}
.event-home-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.7) 100%);
  z-index: 1;
}
.event-home-card > * {
  position: relative;
  z-index: 2;
}

.event-home-category {
  position: absolute;
  top: 24px;
  left: 24px;
  background: rgba(255, 255, 255, 0.9);
  color: #0D0D0D;
  font-family: Urbanist, sans-serif;
  font-weight: 600;
  font-size: 14px;
  padding: 6px 12px;
  border-radius: 20px;
  z-index: 3;
  text-transform: uppercase;
}

.event-home-content-bottom {
  position: absolute;
  bottom: 24px;
  left: 24px;
  right: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.event-home-date-box {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(16px);
  padding: 12px 16px;
  border-radius: 12px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: fit-content;
  gap: 4px;
}

.event-home-date-day {
  font-family: Urbanist, sans-serif;
  font-weight: 300;
  font-size: 32px;
  line-height: 1;
  color: #FFFFFF;
}

.event-home-date-month {
  font-family: Urbanist, sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  text-transform: uppercase;
  color: #FFFFFF;
}

.event-home-title {
  background: transparent;
  color: #FFFFFF;
  font-family: Urbanist, sans-serif;
  font-weight: 500;
  font-size: 24px;
  line-height: 100%;
  padding: 16px 20px;
  border-radius: 12px;
  margin: 0;
}

.event-home-card-small .event-home-title {
  font-size: 18px;
  padding: 12px 16px;
}
.event-home-card-small .event-home-date-day {
  font-size: 24px;
}
.event-home-card-small .event-home-date-month {
  font-size: 12px;
}
.event-home-card-small .event-home-content-bottom {
  bottom: 16px;
  left: 16px;
  right: 16px;
  gap: 12px;
}
.event-home-card-small .event-home-category {
  top: 16px;
  left: 16px;
  font-size: 12px;
  padding: 4px 10px;
}

@media (max-width: 1200px) {
  .event-home-content {
    grid-template-columns: 350px 1fr;
  }
  .event-calendar-wrapper {
    width: 350px;
  }
}
@media (max-width: 992px) {
  .event-home-content {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .event-calendar-wrapper {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }
  .event-cards-grid {
    height: auto;
    min-height: 500px;
  }
}
@media (max-width: 768px) {
  .event-cards-grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 1rem;
  }
  .event-cards-grid .event-home-card-large {
    grid-column: 1;
    grid-row: auto;
    min-height: 300px;
  }
  .event-cards-grid .event-home-card-small {
    grid-column: 1;
    grid-row: auto;
    min-height: 250px;
  }
  .event-home-title {
    font-size: 20px !important;
  }
}
.related-posts-container {
  padding-top: 40px;
  border-top: 1px solid #D6D6D6;
}

.related-posts-heading {
  color: #0D0D0D;
  font-family: Urbanist;
  font-weight: 600;
  font-style: normal;
  font-size: 28px;
  margin-bottom: 24px;
}

.related-posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 1024px) {
  .related-posts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .related-posts-grid {
    grid-template-columns: 1fr;
  }
}

/* ==================================================
   PGS PORTAL - MINIMAL RESPONSIVE STYLES
   ================================================== */
/* This file is intentionally minimal - specific responsive styles
   are in responsive-header-footer-test.scss */
html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
  max-width: 100vw;
}

/* Prevent horizontal overflow */
img, video, iframe, embed, object {
  max-width: 100%;
  height: auto;
}

.portlet {
  margin-bottom: unset !important;
}

html:not(#__):not(#___) .page-editor__fragment-content--portlet-topper-hidden .portlet > .cadmin.portlet-topper .portlet-options {
  display: unset !important;
}