/*
* Name: Obscu
* Version: 4.1.7
* Author: Grow Shine Services Pvt. Ltd.
* Download From: https://themes.grow-shine.com OR https://www.customersupporttheme.com
* Corporate Website : https://www.grow-shine.com
* License: You must have a valid license purchased only from themes.grow-shine.com in order to legally use the theme for your project.
* Copyright: © 2016 - 2025 Grow Shine Services Pvt. Ltd. All Rights Reserved.
*/

@charset "UTF-8";
/***** Normalize.css *****/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 5rem;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
  transition: all 0.3s ease;
}

a:hover {
  transition: all 0.3s ease;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

/***** Base *****/
* {
  box-sizing: border-box;
}

body {
  background-color: #FFFFFF;
  color: rgba(51, 51, 51, 1);
  font-family: 'Open Sans', sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 1024px) {
  body > main {
    min-height: 65vh;
  }
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Open Sans', sans-serif;
  font-weight: 600;
  margin-top: 0;
}

h1 {
  font-size: 32px;
}

h2 {
  font-size: 22px;
}

h3 {
  font-size: 18px;
  font-weight: 600;
}

h4 {
  font-size: 16px;
}

a {
  color: rgba(0, 47, 187, 1);
  text-decoration: none;
}

a:hover, a:active, a:focus {
  text-decoration: none;
}

input,
textarea,
.hbs-form input,
.hbs-form textarea, .search input,
.search textarea {
  color: rgba(51, 51, 51, 1);
  font-size: 14px;
}

input,
.hbs-form input, .search input {
  max-width: 100%;
  box-sizing: border-box;
  transition: border .12s ease-in-out;
}

input:not([type="checkbox"]),
.hbs-form input:where(:not([type=checkbox])), .search input:where(:not([type=checkbox])) {
  outline: none;
}

input[disabled],
.hbs-form input[disabled], .search input[disabled] {
  background-color: #ddd;
}

select,
.hbs-form select, .search select {
  -webkit-appearance: none;
  -moz-appearance: none;
  background: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23CCC' d='M0 0h10L5 6 0 0z'/%3E%3C/svg%3E%0A") no-repeat #fff;
  background-position: right 10px center;
  border: 1px solid #DDDDDD;
  border-radius: 4px;
  padding: 8px 30px 8px 10px;
  outline: none;
  color: #555;
  width: 100%;
}

select:focus,
.hbs-form select:focus, .search select:focus {
  border: 1px solid rgba(0, 47, 187, 1);
}

select::-ms-expand,
.hbs-form select::-ms-expand, .search select::-ms-expand {
  display: none;
}

textarea,
.hbs-form textarea, .search textarea {
  border: 1px solid #DDDDDD;
  border-radius: 3px;
  resize: vertical;
  width: 100%;
  outline: none;
  padding: 10px;
}

textarea:focus,
.hbs-form textarea:focus, .search textarea:focus {
  border: 1px solid rgba(0, 47, 187, 1);
}

.container {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 5%;
}

@media (min-width: 1160px) {
  .container {
    padding: 0;
    width: 90%;
  }

  body .full--width {
    width: 95%;
  }
}

body .full--width {
  max-width: 100%;
}

.container-divider {
  border-top: 1px solid #ddd;
  margin-bottom: 20px;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.error-page {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 5%;
}

.error-page h1 {
    font-size: 5em;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 0;
    margin-top: 40px;
}
.error-page h2,
h1.form-header {
    font-weight: 600;
}
.error-page h3 {
    font-size: 10em;
    color: rgba(0, 47, 187, 1);
    margin: 0;
}

@media (min-width: 1160px) {
  .error-page {
    padding: 0;
    width: 90%;
  }
}

.visibility-hidden, .recent-activity-accessibility-label, .pagination-first-text, .pagination-last-text {
  border: 0;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}

/***** Buttons *****/
.button, .section-subscribe button, .article-subscribe button, .community-follow button, .requests-table-toolbar .organization-subscribe button, .subscriptions-subscribe button, .pagination-next-link, .pagination-prev-link, .pagination-first-link, .pagination-last-link, .edit-profile-button a, .hc__btn,
.split-button button {
  background-color: rgba(0, 47, 187, 1);
  border: 1px solid rgba(0, 47, 187, 1);
  border-radius: 3px;
  color: rgba(255, 255, 255, 1);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  line-height: 2.34;
  margin: 0;
  padding: 0 20px;
  text-align: center;
  transition: background-color .12s ease-in-out, border-color .12s ease-in-out, color .15s ease-in-out;
  user-select: none;
  white-space: nowrap;
  width: 100%;
  -webkit-touch-callout: none;
}

.hc__btn {
    width: auto;
}

@media (min-width: 768px) {
  .button, .section-subscribe button, .article-subscribe button, .community-follow button, .requests-table-toolbar .organization-subscribe button, .subscriptions-subscribe button, .pagination-next-link, .pagination-prev-link, .pagination-first-link, .pagination-last-link, .edit-profile-button a,
  .split-button button {
    width: auto;
  }
}

.button:hover, .section-subscribe button:hover, .article-subscribe button:hover, .community-follow button:hover, .requests-table-toolbar .organization-subscribe button:hover, .subscriptions-subscribe button:hover, .pagination-next-link:hover, .pagination-prev-link:hover, .pagination-first-link:hover, .pagination-last-link:hover, .edit-profile-button a:hover, .button:active, .section-subscribe button:active, .article-subscribe button:active, .community-follow button:active, .requests-table-toolbar .organization-subscribe button:active, .subscriptions-subscribe button:active, .pagination-next-link:active, .pagination-prev-link:active, .pagination-first-link:active, .pagination-last-link:active, .edit-profile-button a:active, .button:focus, .section-subscribe button:focus, .article-subscribe button:focus, .community-follow button:focus, .requests-table-toolbar .organization-subscribe button:focus, .subscriptions-subscribe button:focus, .pagination-next-link:focus, .pagination-prev-link:focus, .pagination-first-link:focus, .pagination-last-link:focus, .edit-profile-button a:focus, .button.button-primary, .section-subscribe button.button-primary, .section-subscribe button[data-selected="true"], .article-subscribe button.button-primary, .article-subscribe button[data-selected="true"], .community-follow button.button-primary, .requests-table-toolbar .organization-subscribe button.button-primary, .requests-table-toolbar .organization-subscribe button[data-selected="true"], .subscriptions-subscribe button.button-primary, .subscriptions-subscribe button[data-selected="true"], .button-primary.pagination-next-link, .button-primary.pagination-prev-link, .button-primary.pagination-first-link, .button-primary.pagination-last-link, .edit-profile-button a.button-primary {
  background-color: rgba(0, 47, 187, 1);
  color: rgba(255, 255, 255, 1);
  text-decoration: none;
}

.button.button-primary:hover, .section-subscribe button.button-primary:hover, .section-subscribe button[data-selected="true"]:hover, .article-subscribe button.button-primary:hover, .article-subscribe button[data-selected="true"]:hover, .community-follow button.button-primary:hover, .requests-table-toolbar .organization-subscribe button.button-primary:hover, .requests-table-toolbar .organization-subscribe button[data-selected="true"]:hover, .subscriptions-subscribe button.button-primary:hover, .subscriptions-subscribe button[data-selected="true"]:hover, .button-primary.pagination-next-link:hover, .button-primary.pagination-prev-link:hover, .button-primary.pagination-first-link:hover, .button-primary.pagination-last-link:hover, .edit-profile-button a.button-primary:hover, .button.button-primary:focus, .section-subscribe button.button-primary:focus, .section-subscribe button[data-selected="true"]:focus, .article-subscribe button.button-primary:focus, .article-subscribe button[data-selected="true"]:focus, .community-follow button.button-primary:focus, .requests-table-toolbar .organization-subscribe button.button-primary:focus, .requests-table-toolbar .organization-subscribe button[data-selected="true"]:focus, .subscriptions-subscribe button.button-primary:focus, .subscriptions-subscribe button[data-selected="true"]:focus, .button-primary.pagination-next-link:focus, .button-primary.pagination-prev-link:focus, .button-primary.pagination-first-link:focus, .button-primary.pagination-last-link:focus, .edit-profile-button a.button-primary:focus, .button.button-primary:active, .section-subscribe button.button-primary:active, .section-subscribe button[data-selected="true"]:active, .article-subscribe button.button-primary:active, .article-subscribe button[data-selected="true"]:active, .community-follow button.button-primary:active, .requests-table-toolbar .organization-subscribe button.button-primary:active, .requests-table-toolbar .organization-subscribe button[data-selected="true"]:active, .subscriptions-subscribe button.button-primary:active, .subscriptions-subscribe button[data-selected="true"]:active, .button-primary.pagination-next-link:active, .button-primary.pagination-prev-link:active, .button-primary.pagination-first-link:active, .button-primary.pagination-last-link:active, .edit-profile-button a.button-primary:active {
  background-color: #001555;
  border-color: #001555;
}

.button[data-disabled], .section-subscribe button[data-disabled], .article-subscribe button[data-disabled], .community-follow button[data-disabled], .requests-table-toolbar .organization-subscribe button[data-disabled], .subscriptions-subscribe button[data-disabled], .pagination-next-link[data-disabled], .pagination-prev-link[data-disabled], .pagination-first-link[data-disabled], .pagination-last-link[data-disabled], .edit-profile-button a[data-disabled] {
  cursor: default;
}

.button-large, input[type="submit"] {
  cursor: pointer;
  background-color: rgba(0, 47, 187, 1);
  border: 0;
  border-radius: 3px;
  color: rgba(255, 255, 255, 1);
  font-size: 14px;
  font-weight: 400;
  line-height: 2.72;
  min-width: 190px;
  padding: 0 1.9286em;
  width: 100%;
}

@media (min-width: 768px) {
  .button-large, input[type="submit"] {
    width: auto;
  }
}

.button-large:hover, .button-large:active, .button-large:focus, input[type="submit"]:hover, input[type="submit"]:active, input[type="submit"]:focus {
  background-color: #001555;
}

.button-large[disabled], input[type="submit"][disabled] {
  background-color: #ddd;
}

.button-secondary {
  color: #666;
  border: 1px solid #DDDDDD;
  background-color: transparent;
}

.button-secondary:hover, .button-secondary:focus, .button-secondary:active {
  color: rgba(51, 51, 51, 1);
  border: 1px solid #DDDDDD;
  background-color: #f7f7f7;
}

/***** Tables *****/
.table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  border-spacing: 0;
}

@media (min-width: 768px) {
  .table {
    table-layout: auto;
  }
}

.table th,
.table th a {
  color: #666;
  font-size: 13px;
  text-align: left;
}

[dir="rtl"] .table th, [dir="rtl"]
.table th a {
  text-align: right;
}

.table tr {
  border-bottom: 1px solid #DDDDDD;
  display: block;
  padding: 20px 0;
}

@media (min-width: 768px) {
  .table tr {
    display: table-row;
  }
}

.table td {
  display: block;
}

@media (min-width: 768px) {
  .table td {
    display: table-cell;
  }
}

@media (min-width: 1024px) {
  .table td, .table th {
    padding: 20px 30px;
  }
}

@media (min-width: 768px) {
  .table td, .table th {
    padding: 10px 20px;
    height: 60px;
  }
}

/***** Forms *****/

.form {
  max-width: 750px;
  background-color: #EEF3F6;
  padding: 30px;
  border-radius: 3px;
  margin-bottom: 50px;
}

.form p {
  text-align: left;
}

.form .rPCMa span.kXVLDw,
.form .hMopEg span.kXVLDw {
  color: red;
  padding-left: 5px;
}

.lnPyYC h2 {
  font-size: 17px;
}

.ihVAXT {
  background: #fff;
  padding: 25px;
  border: 1px solid rgb(216, 220, 222);
  border-radius: 4px;
}

.form-field ~ .form-field {
  margin-top: 25px;
}

.form-field label {
  display: block;
  font-size: 13px;
  margin-bottom: 5px;
  font-weight: 700;
}

.form-field.required > label::after {
  margin-left: 2px;
  content: "*";
  color: #FC8181;
}

.form-field input,
.form input {
  border: 1px solid #DDDDDD;
  border-radius: 4px;
  padding: 10px;
  width: 100%;
}

.new_community_post input[type="submit"] {
  width: 10%;
  padding: 2px;
}

body .ck.ck-editor__main>.ck-editor__editable:not(.ck-focused), .hbs-form select, .search select, .form select, .form .bQzCzH, .upload-dropzone, .form div[role="button"] {
  border: 1px solid #DDDDDD;
}

body .ck.ck-editor__top .ck-sticky-panel .ck-sticky-panel__content {
  border: solid #DDDDDD;
  border-width: 1px 1px 0;
}

.form .ggKiGq, .upload-dropzone, .form div[role="button"] {
  background-color: #fff;
  border: 1px dashed #DDDDDD;
}

.form button[type="submit"] {
    border-radius: 3px;
    min-width: 190px;
}

.form-field input:focus {
  border: 1px solid rgba(0, 47, 187, 1);
}

.form-field input[type="text"] {
  border: 1px solid #DDDDDD;
  border-radius: 4px;
}

.form-field input[type="text"]:focus {
  border: 1px solid rgba(0, 47, 187, 1);
}

.form-field input[type="checkbox"] {
  width: auto;
}

.form-field .nesty-input {
  border-color: #DDDDDD;
  border-radius: 3px;
  height: 40px;
  line-height: 40px;
  outline: none;
  vertical-align: middle;
}

.form-field .nesty-input:focus {
  border: 1px solid rgba(0, 47, 187, 1);
  text-decoration: none;
}

.form-field .hc-multiselect-toggle:focus {
  outline: none;
  border: 1px solid rgba(0, 47, 187, 1);
  text-decoration: none;
}

.form-field textarea {
  vertical-align: middle;
}

.form-field input[type="checkbox"] + label {
  margin: 0 0 0 10px;
}

.form-field .optional {
  color: #666;
  margin-left: 4px;
}

.form-field p {
  color: #666;
  font-size: 12px;
  margin: 5px 0;
}

.form footer {
  margin-top: 0;
  padding-top: 30px;
  text-align: right;
}

.form footer a {
  color: #666;
  cursor: pointer;
  margin-right: 15px;
}

.form .suggestion-list {
  font-size: 13px;
  margin-top: 15px;
}

.form .suggestion-list h2 {
  font-size: 14px;
  margin-bottom: 0;
}

.form .suggestion-list .searchbox {
  background: #fff;
  border: 1px solid #DDDDDD;
  padding: 20px;
  border-radius: 3px;
}

.form .suggestion-list label {
  border-bottom: 1px solid #DDDDDD;
  display: block;
  padding-bottom: 5px;
}

.form .suggestion-list li {
  padding: 10px 0;
}

.form .suggestion-list li a:visited {
  color: #001555;
}

.upload-item,
.bNjKvm {
  background: #ffffff;
}

.upload-item:hover {
  background: #abc4d3;
}

.ck.ck-button:focus-visible, .ck.ck-content.ck-editor__editable.ck-editor__editable_inline.ck-focused,
.ck.ck-content.ck-editor__editable.ck-focused, .ck.ck-toolbar:focus-visible {
  box-shadow: none !important;
  border-color: #DDDDDD !important;
}

.gNoOyn {
  text-align: right;
}

.post-bb {
  border-bottom: 1px solid #DDDDDD;
  margin-bottom: 25px;
}

/***** Header *****/

.alert--bar {
  background: #F05064;
  padding: 10px 0;
  color: #FFFFFF;
  text-align: center;
  position: relative;
  z-index: 3;
}

@media (max-width: 768px) {
  .alert--bar {
    font-size: 11px;
  }
}

.alert--bar a {
  color: #FFFFFF;
  border-bottom: 1px solid;
}

.hc_header {
  background: transparent;
  z-index: 9;
  position: relative;
}

._border {
  border-bottom: 1px solid #fff;
}

.header {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 5%;
  position: relative;
  align-items: center;
  display: flex;
  height: 100px;
  justify-content: space-between;
}

@media (min-width: 1160px) {
  .header {
    padding: 0;
    width: 90%;
  }
}

.logo img {
  max-height: 48px;
}

.user-nav {
  display: inline-block;
  position: absolute;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .user-nav {
    position: relative;
  }
  .form button[type="submit"] {
    float: right;
    margin-bottom: 10px;
  }
}

.user-nav[aria-expanded="true"] {
  background-color: #fff;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.15), 0 4px 10px 0 rgba(0, 0, 0, 0.1);
  border: solid 1px #ddd;
  right: 0;
  left: 0;
  top: 100px;
  z-index: 1;
}

.user-nav[aria-expanded="true"] > a {
  display: block;
  margin: 20px;
}

.logo span {
  color: #FFFFFF;
  height: 48px;
  display: inline-block;
  vertical-align: bottom;
  margin-left: 5px;
}

@media (min-width: 768px) {
  .nav-wrapper .cd-primary-nav-trigger {
    padding-right: 0;
    margin-right: -12px;
  }
}

.nav-wrapper a.login {
  display: inline-block;
}

.nav-wrapper .menu-button {
  background: none;
  border: 0;
  color: #fff;
  display: inline-block;
  margin-right: 2px;
  padding: 0;
  width: auto;
  cursor: pointer;
}

@media (min-width: 768px) {
  .nav-wrapper .menu-button {
    display: none;
  }
}

.nav-wrapper .menu-button .icon-menu {
  vertical-align: middle;
  width: 17px;
  height: 17px;
}

[dir="rtl"] .nav-wrapper .menu-button {
  margin-left: 10px;
  margin-right: 0;
}

.nav-wrapper .menu-button:hover, .nav-wrapper .menu-button:focus, .nav-wrapper .menu-button:active {
  background-color: transparent;
  color: #fff;
}

.user-nav-list {
    display: block;
    list-style: none;
}
  .user-nav-list > li {
    display: inline-block;
}
  @media (max-width: 768px) {
  .nav-wrapper-desktop {
    display: none;
  }
}
@media (min-width: 768px) {
  .nav-wrapper-desktop {
    display: none;
  }
}
@media (min-width: 1024px) {
  .nav-wrapper-desktop {
    display: inline-block;
  }
}
.nav-wrapper-desktop a {
  border: 0;
  color: #FFFFFF;
  display: none;
  font-size: 16px;
  padding: 0 10px 0 10px;
  width: auto;
}
@media (min-width: 768px) {
  .nav-wrapper-desktop a {
    display: inline-block;
  }
}
[dir=rtl] .nav-wrapper-desktop a {
  padding: 0 0 0 20px;
}
.nav-wrapper-desktop a:hover, .nav-wrapper-desktop a:focus, .nav-wrapper-desktop a:active {
  color: #FFFFFF;
  opacity: 0.9;
}

@media (min-width: 1024px) {
  .nav-wrapper-mobile {
    display: none;
  }
}
.nav-wrapper-mobile .menu-button-mobile {
  background: none;
  border: 0;
  width: auto;
  cursor: pointer;
  padding: 0;
}
.nav-wrapper-mobile .menu-button-mobile .icon-menu {
  background: rgba(0, 47, 187, 1);
  color: #fff;
  padding: 7px;
  vertical-align: middle;
  width: 35px;
  height: 35px;
  border-radius: 50%;
}
.nav-wrapper-mobile .menu-button-mobile[aria-expanded=true] .icon-menu {
  background: rgba(0, 47, 187, 1);
}
.nav-wrapper-mobile .menu-list-mobile {
  position: absolute;
  background-color: #fff;
  box-shadow: 0 10px 10px 0 rgba(0, 0, 0, 0.15);
  border-top: solid 1px #ddd;
  border-bottom: solid 1px #ddd;
  right: 0;
  left: 0;
  top: 100px;
  z-index: 2;
}
.nav-wrapper-mobile .menu-list-mobile[aria-expanded=false],
.nav-wrapper-mobile .menu-list-mobile-items li:empty:not(.nav-divider),
.nav-wrapper-mobile .menu-list-mobile-items .nav-divider:last-child,
body .fancybox__caption,
body .fancybox__button--zoom,
body .fancybox__button--fullscreen {
  display: none;
}
.nav-wrapper-mobile .menu-list-mobile[aria-expanded=true] {
  display: block;
}
.nav-wrapper-mobile .menu-list-mobile-items .item {
  margin: 4px 0;
}
.nav-wrapper-mobile .menu-list-mobile-items .nav-divider {
  border-bottom: 0.1px solid #ddd;
  padding: 0;
}
.nav-wrapper-mobile .menu-list-mobile-items button {
  background: none;
  border: none;
  padding: 8px 24px;
  width: 100%;
  height: 100%;
  color: rgba(51, 51, 51, 1);
  cursor: pointer;
  text-align: start;
}
.nav-wrapper-mobile .menu-list-mobile-items button:active, .nav-wrapper-mobile .menu-list-mobile-items button:focus, .nav-wrapper-mobile .menu-list-mobile-items button:hover {
  background-color: #f7f7f7;
}
.nav-wrapper-mobile .menu-list-mobile-items a {
  display: block;
  padding: 8px 24px;
  width: 100%;
  height: 100%;
  color: rgba(51, 51, 51, 1);
}
.nav-wrapper-mobile .menu-list-mobile-items a:active, .nav-wrapper-mobile .menu-list-mobile-items a:focus, .nav-wrapper-mobile .menu-list-mobile-items a:hover {
  background-color: #f7f7f7;
}
.nav-wrapper-mobile .menu-list-mobile-items .my-profile {
  display: flex;
  line-height: 1.5;
}
.nav-wrapper-mobile .menu-list-mobile-items .my-profile .my-profile-tooltip {
  font-size: 12px;
  color: #68737D;
}
.nav-wrapper-mobile .menu-list-mobile-items .menu-profile-avatar {
  height: 40px;
  width: 40px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 8px;
  margin-top: 1px;
}
[dir=rtl] .nav-wrapper-mobile .menu-list-mobile-items .menu-profile-avatar {
  margin-right: 0;
  margin-left: 8px;
}

.skip-navigation {
  align-items: center;
  background-color: black;
  color: white;
  display: flex;
  font-size: 14px;
  justify-content: center;
  left: -999px;
  margin: 20px;
  padding: 20px;
  overflow: hidden;
  position: absolute;
  top: auto;
  z-index: -999;
}
[dir=rtl] .skip-navigation {
  left: initial;
  right: -999px;
}
.skip-navigation:focus, .skip-navigation:active {
  left: auto;
  overflow: auto;
  text-align: center;
  text-decoration: none;
  top: auto;
  z-index: 999;
}
[dir=rtl] .skip-navigation:focus, [dir=rtl] .skip-navigation:active {
  left: initial;
  right: auto;
}

#zd-modal-container ~ .skip-navigation,
.search .clear-button {
  display: none;
}

/***** User info in header *****/
.user-info {
  display: inline-block;
}

.user-info .dropdown-toggle::after {
  display: none;
}

@media (min-width: 768px) {
  .user-info .dropdown-toggle::after {
    display: inline-block;
  }
}

.user-info > button {
  background: rgba(0, 47, 187, 1);
  border: 1px solid rgba(0, 47, 187, 1);
  border-radius: 3px;
  color: #FFFFFF;
  min-width: 0;
  padding: 5px 10px;
  white-space: nowrap;
}

.user-info > button:hover, .user-info > button:focus {
  color: #FFFFFF;
  opacity: 0.9;
}

.user-info > button::after {
  color: rgba(0, 47, 187, 1);
  padding-right: 15px;
}

[dir="rtl"] .user-info > button::after {
  padding-left: 15px;
  padding-right: 0;
}

#user #user-name {
  display: none;
  font-size: 14px;
}

@media (min-width: 768px) {
  #user #user-name {
    display: inline-block;
  }
}

#user #user-name:hover {
  text-decoration: underline;
}

/***** User avatar *****/
.user-avatar {
  height: 25px;
  width: 25px;
  border-radius: 50%;
  display: inline-block;
  vertical-align: middle;
}

.avatar {
  display: inline-block;
  position: relative;
}

.avatar img {
  height: 40px;
  width: 40px;
}

.avatar .icon-agent {
  color: rgba(0, 47, 187, 1);
  border: 2px solid #fff;
  border-radius: 50%;
  bottom: -4px;
  background-color: rgba(255, 255, 255, 1);
  font-size: 17px;
  height: 17px;
  line-height: 17px;
  position: absolute;
  right: -2px;
  text-align: center;
  width: 17px;
}

/***** Footer *****/

.footer {
    background: rgba(0, 47, 187, 1);
    margin-top: 40px;
    color: #ffffff;
}

._grid ._col_4 {
    flex: 1 0 auto;
    width: 25%;
    padding-top: 50px;
    padding-bottom: 10px;
    padding-right: 15px;
}

.hc_footer h3:after,
.article-relatives h2:after,
.article-sidebar .sidenav-title:after,
.new-request-title:after {
    content: "";
    background: #ffffff;
    height: 3px;
    display: block;
    margin-top: 10px;
    max-width: 50px;
}

.article-relatives h2:after,
.article-sidebar .sidenav-title:after,
.new-request-title:after {
    background: rgba(0, 47, 187, 1);
    margin-top: 5px;
}

.hc_footer ._col h3 {
    color: #ffffff;
    font-size: 1.3em;
    font-weight: 700;
}

.hc_footer ._col li {
    padding: 6px 0;
    line-height: 1.2;
}

.footer .social {
    margin-bottom: 10px;
}

.footer .social li {
    display: inline-block;
    margin: 1px;
    padding-bottom: 0;
}
.footer .social li a {
    border: 1px solid #ffffff;
    height: 35px;
    display: block;
    width: 35px;
    line-height: 32px;
    border-radius: 3px;
    text-align: center;
}
.footer .social li i {
    font-size: 0.9em;
}
.footer .social li a:hover,
.footer .social li a:focus {
    background: #fff;
    border-color: #fff;
    color: #333;
}
.footer .social li a:hover {
  transform: translateY(-6px);
}
.footer a,
.footer_copyright a,
.footer_copyright p {
    color: #ffffff;
}
.footer-inner {
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 5%;
    display: flex;
    justify-content: space-between;
}
.text-center {
    text-align: center;
}

.footer_copyright {
    background: rgba(0, 47, 187, 1);
    padding: 10px 1px 10px 1px;
    color: #fff;
}

.footer_copyright a {
   border-bottom: 1px dashed #fff;
}

@media (min-width: 1160px) {
  .footer-inner {
    padding: 0;
    width: 90%;
  }
  .nav-wrapper .cd-primary-nav-trigger {
    padding-right: 0;
    margin-right: -10px;
  }
}

.footer-language-selector {
  color: #666;
  display: inline-block;
  font-weight: 300;
}

.footer-language-selector button.dropdown-toggle {
  color: #ffffff;
  border: 1px solid #ffffff;
  border-radius: 3px;
  padding: 10px 25px;
}

@media (max-width: 500px) {
  body ._grid ._col_4 {
    width: 100%;
    padding-top: 30px;
    padding-bottom: 0;
  }

  body .footer {
    padding-bottom: 0;
  }

  .footer_copyright p {
    margin-top: 0;
  }

  body .home__categories,
  body .contact--blocks {
    padding: 40px 0;
  }

  body .quick-articles > section {
      margin: 20px 0 0;
  }

  .blocks-list li:last-child {
    margin-bottom: 0;
  }

  .user-info .dropdown-toggle > span {
    display: none;
  }

}

/***** Breadcrumbs *****/

.breadcrumbs {
  margin: 0;
  padding: 0;
}

.breadcrumbs li {
  display: inline;
  font-size: 14px;
  max-width: 450px;
  overflow: hidden;
  text-overflow: ellipsis;
}

[dir=ltr] .breadcrumbs__block .breadcrumbs li:first-child a:before,
[dir=rtl] .breadcrumbs__block .breadcrumbs li:first-child a:after {
  content: "\ea81";
  padding-right: 8px;
  font-family: "LineIcons";
  font-size: 15px;
  position: relative;
  top: 3px;
}

[dir=rtl] .breadcrumbs__block .breadcrumbs li:first-child a:after {
  padding-right: 0;
  padding-left: 8px;
}

[dir=ltr] .breadcrumbs li + li::before,
[dir=rtl] .breadcrumbs li + li::after {
  content: "\eb0d";
  font-family: "LineIcons";
  margin: 0 4px;
  font-size: 10px;
}

[dir=rtl] .breadcrumbs li + li::after {
  content: "\eb0f";
}

.breadcrumbs li a:visited {
  color: #333;
}

/***** Search field *****/

.search {
  position: relative;
}

.hero .search {
  margin-top: 25px;
  box-shadow: 0 20px 25px -5px rgb(0 0 0 / 10%), 0 10px 10px -5px rgb(0 0 0 / 4%);
}

.search input[type="search"] {
  box-sizing: border-box;
  color: #333;
  padding-left: 40px;
  padding-right: 20px;
  -webkit-appearance: none;
  width: 100%;
}

.requests-table-toolbar .search input[type="search"] {
  border-color: #DDDDDD;
  background-color: #fff;
  padding-left: 40px;
}

.requests-table-toolbar .search input[type="search"]:focus {
  border-color: #ddd;
}

[dir="rtl"] .search input[type="search"] {
  padding-right: 20px;
  padding-left: 110px;
}

[dir="rtl"] .search input[type="submit"] {
  right: inherit;
  left: 0;
}

.search input[type="search"]:focus {
  border: 1px solid #fff;
}

.search-full input[type="search"] {
  border: 1px solid #fff;
}

.search input[type="search"] {
    background-color: #ffffff;
    border: 1px solid #ffffff;
    border-radius: 3px;
    height: 60px;
    padding: 10px 110px 10px 20px;
    font-size: 16px;
    font-weight: 400;
    width: 100%;
}

.search input[type="submit"] {
    border: medium none;
    color: rgba(255, 255, 255, 1);
    height: calc(100% - 0.5rem);
    overflow: hidden;
    position: absolute;
    right: 0;
    top: 0;
    vertical-align: middle;
    background: rgba(0, 47, 187, 1);
    padding: 0 15px;
    border-radius: 3px;
    margin: 0.25rem;
    min-width: 100px;
    max-width: 100px;
}

.search-icon {
  position: relative;
  top: 50%;
  transform: translateY(28px);
  position: absolute;
  left: 15px;
  z-index: 1;
  width: 18px;
  height: 18px;
  color: #777;
}

.breadcrumbs__block .search-icon,
.requests-table-toolbar .search-icon {
    transform: translateY(-7px);
}

[dir="rtl"] .search-icon {
  right: 15px;
  left: auto;
}

.search-container {
  position: relative;
}

.breadcrumbs__block {
  border-bottom: 1px solid #DDDDDD;
  padding: 20px 0;
  margin-bottom: 30px;
}

/***** Hero component *****/

.welcome_text {
  color: #ffffff;
  margin-bottom: 0;
  font-weight: 700;
  font-size: 3em;
  line-height: 1.1;
}

.help-center-details {
  color: #ffffff;
  font-size: 1.2em;
  font-weight: 300;
}

.hero {
  background-color: rgba(0, 47, 187, 1);
  padding: 180px 0 100px 0;
  margin-top: -100px;
  width: 100%;
}

.colored-header {
  background: rgba(0, 47, 187, 1);
}

.pages--hero {
  padding: 120px 0 60px 0;
}

.hero-image {
    background-image: url(/hc/theming_assets/01KE0GDDJECDS5TT6JACJSW3Q8);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}

.hero-image::before,
.community-hero::before {
    content: "";
    background: rgba(0, 47, 187, 1);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    opacity: 0.6;
}

.hero-gradiant {
    background-image: linear-gradient(-150deg, #19003B 0%, #280082 97%);
}

.header-gradiant {
  background: transparent;
}

.hero-inner {
  max-width: 650px;
  position: relative;
  z-index: 1;
}

.search--center {
  margin: 0 auto;
  text-align: center;
}

.page-header {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 10px 0;
}

@media (min-width: 768px) {
  .page-header {
    align-items: baseline;
    flex-direction: row;
    margin: 0;
  }
}

.page-header .section-subscribe {
  flex-shrink: 0;
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .page-header .section-subscribe {
    margin-bottom: 0;
  }
}

.page-header h1 {
  color: #333;
  flex-grow: 1;
  margin-bottom: 15px;
}

.my-activities-header > h1 {
  font-weight: 600;
}

.page-header-description {
  color: #8c8c8c;
  margin: 0 0 30px 0;
  word-break: break-word;
}

@media (min-width: 1024px) {
  .page-header-description {
    flex-basis: 100%;
  }
}

.page-header .icon-lock {
  height: 20px;
  width: 20px;
  position: relative;
  left: -5px;
  vertical-align: baseline;
}

.sub-nav {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-bottom: 30px;
  min-height: 50px;
  padding-bottom: 15px;
}

.breadcrumbs__block .sub-nav {
  margin-bottom: 0;
  padding-bottom: 0;
  min-height: inherit;
}

@media (min-width: 768px) {
  .sub-nav {
    align-items: baseline;
    flex-direction: row;
  }
}

@media (min-width: 768px) {
  .sub-nav input[type="search"] {
    min-width: 300px;
  }
}

.sub-nav input[type="search"]::after {
  font-size: 15px;
}

/***** Blocks *****/
/* Used in Homepage#categories and Community#topics */
.blocks-list,
.quick-articles,
._grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  list-style: none;
  padding: 0;
}

.pt-30 {
  padding-top: 30px;
}

body .mb-0,
.article-sidebar ul.mb-0,
.article-sidebar ul.mb-0 > li:last-child {
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .blocks-list {
    margin: -12px;
  }
  .quick-articles {
    margin: 0 -10px;
  }
}

.blocks-item,
.quick-articles > section {
  background: #fff;
  border: 1px solid #DDDDDD;
  border-radius: 4px;
  box-sizing: border-box;
  color: rgba(0, 47, 187, 1);
  display: flex;
  flex: 1 0 340px;
  margin: 0 0 30px;
  max-width: 100%;
  transition: all 0.3s ease;
}

.blocks-item {
  border-radius: 5px;
}

.quick-articles > section {
    display: block;
    margin: 40px 15px 10px;
    text-align: left;
    padding: 25px;
}

[dir="rtl"] .quick-articles > section {
  text-align: inherit;
}

.quick-articles h2 {
    font-size: 1.4em;
    font-weight: 700;
    color: rgba(51, 51, 51, 1);
    margin-bottom: 0;
}

@media (min-width: 768px) {
  .blocks-item {
    margin: 15px 15px 15px;
  }
}

.blocks-item:hover, .blocks-item:focus, .blocks-item:active {
  background-color: #fff;
  border-color: rgba(0, 47, 187, 1);
  transition: all 0.3s ease;
}

.blocks-item:hover *, .blocks-item:focus *, .blocks-item:active * {
  color: rgba(51, 51, 51, 1);
  text-decoration: none;
}

.topics-list .blocks-item:hover i {
  color: rgba(0, 47, 187, 1);
}

.blocks-item-internal {
  background-color: transparent;
  border: 1px solid #ddd;
}

.blocks-item-internal .icon-lock {
  height: 15px;
  width: 15px;
  bottom: 5px;
  position: relative;
}

.blocks-item-internal a {
  color: rgba(51, 51, 51, 1);
}

.blocks-item-link {
  background: #fff;
  color: rgba(51, 51, 51, 1);
  padding: 30px;
  display: flex;
  flex-direction: column;
  flex: 1;
  border-radius: inherit;
  position: relative;
}

.icon--center .blocks-item-link {
  align-items: center;
  text-align: center;
}

.blocks-item-link:hover, .blocks-item-link:active {
  text-decoration: none;
}

.blocks-item:hover {
  transform: scale(1.025);
}

.blocks-item-link:focus {
  outline: 0;
  box-shadow: none;
  text-decoration: none;
}

.blocks-item-title {
  font-family: 'Open Sans', sans-serif;
  margin-bottom: 0;
  font-weight: 700;
  font-size: 1.4em;
}

.blocks-item-description {
  color: #8c8c8c;
  font-size: 1em;
  margin: 0;
}

.blocks-item-description:not(:empty) {
  margin-top: 10px;
}

/***** Homepage *****/

.home__categories {
  background: #EEF3F6;
  padding: 60px 0;
}

.contact--blocks {
  background: rgba(26, 116, 176, 0.08);
  padding: 60px 0;
  margin-bottom: -40px;
}

.section {
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .section {
    margin-bottom: 60px;
  }
}

.b-700 {
  font-weight: 700;
}

.home-section h2 {
  color: rgba(51, 51, 51, 1);
  margin-bottom: 10px;
  text-align: center;
  font-weight: 600;
}

.category-icon i {
  display: none;
}

.blocks-item span.category-icon,
.topic-icon,
.category-icon i:last-child {
    display: block;
}

.category-icon img {
  max-width: 45px;
  margin-bottom: 10px;
}

.blocks-item .category-icon i,
.topic-icon i {
    color: rgba(0, 47, 187, 1);
    font-size: 2.5em;
    margin-bottom: 15px;
}

.article-list li:before,
.quick-articles ul > li > a:before,
.article-sidebar ul > li:before,
.section-lists li:before {
    content: "\f15c";
    color: rgba(0, 47, 187, 1);
    font-family: "FontAwesome";
    position: absolute;
    left: 0;
    margin-top: 2px;
}

[dir="rtl"] .article-list li:before,
[dir="rtl"] .quick-articles ul > li > a:before,
[dir="rtl"] .article-sidebar ul > li:before,
[dir="rtl"] .section-lists li:before {
    left: inherit;
    right: 0;
}

.section-lists li:before {
    content: "\f07c";
}
.article-relatives li a {
    color: #333;
}
.article-relatives h2 {
    margin-bottom: 15px;
}
.article-list li:last-child {
    border-bottom: 0;
}

/***** Promoted articles *****/

.promoted-articles {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}

@media (min-width: 1024px) {
  .promoted-articles {
    flex-direction: row;
  }
}

.promoted-articles-item {
  flex: 1 0 auto;
}

@media (min-width: 1024px) {
  .promoted-articles-item {
    align-self: flex-end;
    flex: 0 0 auto;
    padding-right: 0;
    width: 100%;
    /* Three columns on desktop */
  }
  [dir="rtl"] .promoted-articles-item {
    padding: 0 0 0 30px;
  }
}

.promoted-articles-item:nth-child(3n) {
  padding-right: 0;
}

.promoted-articles-item a,
.quick-articles li a {
  display: block;
  border-bottom: 1px solid #DDDDDD;
  padding: 15px 0;
  color: rgba(51, 51, 51, 1);
}

.quick-articles li a,
.article-list li,
.article-sidebar ul> li,
.section-lists li {
    padding-left: 25px;
}

[dir="rtl"] .quick-articles li a,
[dir="rtl"] .article-list li,
[dir="rtl"] .article-sidebar ul> li,
[dir="rtl"] .section-lists li {
    padding-left: 0;
    padding-right: 25px;
}

.quick-articles ul li:last-child a {
    border-bottom: 0;
}

.quick-articles section li,
.article-list li,
.section-lists li {
    position: relative;
    margin-bottom: 0;
}

.promoted-articles-item .icon-lock {
  vertical-align: baseline;
}

.promoted-articles-item:last-child a {
  border: 0;
}

@media (min-width: 1024px) {
  .promoted-articles-item:last-child a {
    border-bottom: 1px solid #DDDDDD;
  }
}

.new-request-title {
  margin-bottom: 30px;
}

/***** Community section in homepage *****/

.community {
  text-align: center;
}

.community-image {
  display: flex;
  align-items: center;
  min-height: 200px;
  background-image: url($community_image);
  background-position: center;
  background-repeat: no-repeat;
  max-width: 100%;
  position: relative;
  text-align: center;
}

.community,
.activity {
  border-top: 0;
  padding: 30px 0;
}

/***** Recent activity *****/

.recent-activity-list {
  padding: 0;
}

.recent-activity-item {
  border-bottom: 1px solid #DDDDDD;
  overflow: auto;
  padding: 20px 0;
}

.recent-activity-item h3 {
  margin-bottom: 5px;
}

.recent-activity-item h3 a {
  font-weight: 700;
  font-size: 17px;
}

.quick-articles .recent-activity-item {
  padding: 10px 0;
}

.quick-articles .recent-activity-list section:last-child {
  border-bottom: 0;
}

.quick-articles .recent-activity-controls {
  padding-top: 0;
}

.recent-activity-item-parent {
  font-size: 16px;
  font-weight: 500;
}

.recent-activity-item-parent, .recent-activity-item-link {
  margin: 6px 0;
  color: rgba(51, 51, 51, 1);
  display: inline-block;
  width: 100%;
}

@media (min-width: 768px) {
  .recent-activity-item-parent, .recent-activity-item-link {
    width: 70%;
    margin: 0;
  }
  .quick-articles .recent-activity-item-parent,
  .quick-articles .recent-activity-item-link {
    width: 100%;
  }
}

.quick-articles .recent-activity-item-parent,
.quick-articles .recent-activity-item-link {
   color: rgba(51, 51, 51, 1);
}

.recent-activity-item-meta {
  margin: 5px 0 5px 0;
  display: flex;
  justify-content: space-between;
}

.recent-activity-item-time, .recent-activity-item-comment {
  color: rgba(0, 47, 187, 1);
  display: inline-block;
  font-size: 12px;
}

.home-recent-activity .recent-activity-item-time {
  color: #8c8c8c;
}

.recent-activity-item-comment {
  padding-left: 5px;
}

[dir="rtl"] .recent-activity-item-comment {
  padding: 0 5px 0 0;
}

.recent-activity-item-comment::before {
  display: inline-block;
}

.recent-activity-controls {
  padding-top: 15px;
}

.recent-activity-comment-icon svg {
  vertical-align: middle;
  color: rgba(0, 47, 187, 1);
  width: 16px;
  height: 16px;
}

.recent-activity-comment-icon:after {
  content: attr(data-comment-count);
  margin-left: 3px;
}

[dir="rtl"] .recent-activity-comment-icon:after {
  margin-left: 0;
  margin-right: 3px;
}

.home-recent-activity .recent-activity-item h3 {
  display: none;
}

/***** Category pages *****/

.category-container {
  display: flex;
  justify-content: flex-end;
}

.category-container .category-empty {
  padding-left: 20px;
}

.category-content {
  flex: 1;
}

@media (min-width: 1024px) {
  .category-content {
    flex: 0 0 100%;
  }
}

.section-tree {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}

@media (min-width: 768px) {
  .section-tree {
    flex-direction: row;
    margin: 0 -15px;
  }
}

.section-tree .section {
  flex: initial;
}

.category-container .section-tree .section {
  background: #EEF3F6;
  border-radius: 3px;
  padding: 30px;
  margin: 15px;
}

@media (min-width: 768px) {
  .section-tree .section {
    flex: 0 0 30%;
    /* Two columns for tablet and desktop. Leaving 5% separation between columns */
  }
}

.section-tree-title {
  margin-bottom: 0;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 10px;
}

.section-tree-title a {
  color: #333;
}

.section-tree .see-all-articles,
.recent-activity-controls > a {
  display: block;
  padding: 6px 15px;
  background: rgba(0, 47, 187, 1);
  border-radius: 3px;
  color: rgba(255, 255, 255, 1);
  margin-top: 10px;
  margin-bottom: 5px;
}

.section-tree .see-all-articles {
  text-align: center;
}

.see-all-articles i {
  transform: rotate(-40deg);
  font-size: 13px;
  margin-left: 4px;
}

.recent-activity-controls > a {
  display: inline-block;
}

.article-list-item,
.section-lists-item {
  font-size: 16px;
  padding: 10px 0;
}

.article-list-item a,
.section-lists-item a {
  color: #333;
}

.icon-star {
  color: rgba(0, 47, 187, 1);
  font-size: 18px;
}

/***** Section pages *****/

.section-container {
  display: flex;
  justify-content: flex-end;
}

.section-container ul.article-list,
.section-container .section-lists {
  background: #EEF3F6;
  padding: 25px;
  border-radius: 3px;
}

.section-container .section-lists {
  margin-top: 10px;
}

.section-content {
  flex: 1;
}

@media (min-width: 1024px) {
  .section-content {
    flex: 0 0 100%;
  }
}

.section-list {
  margin: 40px 0;
}

.section-list--collapsed .section-list-item:nth-child(1n + 6) {
  display: block;
}


.section-list-item {
  border-bottom: 1px solid #ddd;
  font-size: 16px;
  padding: 15px 0;
}

.section-list-item:first-child {
  border-top: 1px solid #ddd;
}

.section-list-item a {
  align-items: center;
  color: rgba(51, 51, 51, 1);
  display: flex;
  justify-content: space-between;
}

.see-all-sections-trigger {
  cursor: pointer;
  display: block;
  padding: 15px;
  text-align: center;
}

.see-all-sections-trigger[aria-hidden="true"] {
  display: none;
}

/***** Article *****/
.article {
  /*
  * The article grid is defined this way to optimize readability:
  * Sidebar | Content | Free space
  * 17%     | 66%     | 17%
  */
  flex: 1 0 auto;
}

@media (min-width: 1024px) {
  .article {
    flex: 1 0 75%;
    max-width: 75%;
    min-width: 640px;
    padding: 0 40px 0 0;
  }
  [dir="rtl"] .article {
    padding: 0px 0 0px 40px;
  }
}

.article-container {
  display: flex;
  flex-direction: column;
}

@media (min-width: 1024px) {
  .article-container {
    flex-direction: row-reverse;
  }
}

.article-header {
  border-bottom: 1px solid #DDDDDD;
  padding-bottom: 20px;
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 20px;
  margin-top: 20px;
}

@media (min-width: 768px) {
  .article-header {
    flex-direction: row;
    margin-top: 0;
  }
}

.article-avatar {
  margin-right: 10px;
}

.article-author {
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .article-title {
    flex-basis: 100%;
    font-weight: 600;
    /* Take entire row */
  }
}

.article-title .icon-lock {
  position: relative;
  left: -5px;
  vertical-align: baseline;
}

.article [role="button"] {
  flex-shrink: 0;
  /*Avoid collapsing elements in Safari (https://github.com/philipwalton/flexbugs#1-minimum-content-sizing-of-flex-items-not-honored)*/
  width: 100%;
}

@media (min-width: 768px) {
  .article [role="button"] {
    width: auto;
  }
}

.article-info {
  font-size: 16px;
  max-width: 100%;
}

.article-meta {
  display: inline-block;
  vertical-align: middle;
}

.article-body img {
  height: auto;
  max-width: 100%;
}

.article-body iframe, .article-body img {
  box-shadow: 0 20px 25px -5px rgb(0 0 0 / 5%), 0 10px 10px -5px rgb(0 0 0 / 4%);
}

.article-body iframe,
.article-body a img,
body .fancybox__image {
  border-radius: 5px;
}

.article-body iframe {
  box-shadow: 25px 25px 0px 0px #EEF3F6;
  margin-bottom: 40px;
}

.article-body ul, .article-body ol,
#service-catalog-item ul,
#service-catalog-item ol {
  padding-left: 20px;
  list-style-position: outside;
  margin: 20px 0 20px 20px;
}

.article-body ul > li, .article-body ol > li,
#service-catalog-item ul > li,
#service-catalog-item ol > li {
  margin-bottom: 0.55rem;
  margin-top: 0.55rem;
}

[dir="rtl"] .article-body ul, [dir="rtl"] .article-body ol {
  padding-right: 20px;
  padding-left: 0;
  margin-left: 0;
  margin-right: 20px;
}

.article-body ul > ul, .article-body ol > ol, .article-body ol > ul, .article-body ul > ol, .article-body li > ul, .article-body li > ol {
  margin: 0;
}

.article-body ul {
  list-style-type: disc;
}

.article-body a:visited {
  color: rgba(0, 47, 187, 1);
}

.article-body a {
  text-decoration: underline;
  text-underline-position: under;
}

.article-body td,
#service-catalog-item td {
  padding: 10px;
}

.article-body code {
  background: #f7f7f7;
  border: 1px solid #ddd;
  border-radius: 3px;
  padding: 0 5px;
  margin: 0 2px;
}

.article-body pre {
  background: #EEF3F6;
  border: 1px solid #dde7ed;
  border-radius: 3px;
  padding: 10px 15px;
  overflow: auto;
  white-space: pre;
}

.article-body blockquote {
  border-left: 1px solid #ddd;
  color: #666;
  font-style: italic;
  padding: 0 15px;
}

.article-body > p:last-child {
  margin-bottom: 0;
}

.article-content {
  line-height: 1.8;
  margin: 30px 0;
  word-wrap: break-word;
}

.article-footer {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding-bottom: 20px;
  padding-top: 20px;
}

.article-comment-count {
  color: #666;
  font-weight: 300;
}

.article-comment-count:hover {
  text-decoration: none;
}

.article-comment-count-icon {
  vertical-align: middle;
  color: rgba(0, 47, 187, 1);
  width: 18px;
  height: 18px;
}

.article-sidebar {
  border-bottom: 1px solid #ddd;
  border-top: 1px solid #ddd;
  flex: 1 0 auto;
  margin-bottom: 20px;
  padding: 0;
}

.article-sidebar .article-sidebar-item {
  font-weight: 700;
  margin-top: 15px;
  display: inline-block;
}

.article-sidebar .article-sidebar-item i {
  position: relative;
  top: 1px;
}

[dir="rtl"] .article-sidebar .article-sidebar-item i {
  display: none;
}

.article-sidebar .article-sidebar-item i,
.article-sidebar .article-sidebar-item:hover i {
  transition: all 0.3s ease;
}

.article-sidebar .article-sidebar-item:hover i {
  transform: translateX(8px);
}

.article-body p > img.image-style-align-left {
  float: left;
  margin: 8px 20px 6px 0;
}
.article-body p > img.image-style-align-right {
  float: right;
  margin: 8px 0px 6px 20px;
}
.article-body p > img.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.article-body p > img.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.article-body figure.image {
  display: table;
  margin: 0 auto;
}
.article-body figure.image > img {
  display: block;
  width: 100%;
}
.article-body figure.image.image-style-align-left {
  float: left;
  margin: 8px 20px 6px 0;
}
.article-body figure.image.image-style-align-right {
  float: right;
  margin: 8px 0px 6px 20px;
}
.article-body figure.image.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.article-body figure.image.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.article-body figcaption {
  padding: 10px 0;
  font-size: 12px;
  text-align: center;
  background-color: #f2f2f2;
}

@media (min-width: 1024px) {
  .article-sidebar {
    border: 0;
    flex: 0 0 25%;
    height: auto;
  }
  .article-sidebar,
  .search-results-sidebar,
  .request-container .request-sidebar,
  .post-sidebar {
    align-self: start;
    position: sticky;
    top: 15px;
  }
}

.article-sidebar ul {
   margin-bottom: 25px;
}

.article-relatives > *:last-child {
  padding: 0;
}

.article-votes {
  border-top: 1px solid #DDDDDD;
  padding: 30px 0;
}

.article-votes .article-votes-controls {
  display: inline-block;
}

.article-vote {
  margin: 0 2px;
  min-width: 30px;
  width: auto;
}

.article-votes .article-votes-question {
  font-weight: 700;
}

.article-more-questions {
  margin: 0;
  text-align: center;
}

.article-return-to-top {
  border-top: 1px solid #ddd;
}

@media (min-width: 1024px) {
  .article-return-to-top {
    display: none;
  }
}

@media (max-width: 600px) {
  .article-votes {
    text-align: center;
  }
  .article-votes .article-votes-question,
  .article-votes .article-votes-controls {
    display: block;
  }
  .article-votes .article-votes-controls {
    margin: 15px 0;
  }
}

.article-return-to-top a {
  color: rgba(51, 51, 51, 1);
  display: block;
  padding: 20px 0;
}

.article-return-to-top a:hover, .article-return-to-top a:focus {
  text-decoration: none;
}

.article-return-to-top-icon {
  transform: rotate(0.5turn);
}

.sidenav-title {
  font-size: 18px;
  position: relative;
  font-weight: 700;
  margin-bottom: 15px;
  display: block;
  font-family: 'Open Sans', sans-serif;
}

.sidenav-item {
  color: rgba(51, 51, 51, 1);
  display: block;
}

.sidenav-item.current-article, .sidenav-item:hover,
.article-sidebar li a:hover {
  color: rgba(0, 47, 187, 1);
}

.recent-articles li,
.related-articles li,
.article-sidebar ul > li{
  margin-bottom: 12px;
  position: relative;
}


/***** Attachments *****/
/* Styles attachments inside posts, articles and comments */
.attachments .attachment-item {
  position: relative;
  margin-bottom: 10px;
}

.article-content .attachments .attachment-item {
  background: #eef3f6;
  padding: 10px 15px;
  border-radius: 10px;
}

.article-content .article-attachments li:first-child {
  margin-top: 25px;
}

.attachments .attachment-item:last-child {
  margin-bottom: 0;
}

.attachments .attachment-item .attachment-icon {
  color: rgba(51, 51, 51, 1);
  left: 0;
  position: relative;
  top: 2px;
}

[dir="rtl"] .attachments .attachment-item {
  padding-left: 0;
  padding-right: 20px;
}

[dir="rtl"] .attachments .attachment-item .attachment-icon {
  left: auto;
  right: 0;
}

.upload-dropzone {
  border-color: #DDDDDD;
  background-color: #fff;
  border-radius: 4px;
}

.upload-dropzone span {
  color: #666;
}

/***** Social share links *****/
.share {
  padding: 0;
  white-space: nowrap;
}

.share li, .share a {
  display: inline-block;
}

.share li {
  height: 25px;
  width: 25px;
}

.share a {
  color: #595959;
}

.share a:hover {
  text-decoration: none;
  color: rgba(0, 47, 187, 1);
}

.share a svg {
  height: 18px;
  width: 18px;
  display: block;
}

/***** Comments *****/
/* Styles comments inside articles, posts and requests */
.comment {
  border-bottom: 1px solid #DDDDDD;
  padding: 20px 0;
}

.comment-heading, .recent-articles-title,
.related-articles-title {
  margin-bottom: 5px;
  margin-top: 0;
  font-size: 18px;
  font-weight: 700;
}

.comment-overview {
  border-bottom: 1px solid #DDDDDD;
  border-top: 1px solid #DDDDDD;
  padding: 20px 0;
}

.comment-overview p {
  margin-top: 0;
}

.comment-callout {
  color: #666;
  display: inline-block;
  font-weight: 300;
  font-size: 13px;
  margin-bottom: 0;
}

.comment-callout a {
  color: rgba(0, 47, 187, 1);
}

.comment-sorter {
  display: inline-block;
  float: right;
}

.comment-sorter .dropdown-toggle {
  color: #666;
  font-size: 13px;
}

[dir="rtl"] .comment-sorter {
  float: left;
}

.comment-wrapper {
  display: flex;
  position: relative;
}

.comment-wrapper.comment-official {
  border: 1px solid rgba(0, 47, 187, 1);
  padding: 40px 20px 20px;
}

@media (min-width: 768px) {
  .comment-wrapper.comment-official {
    padding-top: 20px;
  }
}

.comment-info {
  min-width: 0;
  padding-right: 20px;
  width: 100%;
}

[dir="rtl"] .comment-info {
  padding-right: 0;
  padding-left: 20px;
}

.comment-author {
  align-items: flex-end;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

@media (min-width: 768px) {
  .comment-author {
    align-items: center;
    justify-content: space-between;
  }
}

#hc-wysiwyg {
  border-color: #DDDDDD;
}

.comment-avatar {
  margin-right: 10px;
}

[dir="rtl"] .comment-avatar {
  margin-left: 10px;
  margin-right: 0;
}

.comment-meta {
  flex: 1 0 auto;
}

.comment-labels {
  flex-basis: 100%;
}

@media (min-width: 768px) {
  .comment-labels {
    flex-basis: auto;
  }
}

.comment .status-label:not(.status-label-official) {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .comment .status-label:not(.status-label-official) {
    margin-top: 0;
  }
}

.comment-form {
  display: flex;
  padding-top: 30px;
  word-wrap: break-word;
}

.comment-container {
  width: 100%;
}

.comment-form-controls {
  display: none;
  margin-top: 10px;
  text-align: left;
}

@media (min-width: 768px) {
  [dir="ltr"] .comment-form-controls {
    text-align: right;
  }
}

.comment-form-controls input[type="submit"] {
  margin-top: 15px;
}

@media (min-width: 1024px) {
  .comment-form-controls input[type="submit"] {
    margin-left: 15px;
  }
  [dir="rtl"] .comment-form-controls input[type="submit"] {
    margin-left: 0;
    margin-right: 15px;
  }
}

.comment-form-controls input[type="checkbox"] {
  margin-right: 5px;
}

.comment-form-controls input[type="checkbox"] [dir="rtl"] {
  margin-left: 5px;
}

.comment-ccs {
  display: none;
}

.comment-ccs + textarea {
  margin-top: 10px;
}

.comment-attachments {
  margin-top: 10px;
}

.comment-attachments a {
  color: rgba(0, 47, 187, 1);
}

.comment-body {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  font-family: 'Open Sans', sans-serif;
  line-height: 1.6;
  overflow-x: auto;
}

.comment-body img {
  height: auto;
  max-width: 100%;
}

.comment-body ul, .comment-body ol {
  padding-left: 20px;
  list-style-position: outside;
  margin: 20px 0 20px 20px;
}

[dir="rtl"] .comment-body ul, [dir="rtl"] .comment-body ol {
  padding-right: 20px;
  padding-left: 0;
  margin-left: 0;
  margin-right: 20px;
}

.comment-body ul > ul, .comment-body ol > ol, .comment-body ol > ul, .comment-body ul > ol, .comment-body li > ul, .comment-body li > ol {
  margin: 0;
}

.comment-body ul {
  list-style-type: disc;
}

.comment-body a:visited {
  color: #001555;
}

.comment-body code {
  background: #f7f7f7;
  border: 1px solid #ddd;
  border-radius: 3px;
  padding: 0 5px;
  margin: 0 2px;
}

.comment-body pre {
  background: #f7f7f7;
  border: 1px solid #ddd;
  border-radius: 3px;
  padding: 10px 15px;
  overflow: auto;
  white-space: pre;
}

.comment-body blockquote {
  border-left: 1px solid #ddd;
  color: #666;
  font-style: italic;
  padding: 0 15px;
}

.comment-mark-as-solved {
  display: inline-block;
}

/***** Vote *****/
/* Used in article comments, post comments and post */
.vote {
  display: flex;
  flex-direction: column;
  text-align: center;
}

.vote a:active, .vote a:hover, .vote a:focus {
  text-decoration: none;
}

.vote-sum {
  color: #666;
  display: block;
  margin: 3px 0;
}

[dir="rtl"] .vote-sum {
  direction: ltr;
  unicode-bidi: bidi-override;
}

.vote-up svg {
  transform: scale(1, -1);
}

.vote-up:hover,
.vote-down:hover {
  color: rgba(0, 47, 187, 1);
}

.vote-up, .vote-down {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  color: #666;
  cursor: pointer;
  min-height: 35px;
  min-width: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vote-voted {
  color: rgba(0, 47, 187, 1);
}

.vote-voted:hover {
  color: #001555;
}

/***** Actions *****/
/* Styles admin and en user actions(edit, delete, change status) in comments and posts */
.actions {
  text-align: center;
  flex-shrink: 0;
  /*Avoid collapsing elements in Safari*/
}

.actions button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  cursor: pointer;
  min-height: 35px;
  min-width: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/***** Community *****/
.community-hero {
  background-image: url(/hc/theming_assets/01KE0GDDJECDS5TT6JACJSW3Q8);
  background-position: center center;
  background-size: cover;
  position: relative;
}

.community-footer {
  padding-top: 50px;
  text-align: center;
}

.community-footer-title {
  font-size: 20px;
  margin-bottom: 20px;
  font-weight: 600;
}

.community-featured-posts .title {
  font-weight: 700;
}

.community-featured-posts, .community-activity {
  padding-top: 40px;
  width: 100%;
}

.community-activity .recent-activity-header {
  font-weight: 700;
  margin-bottom: 0;
}

.community-header {
  margin-bottom: 30px;
}

.community-header .title {
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 600;
}

.post-to-community {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .post-to-community {
    margin: 0;
  }
}

/* Community topics grid */
.topics {
  max-width: none;
  width: 100%;
}

.topics-item .meta-group {
  justify-content: center;
  margin-top: 10px;
}

/* Community topic page */
.topic-header {
  border-bottom: 1px solid #DDDDDD;
  font-size: 13px;
}

@media (min-width: 768px) {
  .topic-header {
    padding-bottom: 10px;
  }
}

.topic-header .dropdown {
  display: block;
  border-top: 1px solid #ddd;
  padding: 10px 0;
}

@media (min-width: 768px) {
  .topic-header .dropdown {
    border-top: 0;
    display: inline-block;
    margin-right: 20px;
    padding: 0;
  }
}

.no-posts-with-filter {
  margin-top: 20px;
  margin-bottom: 20px;
}

/* Topic, post and user follow button */
.community-follow {
  margin-bottom: 10px;
  width: 100%;
}

@media (min-width: 768px) {
  .community-follow {
    margin-bottom: 0;
    width: auto;
  }
}

.community-follow button {
  line-height: 30px;
  padding: 0 10px 0 15px;
  position: relative;
  width: 100%;
}

@media (min-width: 768px) {
  .community-follow button {
    width: auto;
  }
}

.community-follow button:hover {
  background-color: rgba(0, 47, 187, 1);
}

.community-follow button:hover::after, .community-follow button:focus::after {
  border-color: rgba(255, 255, 255, 1);
  color: rgba(255, 255, 255, 1);
}

.community-follow button[data-selected="true"] {
  background-color: rgba(0, 47, 187, 1);
  color: rgba(255, 255, 255, 1);
}

.community-follow button[data-selected="true"]::after {
  border-left: 1px solid rgba(255, 255, 255, 1);
  color: rgba(255, 255, 255, 1);
}

.community-follow button[data-selected="true"]:hover {
  background-color: #001555;
  border-color: #001555;
}

.community-follow button::after {
  border-left: 1px solid rgba(255, 255, 255, 1);
  content: attr(data-follower-count);
  color: rgba(255, 255, 255, 1);
  display: inline-block;
  font-family: 'Open Sans', sans-serif;
  margin-left: 15px;
  padding-left: 10px;
  position: absolute;
  right: 10px;
}

@media (min-width: 768px) {
  .community-follow button::after {
    position: static;
  }
}

[dir="rtl"] .community-follow button::after {
  border-left: 0;
  border-right: 1px solid rgba(0, 47, 187, 1);
  margin: 0 10px 0 0;
  padding: 0 10px 0 0;
}

/***** Striped list *****/
/* Used in community posts list and requests list */
.striped-list {
  padding: 0;
}

.striped-list-item {
  align-items: flex-start;
  border-bottom: 1px solid #DDDDDD;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px 0;
}

@media (min-width: 768px) {
  .striped-list-item {
    align-items: center;
    flex-direction: row;
  }
}

.striped-list-info {
  flex: 2;
}

.striped-list-title {
  color: rgba(0, 47, 187, 1);
  margin-bottom: 10px;
  margin-right: 5px;
}

.striped-list-title:hover, .striped-list-title:focus, .striped-list-title:active {
  text-decoration: underline;
}

.striped-list-title:visited {
  color: #001555;
}

.striped-list .meta-group {
  margin: 5px 0;
}

.striped-list-count {
  color: #666;
  font-weight: 300;
  font-size: 13px;
  justify-content: flex-start;
  text-transform: capitalize;
}

@media (min-width: 768px) {
  .striped-list-count {
    display: flex;
    flex: 1;
    justify-content: space-around;
  }
}

.striped-list-count-item::after {
  content: "·";
  display: inline-block;
  padding: 0 5px;
}

@media (min-width: 768px) {
  .striped-list-count-item::after {
    display: none;
  }
}

.striped-list-count-item:last-child::after {
  display: none;
}

.striped-list-number {
  font-weight: 300;
  text-align: center;
}

@media (min-width: 768px) {
  .striped-list-number {
    color: rgba(51, 51, 51, 1);
    display: block;
    font-weight: 400;
  }
}

/***** Status labels *****/
/* Styles labels used in posts, articles and requests */
.status-label {
  background-color: #038153;
  border-radius: 4px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  margin-right: 2px;
  padding: 3px 10px;
  vertical-align: middle;
  white-space: nowrap;
  display: inline-block;
}

.status-label:hover, .status-label:active, .status-label:focus {
  text-decoration: none;
}

.status-label-pinned, .status-label-featured, .status-label-official {
  background-color: rgba(0, 47, 187, 1);
}

.status-label-official {
  border-radius: 0;
  margin-right: 0;
  position: absolute;
  right: 0;
  text-align: center;
  top: 0;
  width: 100%;
}

@media (min-width: 768px) {
  .status-label-official {
    border-radius: 0 0 4px 4px;
    right: 30px;
    width: auto;
  }
}

[dir="rtl"] .status-label-official {
  left: 30px;
  right: auto;
}

.status-label-not-planned, .status-label-closed {
  background-color: #e9ebed;
  color: #666;
}

.status-label-pending, .status-label-pending-moderation {
  background-color: #1f73b7;
  text-align: center;
}

.status-label-open {
  background-color: #c72a1c;
}

.status-label-solved {
  background-color: #68737d;
}

.status-label-new {
  background-color: #ffb648;
  color: #703b15;
}

.status-label-hold {
  background-color: #000;
}

.status-label-open, .status-label-closed, .status-label-solved, .status-label-new, .status-label-hold, .status-label-pending {
  text-transform: lowercase;
}

/***** Post *****/
/*
* The post grid is defined this way:
* Content | Sidebar
* 70%     | 30%
*/
.post {
  flex: 1;
  margin-bottom: 10px;
}

@media (min-width: 1024px) {
  .post {
    flex: 1 0 70%;
    max-width: 70%;
  }
}

.post-container {
  display: flex;
  flex-direction: column;
}

@media (min-width: 1024px) {
  .post-container {
    flex-direction: row;
  }
}

.post-header {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .post-header {
    align-items: baseline;
    flex-direction: row;
  }
}

.post-header .status-label {
  vertical-align: super;
}

.post-title {
  margin-bottom: 20px;
  width: 100%;
}

@media (min-width: 768px) {
  .post-title {
    margin-bottom: 0;
    padding-right: 10px;
  }
}

.post-title h1 {
  display: inline;
  vertical-align: middle;
  font-weight: 600;
}

@media (min-width: 768px) {
  .post-title h1 {
    margin-right: 5px;
  }
}

.post-author {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
}

.post-avatar {
  margin-bottom: 30px;
}

.post-content {
  font-family: 'Open Sans', sans-serif;
  line-height: 1.6;
  word-break: break-word;
}

.post-info-container {
  display: flex;
  margin-bottom: 40px;
}

.post-info {
  min-width: 0;
  padding-right: 20px;
  width: 100%;
}

[dir="rtl"] .post-info {
  padding-right: 0;
  padding-left: 20px;
}

.post-meta {
  display: inline-block;
  flex: 1;
  margin-left: 10px;
  vertical-align: middle;
}

[dir="rtl"] .post-meta {
  margin-left: 0;
  margin-right: 10px;
}

.post-body img {
  height: auto;
  max-width: 100%;
}

.post-body ul, .post-body ol {
  padding-left: 20px;
  list-style-position: outside;
  margin: 20px 0 20px 20px;
}

[dir="rtl"] .post-body ul, [dir="rtl"] .post-body ol {
  padding-right: 20px;
  padding-left: 0;
  margin-left: 0;
  margin-right: 20px;
}

.post-body ul > ul, .post-body ol > ol, .post-body ol > ul, .post-body ul > ol, .post-body li > ul, .post-body li > ol {
  margin: 0;
}

.post-body ul {
  list-style-type: disc;
}

.post-body a:visited {
  color: #001555;
}

.post-body code {
  background: #f7f7f7;
  border: 1px solid #ddd;
  border-radius: 3px;
  padding: 0 5px;
  margin: 0 2px;
}

.post-body pre {
  background: #f7f7f7;
  border: 1px solid #ddd;
  border-radius: 3px;
  padding: 10px 15px;
  overflow: auto;
  white-space: pre;
}

.post-body blockquote {
  border-left: 1px solid #ddd;
  color: #666;
  font-style: italic;
  padding: 0 15px;
}

.post-footer {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding-bottom: 20px;
}

.post-comment-count {
  color: #666;
  font-weight: 300;
}

.post-comment-count:hover {
  text-decoration: none;
}

.post-comment-count .icon-comments {
  color: rgba(0, 47, 187, 1);
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: 5px;
  vertical-align: middle;
}

.post-sidebar {
  border-top: 1px solid #ddd;
  flex: 1;
  padding: 30px 0;
  text-align: center;
}

@media (min-width: 1024px) {
  .post-sidebar {
    border: 0;
    flex: 1 0 30%;
    padding: 0 0 0 50px;
    text-align: initial;
  }
  [dir="rtl"] .post-sidebar {
    padding: 0 50px 0 0;
  }
}

.post-sidebar-title {
  font-weight: 700;
}

.post-comments,
.mb-20 {
  margin-bottom: 20px;
}

@media (min-width: 1024px) {
  .post-comments {
    margin-bottom: 0;
  }
}

/* Navigation element that collapses on mobile */
.collapsible-nav {
  flex-direction: column;
  font-size: 14px;
  position: relative;
}

@media (min-width: 768px) {
  .collapsible-nav {
    flex-direction: row;
  }
}

.collapsible-nav-border {
  border-bottom: 1px solid #DDDDDD;
  border-top: 1px solid #DDDDDD;
}

@media (min-width: 768px) {
  .collapsible-nav-border {
    border-top: 0;
  }
}

.collapsible-nav-toggle {
  top: calc(45px / 2);
  transform: translateY(-50%);
  position: absolute;
  right: 0;
  padding: 0;
  border: 0;
  background: none;
  width: 25px;
  height: 25px;
  border-radius: 50%;
}

@media (min-width: 768px) {
  .collapsible-nav-toggle {
    display: none;
  }
}

[dir="rtl"] .collapsible-nav-toggle {
  left: 0;
  right: auto;
}

.collapsible-nav-toggle-icon {
  display: none;
}

.collapsible-nav-toggle[aria-expanded="false"] .chevron-icon {
  display: inline-block;
}

.collapsible-nav-toggle[aria-expanded="true"] .x-icon {
  display: inline-block;
}

.collapsible-nav-toggle:focus {
  outline: none;
  border: 1px solid rgba(0, 47, 187, 1);
}

.collapsible-nav-list {
  display: flex;
  flex-direction: column;
}

@media (min-width: 768px) {
  .collapsible-nav-list {
    flex-direction: row;
  }
}

.collapsible-nav-list li {
  color: rgba(51, 51, 51, 1);
  line-height: 45px;
  order: 1;
}

@media (min-width: 768px) {
  .collapsible-nav-list li {
    line-height: normal;
    margin-right: 30px;
  }
  [dir="rtl"] .collapsible-nav-list li {
    margin-left: 30px;
    margin-right: 0;
  }
  .collapsible-nav-list li a {
    text-decoration: none;
    padding: 15px 0;
  }
}

.collapsible-nav-list li a {
  color: rgba(51, 51, 51, 1);
  display: block;
}

@media (min-width: 768px) {
  .collapsible-nav-list li:hover {
    border-bottom: 4px solid #ddd;
  }
  .collapsible-nav-list li:hover a:not([aria-current="page"]) {
    padding: 15px 0 11px 0;
    text-decoration: none;
  }
}

.collapsible-nav-list li:not([aria-selected="true"]),
.collapsible-nav-list li:not(.current) {
  display: none;
}

@media (min-width: 768px) {
  .collapsible-nav-list li:not([aria-selected="true"]),
  .collapsible-nav-list li:not(.current) {
    display: block;
  }
}

@media (min-width: 768px) {
  .collapsible-nav-list li[aria-selected="true"] {
    padding: 15px 0 11px 0;
  }
}

.collapsible-nav-list li[aria-selected="true"],
.collapsible-nav-list li.current {
  order: 0;
  position: relative;
}

@media (min-width: 768px) {
  .collapsible-nav-list li[aria-selected="true"],
  .collapsible-nav-list li.current {
    border-bottom: 4px solid rgba(0, 47, 187, 1);
    order: 1;
  }
}

.collapsible-nav-list li[aria-selected="true"] a,
.collapsible-nav-list li.current a {
  color: rgba(51, 51, 51, 1);
}

.collapsible-nav[aria-expanded="true"] li:not([aria-selected="true"]),
.collapsible-nav[aria-expanded="true"] li:not(.current) {
  display: block;
}

/* Sidebar navigation that collapses on mobile */
.collapsible-sidebar {
  flex: 1;
  max-height: 45px;
  overflow: hidden;
  padding: 10px 0;
  position: relative;
}

@media (min-width: 1024px) {
  .collapsible-sidebar {
    max-height: none;
    padding: 0;
  }

  .article-container .collapsible-sidebar {
    background: #EEF3F6;
    padding: 30px;
    margin-bottom: 20px;
    margin-top: 15px;
    border-radius: 3px;
  }
}

.collapsible-sidebar-title {
  margin-top: 0;
}

.collapsible-sidebar-toggle {
  position: absolute;
  top: calc(45px / 2);
  transform: translateY(-50%);
  right: 0;
  padding: 0;
  border: 0;
  background: none;
  width: 25px;
  height: 25px;
  border-radius: 50%;
}

@media (min-width: 1024px) {
  .collapsible-sidebar-toggle {
    display: none;
  }
}

[dir="rtl"] .collapsible-sidebar-toggle {
  left: 0;
  right: auto;
}

.collapsible-sidebar-toggle-icon {
  display: none;
}

.collapsible-sidebar-toggle[aria-expanded="false"] .chevron-icon {
  display: inline-block;
}

.collapsible-sidebar-toggle[aria-expanded="true"] .x-icon {
  display: inline-block;
}

.collapsible-sidebar-toggle:focus {
  outline: none;
  border: 1px solid rgba(0, 47, 187, 1);
}

.collapsible-sidebar-body {
  display: none;
}

@media (min-width: 1024px) {
  .collapsible-sidebar-body {
    display: block;
  }
}

.collapsible-sidebar[aria-expanded="true"] {
  max-height: none;
}

.collapsible-sidebar[aria-expanded="true"] .collapsible-sidebar-body {
  display: block;
}

/***** My activities *****/
.my-activities-nav {
  background-color: #EEF3F6;
  margin-bottom: 20px;
}

.my-activities-sub-nav {
  margin-bottom: 30px;
}

.my-activities-table .striped-list-title {
  /* My activities tables */
  display: block;
  margin-bottom: 10px;
  max-width: 350px;
  white-space: normal;
}

@media (min-width: 1024px) {
  .my-activities-table .striped-list-title {
    margin-bottom: 0;
    max-width: 500px;
    min-width: 350px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}

.my-activities-table thead {
  display: none;
}

@media (min-width: 768px) {
  .my-activities-table thead {
    display: table-header-group;
  }
}

.my-activities-table th:first-child,
.my-activities-table td:first-child {
  padding-left: 0;
}

@media (min-width: 1024px) {
  .my-activities-table th:first-child,
  .my-activities-table td:first-child {
    width: 500px;
  }
}

.my-activities-table th:last-child,
.my-activities-table td:last-child {
  padding-right: 0;
}

.my-activities-table td:not(:first-child) {
  display: none;
}

@media (min-width: 768px) {
  .my-activities-table td:not(:first-child) {
    display: table-cell;
  }
}

/* Requests table */
.requests-search {
  width: 100%;
}

.requests-table-toolbar {
  align-items: flex-end;
  display: flex;
  flex-direction: column;
}

@media (min-width: 768px) {
  .requests-table-toolbar {
    flex-direction: row;
  }
}

.requests-table-toolbar .search {
  flex: 1;
  width: 100%;
}

.requests-table-toolbar .request-table-filter {
  width: 100%;
}

@media (min-width: 768px) {
  .requests-table-toolbar .request-table-filter {
    width: auto;
  }
}

.requests-table-toolbar .request-filter {
  display: block;
}

@media (min-width: 768px) {
  .requests-table-toolbar .request-filter {
    margin: 0 0 0 30px;
  }
  [dir="rtl"] .requests-table-toolbar .request-filter {
    margin: 0 30px 0 0;
  }
}

.requests-table-toolbar .request-filter-label {
  font-size: 13px;
  margin-top: 30px;
}

@media (min-width: 768px) {
  .requests-table-toolbar .request-filter-label {
    margin-top: 0;
  }
}

.requests-table-toolbar select {
  max-height: 40px;
  margin-bottom: 30px;
  width: 100%;
}

@media (min-width: 768px) {
  .requests-table-toolbar select {
    margin-bottom: 0;
    max-width: 300px;
    width: auto;
  }
}

@media (min-width: 768px) {
  .requests-table-toolbar .organization-subscribe {
    margin-left: 10px;
  }
  [dir="rtl"] .requests-table-toolbar .organization-subscribe {
    margin: 0 10px 0 0;
  }
}

.requests-table-toolbar .organization-subscribe button {
  line-height: 40px;
  max-height: 40px;
  padding: 0 20px;
}

.requests-table-toolbar + .requests-search-info {
  margin-top: 15px;
}

.requests-table-toolbar + .requests-search-info.meta-data::after {
  content: "";
  margin: 0;
}

.requests-table-toolbar + .requests-search-info + .requests {
  margin-top: 20px;
}

.requests-table-toolbar + .requests {
  margin-top: 40px;
}

.requests .requests-table-meta {
  display: block;
}

@media (min-width: 768px) {
  .requests .requests-table-meta {
    display: none;
  }
}

.requests .requests-table thead {
  display: none;
}

@media (min-width: 768px) {
  .requests .requests-table thead {
    display: table-header-group;
  }
}

.requests .requests-table-info {
  display: block;
}

@media (min-width: 768px) {
  .requests .requests-table-info {
    display: table-cell;
    vertical-align: middle;
    width: auto;
  }
}

.requests .requests-table .requests-link {
  position: relative;
}

.requests .requests-table .requests-sort-symbol {
  position: absolute;
  left: calc(100% + 3px);
  bottom: 0;
  font-size: 10px;
}

/* Following table */
@media (min-width: 768px) {
  .subscriptions-subscribe button {
    width: auto;
  }
}

.subscriptions-table td:last-child {
  display: block;
}

@media (min-width: 768px) {
  .subscriptions-table td:last-child {
    display: table-cell;
  }
}

.subscriptions-table td:first-child {
  display: flex;
  align-items: center;
}

.subscriptions-table .user-avatar {
  margin-right: 10px;
}

.subscriptions .striped-list-title {
  display: inline-block;
  vertical-align: middle;
}

/* Contributions table */
.contributions-table td:last-child {
  color: #666;
  font-size: 13px;
  font-weight: 300;
}

@media (min-width: 768px) {
  .contributions-table td:last-child {
    color: inherit;
    font-size: inherit;
    font-weight: inherit;
  }
}

.no-activities {
  color: #666;
}

/***** Request *****/
.request-container {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}

@media (min-width: 1024px) {
  .request-container {
    align-items: flex-start;
    flex-direction: row;
  }
}

.request-container .comment-container {
  min-width: 0;
}

.request-breadcrumbs {
  margin-bottom: 30px;
}

@media (min-width: 1024px) {
  .request-breadcrumbs {
    margin-bottom: 20px;
  }
}

.request-main {
  flex: 1 0 auto;
  order: 1;
}

.request-main .comment-fields, .request-main .request-submit-comment {
  display: none;
}

.request-main .comment-fields.shown {
  display: block;
}

.request-main .request-submit-comment.shown {
  display: inline;
}

@media (min-width: 1024px) {
  .request-main {
    flex: 0 0 66%;
    order: 0;
    min-width: 0;
  }
}

.request-main .comment-form-controls {
  display: block;
}

.request-main .comment-ccs {
  display: block;
}

.request-main .comment-show-container {
  background: #EEF3F6;
  border-radius: 3px;
  border: 1px solid #DDDDDD;
  color: #666;
  text-align: inherit;
  padding: 8px 25px;
  width: 100%;
}

.request-main .comment-show-container.hidden {
  display: none;
}

.request-main .form-field.comment-ccs > ul {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: 0;
}

.request-main .form-field.comment-ccs > ul[data-hc-focus="true"] {
  border: 1px solid rgba(0, 47, 187, 1);
}

.request-main .form-field.comment-ccs > input[type="text"] {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: 0;
}

.request-main .comment-ccs + textarea {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  margin-top: 0;
}

.request-main .comment-ccs + textarea:focus {
  border-top: 1px solid rgba(0, 47, 187, 1);
}

.request-main input#mark_as_solved {
  display: none;
}

.request-title {
  width: 100%;
  font-weight: 600;
}

@media (min-width: 1024px) {
  .request-title {
    border-bottom: 1px solid #DDDDDD;
    margin-bottom: 0;
    max-width: 66%;
    padding-bottom: 20px;
  }
}

.request-sidebar {
  border-bottom: 1px solid #ddd;
  border-top: 1px solid #ddd;
  flex: 1 0 auto;
  order: 0;
}

@media (min-width: 1024px) {
  .request-sidebar {
    background-color: #EEF3F6;
    border: 0;
    border-radius: 3px;
    font-size: 13px;
    flex: 0 0 auto;
    padding: 0 20px;
    width: 30%;
  }
}

.request-sidebar h2 {
  font-size: 15px;
  font-weight: 600;
  position: relative;
}

@media (min-width: 1024px) {
  .request-sidebar h2 {
    display: none;
  }
}

.request-details {
  border-bottom: 1px solid #DDDDDD;
  font-size: 0;
  margin: 0;
  padding-bottom: 20px;
}

.request-details:last-child {
  border: 0;
}

.request-details dt, .request-details dd {
  display: inline-block;
  vertical-align: top;
  font-size: 13px;
  margin: 20px 0 0 0;
}

.request-details dd {
  padding: 0 10px;
  width: 60%;
}

.request-details dd::after {
  content: "\A";
  white-space: pre;
}

.request-details dt {
  color: #666;
  font-weight: 600;
  width: 40%;
}

.request-details .request-collaborators {
  display: inline-block;
}

.request-attachments dt, .request-attachments dd {
  width: 100%;
}

.request-attachments dd {
  margin: 10px 0 0 0;
}

.request-form textarea {
  min-height: 120px;
}

.request-follow-up {
  padding-top: 20px;
}

/***** Pagination *****/
.pagination {
  margin: 20px 0;
  text-align: center;
}

.pagination-next, .pagination-prev, .pagination-first, .pagination-last {
  display: inline-block;
}

.pagination-first-link, .pagination-last-link {
  padding: 0 10px;
}

.pagination-next-link {
  padding-right: 10px;
}

.pagination-next-text {
  margin-right: 10px;
}

[dir="rtl"] .pagination-next-link {
  padding-left: 10px;
}

[dir="rtl"] .pagination-next-text {
  margin-left: 10px;
}

.pagination-prev-link {
  padding-left: 10px;
}

.pagination-prev-text {
  margin-left: 10px;
}

[dir="rtl"] .pagination-prev-link {
  padding-right: 10px;
}

[dir="rtl"] .pagination-prev-text {
  margin-right: 10px;
}

/***** Metadata *****/
.meta-group {
  display: block;
}

.meta-group * {
  display: inline;
}

.meta-data {
  color: #666;
  font-size: 13px;
}

.meta-data:not(:last-child)::after {
  content: "\00B7";
  margin: 0 5px;
}

/* User Profiles */
.profile-header {
  padding: 30px 0;
}

.profile-header .container {
  display: flex;
  flex-wrap: wrap;
}

@media (min-width: 768px) {
  .profile-header .container {
    flex-wrap: nowrap;
  }
}

.profile-header .profile-info {
  flex-basis: 100%;
  display: flex;
  flex-wrap: wrap;
  min-width: 0;
}

.profile-avatar {
  position: relative;
  line-height: 0;
  align-self: center;
  margin-right: 10px;
}

[dir="rtl"] .profile-avatar {
  margin-left: 10px;
  margin-right: 0;
}

.profile-avatar .user-avatar {
  width: 65px;
  height: 65px;
}

.profile-avatar .icon-agent {
  bottom: 0;
  right: 0;
}

.profile-header .basic-info {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex-grow: 1;
  flex-basis: 0;
  min-width: 0;
}

.profile-header .basic-info .name {
  margin: 0;
  font-weight: 700;
  line-height: 25px;
  margin-right: 5px;
}

.profile-header .basic-info .name a {
  color: #333;
}

.profile-header .options {
  display: flex;
  flex-basis: 100%;
  margin-top: 12px;
  align-items: flex-start;
  flex-wrap: wrap;
}

@media (min-width: 768px) {
  .profile-header .options {
    flex-wrap: nowrap;
    flex-basis: auto;
    margin-top: 0;
    margin-left: 10px;
  }
  [dir="rtl"] .profile-header .options {
    margin-left: 0;
    margin-right: 10px;
  }
  .profile-header .options > :not(:last-child) {
    margin-bottom: 0;
    margin-right: 10px;
  }
  [dir="rtl"] .profile-header .options > :not(:last-child) {
    margin-left: 10px;
    margin-right: 0;
  }
}

.user-profile-actions {
  width: 100%;
  margin-bottom: 15px;
}

.edit-profile-button a {
  background-color: rgba(0, 47, 187, 1);
  border: 0;
  color: rgba(255, 255, 255, 1);
  line-height: normal;
  padding: 8px 20px;
  outline-color: rgba(0, 47, 187, 1);
}

.profile-header .description {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  margin: 15px 0;
  flex-basis: 100%;
}

.profile-stats {
  font-size: 13px;
  display: flex;
  flex-direction: column;
  flex-basis: 100%;
}

.profile-stats .stat {
  display: flex;
  margin-bottom: 10px;
}

.profile-stats .stat-label {
  color: #666;
  font-weight: 300;
  flex: 0 0 100px;
  margin-right: 10px;
}

[dir="rtl"] .profile-stats .stat-label {
  margin-left: 10px;
  margin-right: 0;
}

.profile-stats-activity {
  border-top: solid 1px #ddd;
  margin-top: 15px;
}

@media (min-width: 768px) {
  .profile-stats-activity {
    border-top: 0;
    flex-direction: row;
  }
}

@media (min-width: 768px) {
  .profile-stats-activity .stat {
    flex-direction: column;
  }
}

.profile-stats-activity .stat:first-child {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .profile-stats-activity .stat:first-child {
    margin-top: 0;
  }
}

@media (min-width: 768px) {
  .profile-stats-activity .stat:not(:last-child) {
    margin-right: 40px;
  }
  [dir="rtl"] .profile-stats-activity .stat:not(:last-child) {
    margin-left: 40px;
    margin-right: 0;
  }
}

@media (min-width: 768px) {
  .profile-stats-activity .stat-label {
    flex: 0 1 auto;
  }
}

.profile-stats-counters {
  border-bottom: solid 1px #ddd;
}

@media (min-width: 768px) {
  .profile-stats-counters {
    flex: 0 0 200px;
    border-bottom: 0;
    margin-left: 40px;
  }
  [dir="rtl"] .profile-stats-counters {
    margin-left: 0;
    margin-right: 40px;
  }
}

@media (min-width: 1024px) {
  .profile-stats-counters {
    flex: 0 0 270px;
    margin-left: 60px;
  }
  [dir="rtl"] .profile-stats-counters {
    margin-right: 60px;
    margin-left: 0;
  }
}

@media (min-width: 768px) {
  .profile-stats-counters .stat {
    flex-direction: column;
  }
}

@media (min-width: 1024px) {
  .profile-stats-counters .stat {
    flex-direction: row;
  }
}

@media (min-width: 768px) {
  .profile-stats-counters .stat:not(:last-child) {
    margin-bottom: 15px;
  }
}

@media (min-width: 768px) {
  .profile-stats-counters .stat-label {
    flex: 0 1 auto;
  }
}

@media (min-width: 1024px) {
  .profile-stats-counters .stat-label {
    flex: 0 0 100px;
  }
}

.profile-private-badge {
  flex-basis: 100%;
  border: solid 1px rgba(0, 47, 187, 1);
  border-radius: 4px;
  color: rgba(0, 47, 187, 1);
  padding: 5px 20px;
  font-size: 12px;
  text-align: center;
}

.profile-private-badge .profile-private-icon {
  margin-left: 5px;
  line-height: 15px;
}

@media (min-width: 768px) {
  .profile-private-badge {
    flex-basis: auto;
  }
}

.profile-nav {
  background-color: #EEF3F6;
  margin-bottom: 37px;
}

.profile-section {
  width: 100%;
}

@media (min-width: 1024px) {
  .profile-section {
    width: calc(100% - 330px);
  }
}

.profile-section-header {
  display: flex;
  flex-wrap: wrap;
}

.profile-section-title {
  flex-basis: 100%;
  margin-bottom: 0;
}

.profile-section-description {
  flex-basis: 100%;
  padding: 10px 0;
  color: #666;
  font-weight: 300;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (min-width: 768px) {
  .profile-section-description {
    flex: 1 0 50%;
    padding-bottom: 0;
  }
}

.profile-section-sorter {
  flex-basis: 100%;
  border-top: solid 1px #eee;
  font-size: 13px;
}

.profile-section-sorter .dropdown-toggle {
  padding: 10px 0;
  width: 100%;
}

.profile-section-sorter .dropdown-toggle::after {
  position: absolute;
  right: 0;
}

[dir="rtl"] .profile-section-sorter .dropdown-toggle::after {
  left: 0;
  right: initial;
}

@media (min-width: 768px) {
  .profile-section-sorter .dropdown-toggle::after {
    position: relative;
  }
}

@media (min-width: 768px) {
  .profile-section-sorter {
    flex: 0 1 auto;
    padding-top: 0;
    border-top: 0;
    margin-left: 20px;
  }
  [dir="rtl"] .profile-section-sorter {
    margin-left: 0;
    margin-right: 20px;
  }
}

.profile-contribution {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  padding: 20px 0;
  position: relative;
}

.profile-contribution-header {
  margin-bottom: 5px;
}

.profile-contribution-title {
  margin: 0 0 5px 0;
  display: inline;
  line-height: 21px;
  font-size: 16px;
  vertical-align: middle;
  font-weight: 700;
}

.profile-contribution-title > a {
   color: #333;
}

.profile-contribution-body {
  margin: 10px 0;
}

#service-catalog-item .service-catalog-description ul {
  padding-left: 30px;
}

.profile-contribution-list > .profile-contribution {
  border-top: 1px solid #ddd;
}

@media (min-width: 768px) {
  .profile-contribution-list > .profile-contribution {
    padding-left: 30px;
  }
  [dir="rtl"] .profile-contribution-list > .profile-contribution {
    padding-right: 30px;
    padding-left: 0;
  }
}

.profile-contribution-list > .profile-contribution:last-child {
  border-bottom: 1px solid #ddd;
}

.profile-contribution-icon {
  left: 0;
  position: absolute;
  color: #ccc;
  line-height: 25px;
}

[dir="rtl"] .profile-contribution-icon {
  right: 0;
}

.profile-contribution-icon svg {
  vertical-align: middle;
}

.profile-contribution-list .profile-contribution-header {
  margin-left: 30px;
}

[dir="rtl"] .profile-contribution-list .profile-contribution-header {
  padding-right: 30px;
  padding-left: 0;
}

@media (min-width: 768px) {
  .profile-contribution-list .profile-contribution-header {
    margin-left: 0;
  }
  [dir="rtl"] .profile-contribution-list .profile-contribution-header {
    padding-right: 0;
  }
}

.profile-comments .profile-contribution-breadcrumbs {
  margin-left: 30px;
}

[dir="rtl"] .profile-comments .profile-contribution-breadcrumbs {
  padding-right: 30px;
  padding-left: 0;
}

@media (min-width: 768px) {
  .profile-comments .profile-contribution-breadcrumbs {
    margin-left: 0;
  }
  [dir="rtl"] .profile-comments .profile-contribution-breadcrumbs {
    padding-right: 0;
  }
}

.profile-section .no-activity,
.profile-section .private-activity {
  display: block;
  margin-top: 40px;
  color: #999;
}

.private-activity-icon {
  margin-right: 10px;
}

[dir="rtl"] .private-activity-icon {
  margin-right: 0;
  margin-left: 10px;
}

.profile-activity-list {
  margin-top: 25px;
}

.profile-activity {
  position: relative;
  padding-bottom: 30px;
}

@media (min-width: 768px) {
  .profile-activity {
    padding-left: 20px;
  }
  [dir="rtl"] .profile-activity {
    padding-right: 20px;
    padding-left: 0;
  }
}

@media (min-width: 768px) {
  .profile-activity:not(:last-child) {
    border-left: 1px solid #ddd;
  }
  [dir="rtl"] .profile-activity:not(:last-child) {
    border-left: 0;
    border-right: 1px solid #ddd;
  }
}

.profile-activity-header {
  display: flex;
  align-items: center;
  margin-left: 35px;
}

[dir="rtl"] .profile-activity-header {
  margin-left: 0;
  margin-right: 35px;
}

@media (min-width: 768px) {
  .profile-activity-header {
    margin-left: 0;
  }
  [dir="rtl"] .profile-activity-header {
    margin-right: 0;
  }
}

.profile-activity-header .user-avatar {
  width: 40px;
  height: 40px;
  margin-right: 10px;
  min-width: 40px;
  align-self: flex-start;
}

[dir="rtl"] .profile-activity-header .user-avatar {
  margin-left: 10px;
  margin-right: 0;
}

.profile-activity-description {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  margin: 0;
  min-width: 0;
  width: 100%;
}

.profile-activity-description span:first-child {
  font-weight: 600;
  display: inline;
}

.profile-activity-contribution {
  padding: 20px;
  margin-top: 10px;
  border-radius: 8px;
  background-color: #EEF3F6;
}

@media (min-width: 768px) {
  .profile-activity-contribution {
    margin-top: 0;
    margin-left: 50px;
  }
  [dir="rtl"] .profile-activity-contribution {
    margin-left: 0;
    margin-right: 50px;
  }
}

.profile-activity-icon {
  position: absolute;
  left: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-size: 14px 14px;
  background-repeat: no-repeat;
  background-color: #ffffff;
  background-position: 50% 50%;
  text-align: center;
  color: #ccc;
}

[dir="rtl"] .profile-activity-icon {
  right: 0;
}

@media (min-width: 768px) {
  .profile-activity-icon {
    left: -14px;
  }
  [dir="rtl"] .profile-activity-icon {
    right: -14px;
  }
}

.profile-activity-icon svg {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  width: 1em;
  height: 1em;
  margin: auto;
}

/***** Search results *****/
.search-results {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}

@media (min-width: 1024px) {
  .search-results {
    flex-direction: row;
  }
}

.search-results-column {
  flex: 1;
}

@media (min-width: 1024px) {
  .search-results-column {
    flex: 0 0 77%;
  }
}

.search-results-sidebar {
  border-top: 1px solid #ddd;
  flex: 1 0 auto;
  margin-bottom: 20px;
  padding: 0;
}

@media (min-width: 1024px) {
  .search-results-sidebar {
    border: 0;
    flex: 0 0 20%;
    height: auto;
  }
}

.search-results-sidebar .sidenav-item {
   padding: 10px;
   border-radius: 3px;
   margin-bottom: 5px;
   background: #EEF3F6;
}

.search-results-sidebar .sidenav-item:hover, .search-results-sidebar .sidenav-item.current {
  background-color: rgba(0, 47, 187, 1);
  color: #fff;
  text-decoration: none;
}

.search-results-sidebar .sidenav-subitem {
  unicode-bidi: embed;
}

.search-results-sidebar .collapsible-sidebar {
  margin-bottom: 30px;
}

.search-results-sidebar .collapsible-sidebar[aria-expanded="false"] .multibrand-filter-list {
  display: none;
}

@media (min-width: 1024px) {
  .search-results-sidebar .collapsible-sidebar[aria-expanded="false"] .multibrand-filter-list {
    display: block;
  }
}

.search-results-sidebar .multibrand-filter-list--collapsed li:nth-child(1n + 16) {
  display: none;
}

/*
.search-results-sidebar .multibrand-filter-list .doc-count {
  color: #666;
}
*/

.search-results-sidebar .see-all-filters {
  background: none;
  border: none;
  cursor: pointer;
  display: block;
  padding: 10px;
  color: #333;
  font-weight: 600;
}

.search-results-sidebar .see-all-filters[aria-hidden="true"] {
  display: none;
}

.search-results-sidebar .see-all-filters:hover {
  text-decoration: underline;
}

.search-results-sidebar .see-all-filters::after {
  content: ' \2304';
  font-weight: bold;
  position: relative;
  top: -4px;
}

.search-results-subheading {
  font-size: 18px;
  font-weight: 600;
}

.search-results-list {
  margin-bottom: 25px;
}

.search-results-list > li {
  border-bottom: 1px solid #DDDDDD;
  padding: 20px 0;
}

.search-results-list > li:first-child {
  border-top: 1px solid #DDDDDD;
}

.search-result-title-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.search-result-meta-container {
    color: #666;
    display: flex;
    flex-direction: column;
}

@media (min-width: 1024px) {
  .search-result-meta-container {
      flex-direction: row;
      align-items: center;
  }
  .search-result-meta-container nav {
    flex: 1;
  }
}

.search-results-list > li h2 {
  margin-bottom: 5px;
  font-weight: 700;
  font-size: 1.2em;
}

.search-results-list > li h2 a {
  color: #333;
}

.search-results .meta-group {
  display: block;
  align-items: center;
  clear: both;
  color: #666;
}

@media (min-width: 1024px) {
  .search-results .meta-group {
    display: flex;
  }
}

.search-results .meta-group > li {
  display: block;
}

@media (min-width: 1024px) {
  .search-results .meta-group > li {
    display: inline;
  }
}

@media (min-width: 1024px) {
  .search-results .meta-group li:first-child {
    flex: 1;
  }
}

.search-results .meta-group .meta-data {
  color: inherit;
}

[dir="ltr"] .search-results .meta-group .meta-data:not(:last-child) {
  margin-right: 20px;
}

[dir="rtl"] .search-results .meta-group .meta-data:not(:last-child) {
  margin-left: 20px;
}

.search-results .meta-group .meta-data::after {
  content: none;
}

.search-results-description {
  margin-top: 10px;
  word-break: break-word;
}

.search-result-title {
  font-size: 16px;
  display: inline-block;
}

[dir="ltr"] .search-result-icons {
  float: right;
}

[dir="rtl"] .search-result-icons {
  float: left;
}

.search-result-votes, .search-result-meta-count {
  color: #666;
  display: inline-block;
  font-size: 13px;
  font-weight: 300;
  padding: 4px 5px;
  position: relative;
}

.search-result-votes-icon, .search-result-meta-count-icon {
  color: rgba(0, 47, 187, 1);
  vertical-align: middle;
  width: 13px;
  height: 13px;
}

[dir="ltr"] .search-result-votes, [dir="ltr"] .search-result-meta-count {
  margin-left: 5px;
}

[dir="ltr"] .search-result-votes::before, [dir="ltr"] .search-result-meta-count::before {
  margin-right: 3px;
}

[dir="rtl"] .search-result-votes, [dir="rtl"] .search-result-meta-count {
  margin-right: 5px;
}

[dir="rtl"] .search-result-votes::before, [dir="rtl"] .search-result-meta-count::before {
  margin-left: 3px;
}

.search-result .meta-group {
  align-items: center;
}

.search-result-breadcrumbs {
  margin: 0;
}

@media (min-width: 1024px) {
  .search-result-breadcrumbs {
    display: table-row;
  }
}

@media (min-width: 1024px) {
  .search-result-breadcrumbs li {
    display: table-cell;
  }
}

.search-result-breadcrumbs li, .search-result-breadcrumbs li a, .search-result-breadcrumbs li a:visited {
  color: inherit;
}

/* By default use bold instead of italic to highlight */
.search-results-description em {
  background: #fff3ca;
  font-style: normal;
  font-weight: 600;
}

/* Background for Chinese */
html[lang|="zh"] .search-results-description em {
  font-style: normal;
  background: #fff3ca;
}

/***** Notifications *****/
.notification {
  border: 1px solid;
  display: table;
  font-family: sans-serif;
  font-size: 12px;
  padding: 13px 15px;
  transition: height .2s;
  width: 100%;
  color: #555;
}

.notification a {
  color: #158ec2;
}

.notification-inner {
  margin: 0 auto;
  padding: 0 20px;
  max-width: 980px;
}

.notification-icon, .notification-text, .notification-dismiss {
  display: table-cell;
  vertical-align: middle;
}

.notification-text {
  padding: 0 15px;
  width: 100%;
}

.notification + .notification {
  margin-bottom: -1px;
  position: relative;
  top: -1px;
}

/* Error */
.notification-error {
  background: #ffeded;
  border-color: #f7cbcb;
}

.notification-error .notification-icon::before, .notification-error .notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cg fill='none' stroke='%23555555'%3E%3Ccircle cx='5.5' cy='6.5' r='5'/%3E%3Cpath stroke-linecap='round' d='M5.5 3.5v3'/%3E%3C/g%3E%3Ccircle cx='5.5' cy='9' r='1' fill='%23555555'/%3E%3C/svg%3E");
}

/* Notice */
.notification-notice {
  background: #dbf3ff;
  border-color: #b5e0f5;
}

.notification-notice .notification-icon::before, .notification-notice .notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cg fill='none' stroke='%23555555'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M3.5 6l2 2L9 4.5'/%3E%3Ccircle cx='6' cy='6' r='5.5'/%3E%3C/g%3E%3C/svg%3E");
}

/* Alert / Lock */
.notification-alert {
  color: #ad5e18;
  background: #fff8ed;
  border-color: #fcdba9;
}

.notification-alert .notification-icon::before, .notification-alert .notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%23ad5e18' stroke-linecap='round' d='M5.06 1.27l-4.5 8.5c-.18.33.06.73.44.73h9c.38 0 .62-.4.44-.73l-4.5-8.5a.494.494 0 00-.88 0zM5.5 4v2'/%3E%3Ccircle cx='5.5' cy='8' r='.8' fill='%23ad5e18'/%3E%3C/svg%3E");
}

.notification-icon::before, .notification-inline.notification-error::before {
  background-size: cover;
  content: "";
  display: inline-block;
  height: 14px;
  width: 14px;
  vertical-align: middle;
}

/* Dismiss button */
.notification-dismiss, a.notification-dismiss {
  color: #555;
  cursor: pointer;
  opacity: .6;
  transition: opacity 100ms ease;
  text-decoration: none !important;
}

.notification-dismiss:hover {
  opacity: 1;
}

/* Inline notifications */
.notification-inline {
  border-radius: 4px;
  line-height: 14px;
  margin-top: 5px;
  padding: 5px;
  position: relative;
  text-align: left;
  vertical-align: middle;
}

[dir="rtl"] .notification-inline {
  text-align: right;
}

.notification-inline[aria-hidden="true"] {
  display: none;
}

.notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cg fill='none' stroke='%23e35b66'%3E%3Ccircle cx='5.5' cy='6.5' r='5'/%3E%3Cpath stroke-linecap='round' d='M5.5 3.5v3'/%3E%3C/g%3E%3Ccircle cx='5.5' cy='9' r='1' fill='%23e35b66'/%3E%3C/svg%3E");
  margin: -2px 5px 0 0;
}

[dir="rtl"] .notification-inline.notification-error::before {
  margin: 0 0 0 5px;
}

.notification-inline.notification-error {
  background-color: #fff0f1;
  border: 1px solid #e35b66;
  color: #cc3340;
}

.notification-inline.notification-large {
  padding: 13px 15px;
  margin-bottom: 25px;
}

.notification-left-aligned {
  text-align: left;
  padding-left: 0;
}

html[dir="rtl"] .notification-left-aligned {
  text-align: right;
  padding-left: auto;
  padding-right: 0;
}

.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-toggle {
  cursor: pointer;
  background: none;
  border: 0;
  display: inline-block;
  padding: 0;
  text-align: initial;
  vertical-align: middle;
}

.dropdown-toggle:hover,
.dropdown-toggle:focus {
  outline: none;
  text-decoration: none;
}

.dropdown-toggle > * {
  display: inline-block;
}

.dropdown-menu {
  background: #fff;
  border: 1px solid #d8d8d8;
  border-radius: 3px;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1);
  display: none;
  font-size: 14px;
  font-style: normal;
  font-weight: normal;
  left: 0;
  margin-top: 5px;
  min-width: 170px;
  padding: 10px 0;
  position: absolute;
  text-align: left;
  z-index: 1000;
}

[dir="rtl"] .dropdown-menu {
  text-align: right;
}

.dropdown-menu[aria-expanded="true"],
.dropdown-toggle[aria-expanded=true] + .dropdown-menu {
  display: block;
}

.hc_header .dropdown-menu[aria-expanded="true"] {
  left: inherit;
  right: 0;
}

.dropdown-menu [role="separator"] {
  border-bottom: 1px solid #DDDDDD;
  color: rgba(51, 51, 51, 1);
  display: block;
  font-weight: normal;
  font-size: 11px;
  padding: 5px 0;
  margin: 5px 20px 10px 20px;
}

.dropdown-menu [role="menuitem"],
.dropdown-menu [role=menuitem],
.dropdown-menu [role=menuitemradio] {
  color: #333;
  cursor: pointer;
  display: block;
  padding: 7px 40px 7px 20px;
  white-space: nowrap;
  background-color: transparent;
  border: 0;
  -webkit-appearance: none;
  text-align: start;
  line-height: inherit;
  width: 100%;
}

[dir="rtl"] .dropdown-menu [role="menuitem"],
.dropdown-menu [role=menuitem],
.dropdown-menu [role=menuitemradio] {
  padding: 7px 20px 7px 20px;
}

.dropdown-menu [role="menuitem"]:hover, .dropdown-menu [role="menuitem"]:focus {
  background: #f3f3f3;
  text-decoration: none;
  color: #333;
}

.dropdown-menu [role="menuitem"][aria-selected="true"],
.dropdown-menu [role=menuitem][aria-selected=true], .dropdown-menu [role=menuitem][aria-checked=true],
.dropdown-menu [role=menuitemradio][aria-selected=true],
.dropdown-menu [role=menuitemradio][aria-checked=true] {
  cursor: default;
}

.dropdown-menu [role="menuitem"][aria-selected="true"]::after,
.dropdown-menu [role=menuitem][aria-selected=true]::after, .dropdown-menu [role=menuitem][aria-checked=true]::after,
.dropdown-menu [role=menuitemradio][aria-selected=true]::after,
.dropdown-menu [role=menuitemradio][aria-checked=true]::after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M1 7l3 3 7-7'%3E%3C/path%3E%3C/svg%3E");
  display: inline-block;
  height: 12px;
  margin-left: 10px;
  width: 12px;
}

[dir="rtl"] .dropdown-menu [role="menuitem"][aria-selected="true"]::after,
[dir=rtl] .dropdown-menu [role=menuitem][aria-selected=true]::after, [dir=rtl] .dropdown-menu [role=menuitem][aria-checked=true]::after,
[dir=rtl] .dropdown-menu [role=menuitemradio][aria-selected=true]::after,
[dir=rtl] .dropdown-menu [role=menuitemradio][aria-checked=true]::after {
  margin-left: 0;
  margin-right: 10px;
  float: left;
}

.dropdown-menu [role="menuitem"][hidden], .dropdown-menu [role="menuitem"][aria-hidden="true"],
.dropdown-menu [role=menuitem][hidden], .dropdown-menu [role=menuitem][aria-hidden=true],
.dropdown-menu [role=menuitemradio][hidden],
.dropdown-menu [role=menuitemradio][aria-hidden=true] {
  display: none !important;
}

.dropdown-menu-end {
  left: auto;
  right: 0;
}

.dropdown-menu-top {
  bottom: 100%;
  border-radius: 8px;
  margin-bottom: 6px;
}

[dir="rtl"] .dropdown-menu {
  left: auto;
  right: 0;
  text-align: right;
}

[dir="rtl"] .dropdown-menu-end {
  left: 0;
  right: auto;
}

.dropdown-chevron-icon {
  vertical-align: middle;
}

@media (max-width: 1024px) {
  .article-container .article-relatives,
  .article-sidebar .sidenav-title:after {
    display: none;
  }
  .collapsible-sidebar-title {
    cursor: pointer;
  }
  .search-results-sidebar .collapsible-sidebar {
    margin-bottom: 0;
  }
  .search-results-sidebar .collapsible-sidebar-title {
    border-bottom: 1px solid #ddd;
    padding-bottom: 7px;
  }
}

@media (max-width: 992px) {
  .section-tree .section {
    flex: 0 0 45%;
  }
}

@media (max-width: 768px) {
  .xs_hide, .user-nav {
    display: none;
  }
  .user-nav[aria-expanded="true"] {
    display: block;
  }
  .user-nav a,
  .user-nav a:hover {
    color: #333
  }
  ._grid ._col_4 {
    width: 50%;
  }
  .category-container .section-tree .section {
    margin: 0 0 15px 0;
  }
  .quick-articles > section {
    margin: 50px 0 0;
  }
}
@media (max-width: 464px) {
  .hero-inner .search-icon {
    top: 65%;
  }
}

/* =========================================== */
/*  Shortcodes
/* =========================================== */

.alert {
    padding: 15px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    border-radius: 4px;
}

.alert-info {
    color: #31708f;
    background-color: #d9edf7;
    border-color: #bce8f1;
}

.alert-success {
    color: #3c763d;
    background-color: #dff0d8;
    border-color: #d6e9c6;
}

.alert-warning {
    color: #8a6d3b;
    background-color: #fcf8e3;
    border-color: #faebcc;
}

.alert-danger {
    color: #a94442;
    background-color: #f2dede;
    border-color: #ebccd1;
}

.alert {
    border-width: 2px;
}

.__with_fa {
    border: 2px solid rgba(245, 166, 35, 1);
    background: rgba(245, 166, 35, 0.66);
    position: relative;
    font-size: 1.2em;
    line-height: 1.4;
    padding: 30px 15px 15px 15px;
}

.__with_fa .fa {
    position: absolute;
    top: 0;
    background: #fff;
    margin-top: -25px;
    border-radius: 100%;
    border: 2px solid rgba(245, 166, 35, 1);
    left: 15px;
    height: 45px;
    width: 45px;
    display: block;
    text-align: center;
    line-height: 45px;
}

.__with_fa .fa:before {
    margin-left: 5px;
}

.__with_fa {
    margin-top: 40px;
}

.alert-download {
    border: 2px solid #9adeec;
    background: #bce8f1;
}

.alert-quote {
    border: 2px solid rgba(103, 77, 68, 0.26);
    background: rgba(121, 85, 72, 0.26);
}

.alert-pdf {
    border: 2px solid rgba(229, 65, 94, 1);
    background: rgb(229, 65, 94);
    color: #fff;
}

.alert-download .fa {
    border: 2px solid #9adeec;
}

.alert-quote .fa {
    border: 2px solid rgb(186, 174, 168);
}

.alert-pdf .fa {
    border: 2px solid rgba(229, 65, 94, 1);
    color: rgba(229, 65, 94, 1);
}

.accordion {
   margin-bottom: 30px;
}

.colored_accordion .accordion_title {
   background: #ddd;
   border-color: #ddd;
}

.colored_accordion ._active {
   background: #ffb110;
   border-color: #ffb110;
   color: #fff;
}

.default_accordion ._active {
   background: #444;
   border-color: #444;
   color: #ffffff;
}

.accordion_content {
   display: none;
   padding: 10px;
}

._active::after,
.accordion .open::after {
   transform: rotate(90deg);
}

body .table,
.form .jpeIfh {
    background: #fff;
}

.table > thead > tr > th {
   color: #333;
   font-weight: 500;
   padding: 14px;
}

.article-container .table > thead > tr > th {
   border-bottom: 3px solid #ddd;
}

.article-container .table > tbody > tr > td {
   border-top: 1px solid #ddd;
   padding: 14px;
   font-size: 0.9em;
}

.table.header-color>thead>tr>th {
   border-color: #444;
   background: #444;
   color: #fff;
   padding: 10px;
}

.dark-table {
   background: #444;
   color: #fff;
}

.dark-table > thead > tr > th {
   border-bottom: 2px solid #fff;
}

.dark-table > tbody > tr > td {
   background: #333;
   border-color: #fff;
}

.dark-table > thead > tr > th {
   color: #fff;
}

.colored-list ul,
.colored-list ol {
   margin: 15px 0 0 0px;
}

.colored-list {
    list-style-type: none;
    padding: 0;
    counter-reset: li-counter;
}

.colored-list > li {
    position: relative;
    margin-bottom: 12px;
    padding-left: 35px;
    min-height: 0;
}

.colored-list > li:before {
    position: absolute;
    top: 3px;
    left: 0;
    font-size: 12px;
    color: #fff;
    content: counter(li-counter);
    counter-increment: li-counter;
    background-color: #276FD0;
    border-radius: 100%;
    height: 25px;
    width: 25px;
    line-height: 25px;
    text-align: center;
}

.list-black > li:before {
   background-color: #a59898;
}

.check-list-bullet li {
   list-style-type: none;
   position: relative;
   padding-left: 30px;
   margin-bottom: 15px;
}

.check-list-bullet li:before {
   content: "\f058";
   position: absolute;
   top: 0;
   left: 0;
   font-family: "FontAwesome";
   font-size: 25px;
   color: #276FD0;
   margin-top: -6px;
}

body .note--message,
body .warning--message,
body .quote--message,
body .support--message {
  padding: 30px 15px 15px 15px;
  font-size: 16px !important;
  position: relative;
  margin-top: 40px;
  margin-bottom: 20px;
  border-radius: 2px;
}

body .note--message::before,
body .warning--message::before,
body .quote--message::before,
body .support--message::before {
  font-family: 'LineIcons';
  position: absolute;
  top: 0;
  background: #fff;
  margin-top: -25px;
  border-radius: 100%;
  left: 15px;
  height: 45px;
  width: 45px;
  line-height: 45px;
  text-align: center;
  font-size: 23px;
}

[dir="rtl"] body .note--message::before,
[dir="rtl"] body .warning--message::before,
[dir="rtl"] body .quote--message::before,
[dir="rtl"] body .support--message::before {
  left: inherit;
  right: 15px;
}

body .note--message::before {
  content: "\eaf4";
}

body .warning--message::before {
  content: "\eaab";
}

body .quote--message::before {
  content: "\eb70";
}

body .support--message::before {
  content: "\ea2f";
}

body .note--message {
  background: #bce8f1;
  border: 2px solid #68cbdf;
}

body .support--message {
  background: rgba(0, 47, 187, 1);
  border: 2px solid #028;
  color: #fff;
}

body .note--message::before {
  border: 2px solid #68cbdf;
}

body .support--message::before {
  border: 2px solid #028;
  color: #028;
}

body .warning--message {
  background: #e5415e;
  border: 2px solid #e5415e;
  color: #fff;
}

body .warning--message::before {
  border: 2px solid #e5415e;
  color: #000;
}

body .quote--message {
  background: #d5ccc9;
  border: 2px solid #a89690;
}

body .quote--message::before {
  border: 2px solid #a89690;
}

body .check--list {
  margin-left: 30px;
}

body .check--list li,
body .number--list li,
#service-catalog-item li {
  position: relative;
  list-style-type: none;
}

body .number--list li,
#service-catalog-item .service-catalog-description ol > li{
  padding-left: 35px;
}

body .check--list li:before,
#service-catalog-item ul > li:before {
  content: "\ead2";
  font-family: "LineIcons";
  position: absolute;
  top: 0;
  left: -30px;
  font-size: 22px;
  color: rgba(0, 47, 187, 1);
  margin-top: -4px;
}

[dir="rtl"] body .check--list li:before,
[dir="rtl"] #service-catalog-item ul > li:before {
  left: inherit;
  right: -30px;
}

body .number--list,
#service-catalog-item .service-catalog-description ol {
  list-style-type: none;
  padding: 0;
  counter-reset: li-counter;
}

body .number--list > li:before,
#service-catalog-item .service-catalog-description ol > li:before {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 12px;
  color: #fff;
  content: counter(li-counter);
  counter-increment: li-counter;
  background-color: rgba(0, 47, 187, 1);
  border-radius: 100%;
  height: 25px;
  width: 25px;
  line-height: 25px;
  text-align: center;
  margin-top: -1px;
}

[dir="rtl"] body .number--list > li:before,
[dir="rtl"] #service-catalog-item .service-catalog-description ol > li:before {
  left: inherit;
  right: -35px;
}

body .accordion_title {
  background: #ffffff;
  border: 2px solid #dddddd;
  color: rgba(51, 51, 51, 1);
  cursor: pointer;
  padding: 15px 45px 15px 15px;
  margin-bottom: 5px;
  position: relative;
  border-radius: 2px;
}

[dir="rtl"] body .accordion_title {
  padding: 15px 15px 15px 45px;
}

body .accordion_content {
  display: none;
  padding: 10px;
}

body .accordion_title::after {
  content: "\eb0d";
  font-family: "LineIcons";
  position: absolute;
  top: 50%;
  right: 15px;
  font-size: 16px;
  margin-top: -12px;
  transition: all 0.2s ease-in;
}

[dir="rtl"] body .accordion_title::after {
  right: inherit;
  left: 15px;
  transform: rotate(180deg);
}

body .article-body .accordion_title._active::after,
body .article-body .accordion_title.open::after,
.active::after {
  transform: rotate(90deg) !important;
}

body .accordion_title.open {
  background: rgba(0, 47, 187, 1);
  border: 2px solid rgba(0, 47, 187, 1);
  color: #fff;
}

.tabs {
  width: 100%;
  background-color: rgba(0, 47, 187, 1);
  border-radius: 5px;
}

ul#tabs-nav {
  list-style: none;
  margin: 0;
  padding: 5px;
  overflow: auto;
}

ul#tabs-nav > li {
  float: left;
  font-weight: 600;
  margin-right: 2px;
  margin-bottom: 0;
  padding: 8px 10px;
  border-radius: 5px;
  cursor: pointer;
}

[dir="rtl"] ul#tabs-nav > li {
  float: right;
}

ul#tabs-nav > li:hover,
ul#tabs-nav > li.active {
  background-color: #001555;
}

#tabs-nav > li > a {
  text-decoration: none;
  color: #ffffff;
}

#tabs-content {
  background: #ffffff;
}

.tab-content {
  padding: 10px;
  border: 2px solid rgba(0, 47, 187, 1);
  background-color: #ffffff;
}

/***** Community Badges *****/
/* Styles labels used next to the authors of article comments, community posts, and community comments */

.community-badge-title {
  background-color: rgba(0, 47, 187, 1);
  border-radius: 4px;
  color: rgba(255, 255, 255, 1);
  font-size: 12px;
  font-weight: 600;
  padding: 0px 8px;
  vertical-align: top;
  white-space: nowrap;
  display: inline-flex;
  line-height: 18px;
  vertical-align: middle;
}

.profile-info .community-badge-title {
  padding: 2px 8px;
  line-height: 20px;
}

.community-badge-container-achievements {
  display: flex;
}

.community-badge-container-achievements > .community-badge-titles {
  margin-left: calc(28px - 0.5em);
}

[dir="rtl"] .community-badge-container-achievements > .community-badge-titles {
  margin-right: calc(28px - 0.5em);
}

.community-name-and-title-badges {
  display: flex;
  flex-wrap: wrap;
}

.community-badge {
  margin: 2px;
}

.community-badge-achievements {
  display: block;
  height: 16px;
  white-space: nowrap;
  width: 16px;
}

.profile-info .community-badge-achievements {
  height: 40px;
  width: 40px;
}

.community-title-badges {
  flex-basis: 100%;
  margin-top: 15px;
}

.community-badge-achievements-rest {
  font-size: 12px;
  font-weight: 600;
  line-height: 20px;
  text-align: center;
  vertical-align: top;
}

.community-badge-achievements img {
  width: 100%;
  height: 100%;
}

.community-badge-titles img {
  width: 20px;
  height: 20px;
}

.profile-info .community-badge-achievements-rest {
  line-height: 40px;
  font-size: 20px;
}

.split-button {
  display: flex;
}

.split-button button {
  background: rgba(0, 47, 187, 1);
  border: 0;
  color: #FFFFFF;
  height: 32px;
  line-height: 16px;
  outline-color: rgba(0, 47, 187, 1);
}

.split-button button:not(:only-child):last-child {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 26px;
  min-width: 26px;
  max-width: 26px;
  padding: 0;
}

[dir="rtl"] .split-button button:not(:only-child):first-child {
  border-left: 1px solid rgba(255, 255, 255, 1);
  border-top-left-radius: unset;
  border-bottom-left-radius: unset;
}

[dir="ltr"] .split-button button:not(:only-child):first-child {
  border-right: 1px solid rgba(255, 255, 255, 1);
  border-top-right-radius: unset;
  border-bottom-right-radius: unset;
}

[dir="rtl"] .split-button button:not(:only-child):last-child {
  border-top-right-radius: unset;
  border-bottom-right-radius: unset;
}

[dir="ltr"] .split-button button:not(:only-child):last-child {
  border-top-left-radius: unset;
  border-bottom-left-radius: unset;
}

.profile-badges-items {
  margin-top: 25px;
}

.profile-badges-item {
  border-top: 1px solid #DDDDDD;
  display: flex;
  flex: 1;
  flex-direction: row;
  justify-content: flex-start;
  padding: 27px 12px;
}

.profile-badges-item-image {
  height: 40px;
  width: 40px;
  margin-right: 12px;
}

[dir="rtl"] .profile-badges-item-image {
  margin-left: 12px;
  margin-right: 0;
}

.profile-badges-item > div {
  padding-right: 12px;
  padding-left: 12px;
}

.profile-badges-item-image img {
  max-height: 40px;
}

.profile-badges-item-title, .profile-badges-item-metadata-title {
  font-size: 15px;
  margin-bottom: 10px;
}

.profile-badges-item-title {
  font-weight: 600;
}

.profile-badges-item-description, .profile-badges-item-metadata-description {
  color: #666;
  font-size: 13px;
  margin: 0;
}

.profile-badges-item-metadata {
  margin-left: auto;
  text-align: right;
}

[dir="rtl"] .profile-badges-item-metadata {
  margin-left: 0;
  margin-right: auto;
  text-align: left;
}

.community-badge[aria-label="Community team"] {
  background: #eaa40a;
}

.community-badge[aria-label="Community moderator"],
.community-badge[aria-label="Community manager"] {
  background: #11aa7b;
}

.community-badge[aria-label="Idea generator"],
.community-badge[aria-label="Good karma"] {
  background: #4a8cf1;
}

.community-badge[aria-label="Great answers"] {
  background: #fc585b;
}

.content-tags > p {
  color: #68737D;
  margin-top: 32px;
  margin-bottom: 4px;
}

.content-tags-add-hint {
  color: #68737D;
  font-size: 14px;
}

.content-tag-list {
  display: flex;
  flex-wrap: wrap;
  word-break: break-word;
}

.content-tag-list li {
  border-right: 1px solid #C2C8CC;
  margin-bottom: 4px;
}

[dir="ltr"] .content-tag-list li {
  padding-right: 8px;
  margin-right: 8px;
}

[dir="rtl"] .content-tag-list li {
  padding-left: 8px;
  margin-left: 8px;
}

.content-tag-list li:last-child {
  border: none;
}

#service-catalog-item .service-catalog-description {
  line-height: 1.6;
  font-size: 16px;
}

 /* Modificación de altura de la imagen de cabecera */
.hero {
padding: 
80px 0 65px 0;
}

/* Modificación de icono de los artículos

.article-list li:before,
.quick-articles ul > li > a:before,
.article-sidebar ul > li:before,
.section-lists li:before {
    content: "\f15c";    -----------------------------------------  este es el icono mirar página https://fontawesome.com/v4/icon/file-text
    color: rgba(0, 47, 187, 1);
    font-family: "FontAwesome";
    position: absolute;
    left: 0;
    margin-top: 2px;
}

*/


 /* Desactivar desplegable de formularios en una solicitud */
#id\:0--trigger
{
  /*display:none; */
  pointer-events: none;
  opacity: 0.5;
}


/* CODIGO PARA SERVICIOS */


/* Buscador y Contenedores */
.catalog-search-wrapper { margin: 20px 0 40px; max-width: 500px; }
#catalog-search-input { width: 100%; padding: 12px 15px; border: 1px solid #d8dcde; border-radius: 4px; font-size: 16px; }

/* Grid de Servicios */
.catalog-group { margin-bottom: 40px; }
.group-title { font-size: 22px; font-weight: 700; border-bottom: 2px solid #eee; padding-bottom: 8px; margin-bottom: 20px; color: #333; }
.services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }

/* Tarjetas */
.service-card { display: flex; padding: 20px; background: #fff; border: 1px solid #e1e4e8; border-radius: 8px; text-decoration: none !important; transition: transform 0.2s, border-color 0.2s; color: inherit; }
.service-card:hover { transform: translateY(-3px); border-color: #174ae6; box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
.card-icon { font-size: 26px; color: #174ae6; margin-right: 18px; flex-shrink: 0; }
.service-name { display: block; font-weight: 700; font-size: 17px; margin-bottom: 4px; }
.service-description { font-size: 14px; color: #68737d; line-height: 1.4; margin-bottom: 10px; }
.service-action { font-size: 13px; font-weight: 700; color: #174ae6; }

/* Skeleton Loading Animation */
@keyframes shimmer { 0% { background-position: -468px 0; } 100% { background-position: 468px 0; } }
.skeleton-title, .skeleton-card { background: #f6f7f8; background-image: linear-gradient(to right, #f6f7f8 0%, #edeef1 20%, #f6f7f8 40%, #f6f7f8 100%); animation: shimmer 1.5s infinite linear; border-radius: 4px; }
.skeleton-title { height: 25px; width: 180px; margin-bottom: 20px; }
.skeleton-card { height: 120px; }

@media (max-width: 767px) { .services-grid { grid-template-columns: 1fr; } }


/* Forzar visibilidad del contenedor de búsqueda */
.catalog-search-wrapper.is-visible {
  display: block !important;
  visibility: visible !important;
  margin: 30px 0 !important;
  position: relative !important;
  width: 100% !important;
  max-width: 600px !important;
}

/* Estilo visual de la caja */
#catalog-search-input {
  width: 100% !important;
  padding: 15px 20px 15px 45px !important; /* Espacio para el icono */
  border: 2px solid #d8dcde !important;
  border-radius: 30px !important; /* Estilo redondeado moderno */
  font-size: 16px !important;
  color: #2f3941 !important;
  background-color: #ffffff !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05) !important;
  outline: none !important;
}

#catalog-search-input:focus {
  border-color: #174ae6 !important;
  box-shadow: 0 4px 8px rgba(23, 74, 230, 0.15) !important;
}

/* Icono de lupa dentro de la caja */
.catalog-search-wrapper .search-icon {
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  color: #68737d;
  font-size: 18px;
  pointer-events: none;
}

.no-results-found {
  text-align: center;
  padding: 50px 20px;
  color: #68737d;
}

.no-results-found i {
  font-size: 40px;
  margin-bottom: 15px;
  display: block;
}

.service-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.service-badge {
  font-size: 10px;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 12px;
  font-weight: bold;
  white-space: nowrap;
}

/* Colores dinámicos basados en el texto */
.badge-nuevo { background: #e7f5ff; color: #007bff; border: 1px solid #007bff; }
.badge-popular { background: #fff4e6; color: #fd7e14; border: 1px solid #fd7e14; }
.badge-averia { background: #fff5f5; color: #fa5252; border: 1px solid #fa5252; }
.badge-proximamente { background: #f8f9fa; color: #6c757d; border: 1px solid #6c757d; }


.filters-container {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 30px;
}

.filter-btn {
  padding: 8px 16px;
  border: 1px solid #d8dcde;
  background: white;
  border-radius: 20px;
  cursor: pointer;
  font-size: 14px;
  transition: all 0.2s;
}

.filter-btn:hover {
  border-color: #174ae6;
  color: #174ae6;
}

.filter-btn.active {
  background: #174ae6;
  color: white;
  border-color: #174ae6;
}

.filter-btn.badge-filter {
  border-style: dashed; /* Un toque visual distinto */
  border-color: #fd7e14;
  color: #fd7e14;
}

.filter-btn.badge-filter.active {
  background: #fd7e14;
  color: white;
}

.filter-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.1);
  color: inherit;
  font-size: 0.8em;
  font-weight: bold;
  padding: 2px 8px;
  border-radius: 12px;
  margin-left: 8px;
  opacity: 0.8;
}

.filter-btn.active .filter-count {
  background-color: rgba(255, 255, 255, 0.3);
  opacity: 1;
}

/* Estilo para diferenciar los badges de las categorías */
.filter-btn.badge-filter {
  border: 1px dashed #fd7e14;
  color: #fd7e14;
}

.filter-btn.badge-filter.active {
  background-color: #fd7e14;
  color: white;
  border-style: solid;
}

/* Clase que aplicaremos a cada tarjeta */
.service-card {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInUp 0.4s ease forwards;
}

/* Definición de la animación */
@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Retraso escalonado para efecto cascada (hasta 10 tarjetas) */
.service-card:nth-child(1) { animation-delay: 0.05s; }
.service-card:nth-child(2) { animation-delay: 0.1s; }
.service-card:nth-child(3) { animation-delay: 0.15s; }
.service-card:nth-child(4) { animation-delay: 0.2s; }
.service-card:nth-child(5) { animation-delay: 0.25s; }
.service-card:nth-child(6) { animation-delay: 0.3s; }
.service-card:nth-child(7) { animation-delay: 0.35s; }
.service-card:nth-child(8) { animation-delay: 0.4s; }

/* Evitar saltos visuales en el contenedor */
#dynamic-service-catalog {
  transition: min-height 0.3s ease;
  min-height: 200px;
}

.filter-btn {
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.filter-btn:hover {
  transform: scale(1.05);
}

.filter-btn:active {
  transform: scale(0.95);
}

/* Contenedor principal del buscador */
.catalog-search-wrapper {
  position: relative;
  display: flex;
  align-items: center; /* Centra verticalmente los elementos internos */
  width: 100%;
  max-width: 600px; /* O el ancho que tengas configurado */
  margin: 0 auto 20px;
}

/* Ajustes del input para que no lo pise la X */
#catalog-search-input {
  width: 100%;
  padding-right: 45px; /* Espacio extra a la derecha para la X */
  height: 45px;        /* Altura fija para asegurar el centrado */
  box-sizing: border-box;
}

/* Posicionamiento absoluto de la X respecto al contenedor */
.clear-search-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%); /* Truco para centrado vertical perfecto */
  background: transparent;
  border: none;
  color: #999;
  cursor: pointer;
  padding: 8px;
  font-size: 18px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.clear-search-btn:hover {
  color: #333;
}

/* Icono de lupa (si lo tienes a la izquierda) */
.search-icon {
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  color: #999;
  pointer-events: none;
}

/* --- ESTILOS PARA LA SECCIÓN RECOMENDADOS --- */

/* 1. Contenedor principal de la sección */
.recommended-section {
  background: linear-gradient(to right, #fffdf0, #ffffff);
  border: 1px solid #f1c40f;
  border-left: 6px solid #f1c40f;
  padding: 15px 20px; /* Reducido el padding vertical de 25px a 15px */
  border-radius: 12px;
  margin-bottom: 20px; /* Reducido el margen de 40px a 20px */
  box-shadow: 0 4px 15px rgba(241, 196, 15, 0.1);
  position: relative;
}

/* 2. Título de la sección (Versión combinada y compacta) */
.recommended-section .group-title {
  color: #856404 !important;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  gap: 10px;
  /* Ajuste de márgenes para reducir espacio */
  margin-top: 5px; 
  margin-bottom: 15px; 
}

/* 3. Estilo especial para las TARJETAS dentro de recomendados */
.recommended-section .service-card {
  background-color: #ffffff;
  border-color: #f1c40f;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.recommended-section .service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 15px rgba(241, 196, 15, 0.2);
  border-color: #d4ac0d;
}

/* 4. Iconos dentro de las tarjetas recomendadas */
.recommended-section .card-icon i {
  color: #f1c40f; /* Cambia el color del icono a dorado */
}

/* 5. Separador inferior */
.section-divider {
  border: 0;
  border-top: 2px dashed #eee;
  margin: 40px 0;
}

/* 6. Animación sutil para la estrella del título */
.recommended-section .fa-star {
  animation: pulse-star 2s infinite;
}

@keyframes pulse-star {
  0% { transform: scale(1); }
  50% { transform: scale(1.2); }
  100% { transform: scale(1); }
}

/* Añade un pequeño texto de "Sugerido" encima de la tarjeta solo en esta sección 
.recommended-section .service-card::before {
  content: "GENERAL";
  position: absolute;
  top: -10px;
  right: 15px;
  background: #f1c40f;
  color: #856404;
  font-size: 10px;
  font-weight: bold;
  padding: 2px 8px;
  border-radius: 10px;
  z-index: 1;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
*/

.uncategorized-section {
  padding-top: 10px;
  border-top: 1px solid transparent; /* Ayuda a separar visualmente sin pintar línea si no quieres */
}

/* 1. Fondo de página para generar contraste */
body {
    background-color: #f1f5f9 !important; /* Un gris azulado suave pero visible */
}

/* 2. LA TARJETA DE CATEGORÍA (MÁS MARCADA) */
.catalog-group {
    background: #ffffff !important;
    /* Borde más oscuro y sólido */
    border: 2px solid #d1d5db !important; 
    border-radius: 12px !important;
    padding: 30px !important;
    margin-bottom: 50px !important;
    /* Sombra más densa para dar volumen */
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 
                0 8px 10px -6px rgba(0, 0, 0, 0.1) !important;
    position: relative;
}

/* 3. Título de la categoría */
.catalog-group .group-title {
    font-size: 1.5rem;
    font-weight: 800;
    color: #111827; /* Negro casi puro para legibilidad */
    margin-top: 0;
    margin-bottom: 25px;
    padding-bottom: 15px;
    border-bottom: 2px solid #e5e7eb;
    display: flex;
    align-items: center;
}

/* 4. Línea de acento (más gruesa) */
.catalog-group .group-title::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 120px;
    height: 5px;
    background: #2563eb; /* Azul intenso */
    border-radius: 3px;
}

/* 5. Especialmente para ti (Diferenciación clara) */
.recommended-section {
    border: 2px solid #f59e0b !important; /* Borde naranja/dorado */
    border-top: 8px solid #f59e0b !important; /* Ceja superior más gruesa */
}

.recommended-section .group-title::after {
    background: #f59e0b;
}

/* 6. Ajuste de las tarjetas de servicio interiores */
.service-card {
  	overflow: hidden;
    background: #f9fafb; /* Fondo ligeramente gris para que resalte sobre el blanco de la tarjeta grande */
    border: 1px solid #e2e8f0;
		overflow: hidden;
}

.service-card-wrapper { position: relative; display: flex; flex-direction: column; }
.info-icon-container { position: absolute; top: 12px; right: 12px; z-index: 15; }
.info-trigger { font-size: 20px; color: #3b82f6; cursor: pointer; background: white; border-radius: 50%; }
.instructions-popover { 
    display: none; position: absolute; top: 32px; right: 0; width: 260px; 
    background: #1e293b; color: white; padding: 15px; border-radius: 8px; 
    font-size: 13px; box-shadow: 0 10px 15px rgba(0,0,0,0.3); z-index: 100; 
}
.popover-arrow { 
    position: absolute; top: -6px; right: 12px; width: 12px; height: 12px; 
    background: #1e293b; transform: rotate(45deg); 
}
.popover-body { max-height: 200px; overflow-y: auto; }
/* Estilo para HTML dentro del popover */
.popover-body a { color: #60a5fa; text-decoration: underline; }


.catalog-search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  max-width: 500px;
  margin: 20px 0;
}

#catalog-search-input {
  width: 100%;
  padding: 12px 45px 12px 40px; /* Espacio para lupa (izq) y X (der) */
  border-radius: 25px;
  border: 1px solid #ddd;
}

.search-icon {
  position: absolute;
  left: 15px;
  color: #888;
}

.clear-search-btn {
  position: absolute;
  right: 12px;
  background: none;
  border: none;
  color: #999;
  font-size: 18px;
  cursor: pointer;
  padding: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.clear-search-btn:hover {
  color: #666;
}

/* Estilos para la estrella de favoritos */
.fav-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 5;
  transition: all 0.2s ease;
  color: #ccc;
  border: 1px solid #eee;
}

.fav-btn:hover {
  transform: scale(1.1);
  background: #fff;
}

.fav-btn.is-active {
  color: #f1c40f; /* Color dorado */
  border-color: #f1c40f;
}

/* Ajuste para que el icono de info no choque con la estrella */
.info-icon-container {
  right: 45px !important; /* Movemos el icono de info un poco a la izquierda */
}

/* Estrella bloqueada (Backend) */
.fav-btn.is-locked {
  cursor: default;
  background: rgba(241, 196, 15, 0.1); /* Un fondo sutil dorado */
  border-color: #f1c40f;
  pointer-events: none; /* Evita que el clic dispare nada */
}

.fav-btn.is-locked:hover {
  transform: none; /* Sin animación de escala */
}

/* Tooltip sencillo para explicar por qué está ahí */
.fav-btn[title]:hover:after {
  content: attr(title);
  position: absolute;
  top: -30px;
  background: #333;
  color: #fff;
  padding: 4px 8px;
  font-size: 11px;
  border-radius: 4px;
  white-space: nowrap;
  z-index: 10;
}

/* Contenedor de la tarjeta */
.service-card-wrapper {
  position: relative; /* Base para posicionar iconos */
  display: block;
}

/* Zona de acciones superiores (Estrella e Info) */
.card-actions {
  position: absolute;
  top: 10px;
  left: 10px;
  right: 10px;
  display: flex;
  justify-content: space-between; /* Estrella a un lado, Info al otro */
  z-index: 10; /* Siempre por encima del enlace <a> */
  pointer-events: none; /* Deja pasar el clic al fondo... */
}

.fav-btn, .info-icon-container {
  pointer-events: auto; /* ...excepto en los iconos mismos */
  background: white;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  border: 1px solid #eee;
  cursor: pointer;
}

/* Ajuste del Badge para que no tape nada */
.service-badge {
  display: inline-block;
  margin-top: 5px;
  padding: 2px 8px;
  font-size: 11px;
  border-radius: 4px;
  font-weight: bold;
  text-transform: uppercase;
}

/* Reset de la Info Icon para que no use su posicionamiento antiguo */
.info-icon-container {
  position: relative !important;
  right: auto !important;
  top: auto !important;
}

.fav-btn.is-active { color: #f1c40f; border-color: #f1c40f; }
.fav-btn.is-locked { background: #fffdf0; opacity: 0.9; cursor: default; }


/* Contenedor principal */
.service-card-wrapper {
  position: relative;
  overflow: visible;
}

/* Capa superior de botones (Estrella e Info) */
.card-actions {
  position: absolute;
  top: -10px; /* Los sacamos un poco por arriba para que respiren */
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-between;
  padding: 0 5px;
  z-index: 20; /* Prioridad máxima */
  pointer-events: none;
}

.fav-btn, .info-icon-container {
  pointer-events: auto; /* Activamos clics solo en los iconos */
  background: white !important;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0,0,0,0.15);
  border: 1px solid #eee;
  cursor: pointer;
}

/* Espaciado interno de la tarjeta para no chocar con los botones */
.service-card {
  padding-top: 25px !important; /* Espacio reservado para los botones de arriba */
  display: flex;
  flex-direction: column;
  height: 100%;
  border: 1px solid #e2e8f0;
  overflow: hidden;
}

/* El nombre del servicio */
.service-name {
  display: block;
  margin-bottom: 8px;
  line-height: 1.2;
}

/* El Badge: lo movemos debajo del título con margen */
.badge-container {
  display: block;
  margin: 10px 0;
  clear: both;
}

.service-badge {
  display: inline-block;
  padding: 3px 10px;
  font-size: 10px;
  border-radius: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
}

/* Colores de badges (Asegúrate de tener estos) */
.badge-nuevo { background: #e3f2fd; color: #1976d2; }
.badge-popular { background: #fff3e0; color: #f57c00; }
.badge-averia { background: #ffebee; color: #d32f2f; }

/* Estrellas */
.fav-btn.is-active { color: #f1c40f; border-color: #f1c40f; }
.fav-btn.is-locked { background: #fffdf0 !important; cursor: default; }

.info-icon-container {
  pointer-events: auto;
  background: white !important;
  width: 36px;  /* Antes 32px - Un poco más grande para facilitar el clic */
  height: 36px; /* Antes 32px */
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0,0,0,0.15);
  border: 1px solid #eee;
  cursor: pointer;
}

.info-icon-container .fa-info-circle {
  font-size: 20px; /* Antes ~16px - Icono más visible */
  color: #1976d2;  /* Un azul corporativo sutil para que destaque */
}

/* Ajustamos también la estrella para que mantengan la simetría */
.fav-btn {
  width: 36px;
  height: 36px;
  font-size: 18px;
}

/* Agrupamos Estrella e Info a la derecha */
.card-actions {
  position: absolute;
  top: 10px;
  right: 10px; /* Ambos a la derecha */
  display: flex;
  gap: 8px; /* Espacio entre los dos botones */
  z-index: 20;
  pointer-events: none;
}

.fav-btn, .info-icon-container {
  pointer-events: auto;
  background: white !important;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0,0,0,0.15);
  border: 1px solid #eee;
}

/* Movemos el Badge a la esquina superior izquierda */
.badge-container {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 10;
  margin: 0; /* Quitamos márgenes antiguos */
}

.service-badge {
  display: inline-block;
  padding: 4px 10px;
  font-size: 10px;
  border-radius: 4px; /* Un poco más cuadrado para que parezca etiqueta */
  font-weight: 700;
  text-transform: uppercase;
}

/* Ajuste del padding superior de la tarjeta para que el contenido no suba tanto */
.service-card {
  padding-top: 45px !important; 
}


/* Contenedor de botones a la DERECHA */
.card-actions {
  position: absolute;
  top: 10px;
  right: 10px; /* Alineado a la derecha */
  display: flex;
  gap: 10px;    /* Espacio entre Info y Estrella */
  z-index: 20;
  pointer-events: none;
}

/* El Badge a la IZQUIERDA */
.badge-container {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 10;
}


/* RESET de la Info para que no se mueva sola */
.info-icon-container {
  position: relative !important; /* IMPORTANTE: Deja de ser absoluto */
  top: auto !important;
  left: auto !important;
  right: auto !important;
  pointer-events: auto;
}

/* El contenedor que manda ahora */
.card-actions {
  position: absolute;
  top: 10px;
  right: 10px;    /* Todo a la derecha */
  display: flex !important;
  flex-direction: row !important;
  gap: 10px;      /* Espacio entre i y estrella */
  z-index: 30;
  pointer-events: none;
}

/* Aseguramos que los botones dentro respondan al clic */
.card-actions > div {
  pointer-events: auto;
}

/************************************************************
 * FIX: AGRUPACIÓN INFO + ESTRELLA (LADO DERECHO)
 * Este bloque corrige la posición sin afectar al resto del CSS
 ************************************************************/

/* 1. Forzamos el contenedor de acciones a la derecha */
.service-card-wrapper .card-actions {
  position: absolute !important;
  top: 15px !important;
  right: 15px !important; /* Alineación derecha total */
  left: auto !important;  /* Anula cualquier empuje desde la izquierda */
  display: flex !important;
  flex-direction: row !important; /* i y estrella en línea */
  align-items: center !important;
  gap: 10px !important; /* Espacio entre ellos */
  z-index: 99 !important;
  pointer-events: none;
  width: auto !important;
}

/* 2. Reset de la "i" de información */
/* Anulamos cualquier estilo previo que la mandara a la izquierda */
.service-card-wrapper .info-icon-container {
  position: relative !important; /* Deja de ser absoluto para obedecer al flex del padre */
  top: auto !important;
  left: auto !important;
  right: auto !important;
  margin: 0 !important;
  pointer-events: auto;
  display: flex !important;
}

/* 3. Reset de la Estrella */
.service-card-wrapper .fav-btn {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  margin: 0 !important;
  pointer-events: auto;
  display: flex !important;
}

/* 4. El Badge se queda solo a la izquierda */
.service-card-wrapper .badge-container {
  position: absolute !important;
  top: 15px !important;
  left: 15px !important; /* Extremo izquierdo */
  right: auto !important;
  z-index: 90 !important;
}

/* Estilo visual para que ambos iconos se vean iguales (Opcional) */
.info-icon-container, .fav-btn {
  width: 34px;
  height: 34px;
  background: #fff;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  border: 1px solid #eee;
}


/* --- CONTROLES DE VISTA --- */
.view-controls {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-bottom: 20px;
}
.view-btn {
  background: white;
  border: 1px solid #ddd;
  padding: 8px 12px;
  border-radius: 6px;
  cursor: pointer;
  color: #666;
  transition: all 0.2s;
}
.view-btn.active {
  background: rgba(0, 47, 187, 1);
  color: white;
  border-color: rgba(0, 47, 187, 1);
}

/* --- MODO LISTA (ESTILOS ESPECÍFICOS) --- */
.services-grid.list-mode {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.services-grid.list-mode .service-card-wrapper {
  width: 100%;
}

.services-grid.list-mode .service-card {
  flex-direction: row; /* Alineación horizontal */
  text-align: left;
  padding: 15px 80px 15px 60px; /* Ajuste para badge y botones */
  min-height: auto;
  align-items: center;
}

.services-grid.list-mode .card-icon {
  font-size: 24px;
  margin-bottom: 0;
  margin-right: 20px;
  min-width: 30px;
}

.services-grid.list-mode .service-content {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.services-grid.list-mode .service-description {
  margin-bottom: 0;
  margin-left: 20px;
  font-size: 13px;
  display: -webkit-box;
  -webkit-line-clamp: 1; /* Limita a una línea en modo lista */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.services-grid.list-mode .service-action {
  display: none; /* Opcional: ocultar el botón "Solicitar" para ahorrar espacio */
}

/* Ajuste de botones en modo lista */
.services-grid.list-mode .card-actions, 
.services-grid.list-mode .badge-container {
  top: 50% !important;
  transform: translateY(-50%);
}

/* ==========================================================================
   ANIMACIONES Y MICRO-INTERACCIONES (MEJORA 3)
   ========================================================================== */

/* 1. Animación de la Estrella (Pop) */
@keyframes starPop {
  0% { transform: scale(1); }
  50% { transform: scale(1.4); }
  100% { transform: scale(1); }
}

.fav-btn.is-active i {
  animation: starPop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  color: #f1c40f !important;
}

/* 2. Hover en la Tarjeta */
.service-card {
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
}

.service-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 15px 35px rgba(0,0,0,0.12) !important;
  border-color: rgba(0, 47, 187, 1) !important;
}

/* 3. Animación del Icono al hacer Hover */
.service-card:hover .card-icon i {
  transform: rotate(-10deg) scale(1.1);
  color: rgba(0, 47, 187, 1);
  transition: all 0.3s ease;
}

.card-icon i {
  transition: all 0.3s ease;
  display: inline-block;
}

/* 4. Efecto de pulsación en el Badge */
.service-badge {
  position: relative;
  overflow: hidden;
}

.service-badge::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: rgba(255,255,255,0.2);
  transform: rotate(45deg);
  transition: all 0.5s;
  opacity: 0;
}

.service-card-wrapper:hover .service-badge::after {
  left: 120%;
  opacity: 1;
}

/* --- ICONO FIJO PARA EVITAR DESPLAZAMIENTOS --- */
.card-icon {
  height: 60px; /* Altura fija para que no empuje el texto */
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}

.card-icon i {
  transition: transform 0.3s ease-out, color 0.3s ease;
  display: inline-block;
  backface-visibility: hidden; /* Evita parpadeos en Chrome */
}

/* --- ANIMACIÓN MEJORADA (SOLO ROTACIÓN SUAVE) --- */
.service-card:hover .card-icon i {
  /* Eliminamos el 'scale' excesivo y solo rotamos un poco */
  transform: rotate(-10deg); 
  color: rgba(0, 47, 187, 1);
}

/* --- LEVANTAMIENTO DE TARJETA MÁS SUTIL --- */
.service-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease !important;
}

.service-card:hover {
  /* Reducimos el desplazamiento de 8px a 4px para que sea menos brusco */
  transform: translateY(-4px) !important;
  box-shadow: 0 8px 20px rgba(0,0,0,0.08) !important;
}

/* ==========================================================================
   VERSION COMPACTA Y ESTABLE (SIN MOVIMIENTO)
   ========================================================================== */

/* 1. Icono más discreto y estático */
.card-icon {
  height: auto; /* Quitamos la altura fija alta */
  margin-bottom: 10px; /* Reducimos espacio con el texto */
  display: block;
}

.card-icon i {
  font-size: 28px; /* Tamaño un poco más pequeño para menos protagonismo */
  transition: color 0.3s ease;
  transform: none !important; /* Forzamos que no haya rotación */
  display: inline-block;
}

/* 2. Tarjeta totalmente estable (Sin saltos) */
.service-card {
  /* Quitamos el transform de la transición para evitar mareos */
  transition: box-shadow 0.3s ease, border-color 0.3s ease, background-color 0.3s ease !important;
  transform: none !important; 
  text-align: center;
  padding: 40px 20px 25px; /* Padding más equilibrado */
}

.service-card:hover {
  transform: none !important; /* No se desplaza hacia arriba */
  border-color: rgba(0, 47, 187, 1) !important; /* Feedback visual mediante color de borde */
  box-shadow: 0 4px 12px rgba(0,0,0,0.1) !important; /* Sombra muy sutil */
  background-color: #fafafa; /* Cambio de fondo suave para indicar selección */
}

/* 3. Aseguramos que el icono no se mueva al hacer hover */
.service-card:hover .card-icon i {
  transform: none !important;
  color: rgba(0, 47, 187, 1);
}

/* 4. Texto más compacto */
.service-name {
  font-size: 17px;
  margin-bottom: 8px;
}

.service-description {
  font-size: 13px;
  line-height: 1.4;
}

/* --- CABECERA DE TARJETA EN LÍNEA --- */
.card-header-flex {
  display: flex;
  align-items: center; /* Alineación vertical perfecta */
  gap: 12px;           /* Espacio entre icono y nombre */
  width: 100%;
  margin-bottom: 12px;
  text-align: left;    /* Alineamos el texto a la izquierda */
}

.service-card {
  text-align: left !important; /* Toda la tarjeta alineada a la izquierda */
  padding: 45px 20px 20px !important; /* Ajuste de padding superior por los iconos */
  display: flex;
  flex-direction: column;
}

.card-icon {
  margin-bottom: 0 !important; /* Quitamos el margen inferior antiguo */
  flex-shrink: 0;             /* Evita que el icono se aplaste */
}

.card-icon i {
  font-size: 24px;            /* Tamaño más equilibrado para ir en línea */
  color: rgba(0, 47, 187, 1);
}

.service-name {
  font-size: 16px;
  margin-bottom: 0 !important; /* El margen ahora lo controla el gap del padre */
  line-height: 1.2;
}

.service-description {
  margin-left: 0;             /* Alineado con el resto */
  font-size: 13px;
  color: #666;
  text-align: left;
}

/* Ajuste para el modo Lista (opcional, para que mantenga coherencia) */
.services-grid.list-mode .card-header-flex {
  margin-bottom: 0;
  width: auto;
}

/* ==========================================================================
   MEJORA DE CONTRASTE Y VISIBILIDAD
   ========================================================================== */

/* 1. Línea de título de categoría (Más gruesa y oscura) */
.group-title {
  font-size: 24px;
  margin-bottom: 25px;
  padding-bottom: 12px;
  /* Cambiamos el gris suave por uno más definido y mantenemos el acento de marca */
  border-bottom: 3px solid #ced4da; 
  position: relative;
}

/* Opcional: una pequeña línea de color de marca debajo del gris para que destaque más */
.group-title::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 60px;
  height: 3px;
  background-color: rgba(0, 47, 187, 1);
}

/* 2. Recuadro de los servicios (Borde más visible y sombra definida) */
.service-card {
  background: #ffffff;
  /* Borde más oscuro (#cbd5e0 en lugar de #eef2f6) */
  border: 1.5px solid #cbd5e0 !important; 
  border-radius: 12px;
  /* Sombra con un poco más de opacidad para dar profundidad */
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
  transition: all 0.3s ease !important;
}

/* 3. Estado al pasar el ratón (Hover) */
.service-card:hover {
  border-color: rgba(0, 47, 187, 1) !important;
  /* Sombra más marcada al seleccionar */
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.12) !important;
  background-color: #f8fafc; /* Un tono grisáceo muy leve de fondo */
}

/* 4. Separación de la descripción (Mejor lectura) */
.service-description {
  color: #4a5568; /* Gris más oscuro para el texto descriptivo */
  font-weight: 450;
}

/* --- MEJORA 1: RESALTADO DE BÚSQUEDA --- */
mark.search-highlight {
  background-color: rgba(255, 235, 59, 0.4); /* Amarillo suave */
  border-bottom: 2px solid #fbc02d;        /* Línea inferior para destacar */
  color: inherit;
  padding: 0 2px;
  border-radius: 2px;
}

/* --- MEJORA 3: CONTADORES EN FILTROS --- */
.filter-count {
  display: inline-block;
  background-color: rgba(0, 0, 0, 0.08);
  color: #666;
  font-size: 11px;
  font-weight: bold;
  padding: 2px 6px;
  border-radius: 10px;
  margin-left: 6px;
  transition: all 0.2s;
}

.filter-btn.active .filter-count {
  background-color: rgba(255, 255, 255, 0.2);
  color: white;
}

/* --- ANIMACIÓN DE ENTRADA (OPCIÓN A) --- */

/* Definimos el movimiento: de abajo hacia arriba y de transparente a visible */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(15px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Esta clase se aplicará a las tarjetas para ejecutar la animación */
.service-card-wrapper {
  animation: fadeInUp 0.4s ease forwards;
}

/* Opcional: Escalonado (Stagger effect) 
   Hace que las tarjetas no aparezcan todas a la vez, sino una tras otra */
.service-card-wrapper:nth-child(1) { animation-delay: 0.05s; }
.service-card-wrapper:nth-child(2) { animation-delay: 0.1s; }
.service-card-wrapper:nth-child(3) { animation-delay: 0.15s; }
.service-card-wrapper:nth-child(4) { animation-delay: 0.2s; }
.service-card-wrapper:nth-child(5) { animation-delay: 0.25s; }
.service-card-wrapper:nth-child(6) { animation-delay: 0.3s; }

/* --- ANIMACIÓN DE ENTRADA SUAVE (OPCIÓN A - LENTA) --- */

@keyframes fadeInUp {
  from {
    opacity: 0;
    /* Un poco más de desplazamiento inicial para que el recorrido sea más fluido */
    transform: translateY(25px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.service-card-wrapper {
  /* Aumentamos a 0.8s para una entrada pausada y usamos cubic-bezier para suavidad extra */
  animation: fadeInUp 0.8s cubic-bezier(0.21, 1.02, 0.73, 1) forwards;
  opacity: 0; /* Asegura que no parpadee antes de la animación */
}

/* Escalonado (Stagger effect) más espaciado */
.service-card-wrapper:nth-child(1) { animation-delay: 0.1s; }
.service-card-wrapper:nth-child(2) { animation-delay: 0.2s; }
.service-card-wrapper:nth-child(3) { animation-delay: 0.3s; }
.service-card-wrapper:nth-child(4) { animation-delay: 0.4s; }
.service-card-wrapper:nth-child(5) { animation-delay: 0.5s; }
.service-card-wrapper:nth-child(6) { animation-delay: 0.6s; }

/* --- ANIMACIÓN DE ENTRADA ULTRA-SUTIL --- */

@keyframes fadeInUpSutil {
  from {
    opacity: 0;
    /* Desplazamiento mínimo para un efecto elegante */
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.service-card-wrapper {
  /* Mantenemos una duración calmada pero con un movimiento muy corto */
  animation: fadeInUpSutil 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  opacity: 0;
}

/* Escalonado muy breve para no retrasar la percepción de carga */
.service-card-wrapper:nth-child(1) { animation-delay: 0.05s; }
.service-card-wrapper:nth-child(2) { animation-delay: 0.10s; }
.service-card-wrapper:nth-child(3) { animation-delay: 0.15s; }
.service-card-wrapper:nth-child(4) { animation-delay: 0.20s; }
.service-card-wrapper:nth-child(5) { animation-delay: 0.25s; }
.service-card-wrapper:nth-child(6) { animation-delay: 0.30s; }

/* --- SKELETON LOADING --- */
.skeleton-card {
  height: 120px;
  background: #f6f7f8;
  background-image: linear-gradient(to right, #f6f7f8 0%, #edeef1 20%, #f6f7f8 40%, #f6f7f8 100%);
  background-repeat: no-repeat;
  background-size: 800px 100%;
  display: inline-block;
  position: relative;
  animation: skeletonShimmer 1.5s linear infinite forwards;
  border-radius: 8px;
  border: 1px solid #e1e1e1;
}

@keyframes skeletonShimmer {
  0% { background-position: -468px 0; }
  100% { background-position: 468px 0; }
}

/* --- BOTÓN VOLVER ARRIBA (FIXED) --- */
.scroll-to-top {
  position: fixed; /* Esto es vital para que flote */
  bottom: 30px;    /* Distancia desde abajo */
  right: 30px;     /* Distancia desde la derecha */
  width: 50px;
  height: 50px;
  background-color: #000000; /* Puedes cambiarlo por tu color corporativo */
  color: #ffffff;
  border: none;
  border-radius: 50%; /* Lo hace redondo */
  cursor: pointer;
  z-index: 9999;     /* Para que esté por encima de todo */
  
  /* Flexbox para centrar la flecha */
  display: none;     /* El JS se encarga de cambiarlo a 'flex' al hacer scroll */
  align-items: center;
  justify-content: center;
  
  /* Sombra elegante */
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease;
}

.scroll-to-top:hover {
  background-color: #333333;
  transform: translateY(-5px); /* Pequeño salto al pasar el ratón */
}

.scroll-to-top i {
  font-size: 20px;
}

/* Ajuste para móviles */
@media (max-width: 767px) {
  .scroll-to-top {
    bottom: 20px;
    right: 20px;
    width: 45px;
    height: 45px;
  }
}

/* --- BOTÓN VOLVER ARRIBA (AJUSTADO) --- */
.scroll-to-top {
  position: fixed !important;
  bottom: 30px !important;
  right: 30px !important;
  width: 50px !important;
  height: 50px !important;
  background-color: #000000 !important; /* Color negro */
  color: #ffffff !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  z-index: 999999 !important; /* Por encima de todo */
  display: none; /* Controlado por JS */
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
  transition: all 0.3s ease;
}

.scroll-to-top i {
  font-size: 20px !important;
  color: #ffffff !important;
}

.scroll-to-top:hover {
  background-color: #333333 !important;
  transform: translateY(-5px) !important;
}


/* --- BOTÓN VOLVER ARRIBA (AJUSTADO PARA NO CHOCAR CON CHATBOT) --- */
.scroll-to-top {
  position: fixed !important;
  bottom: 30px !important;
  /* CAMBIO: Lo movemos a la izquierda para que no lo tape el chatbot */
  left: 30px !important; 
  right: auto !important; 
  
  width: 50px !important;
  height: 50px !important;
  background-color: #000000 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  z-index: 999999 !important;
  display: none; /* Controlado por JS */
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
  transition: all 0.3s ease;
}

.scroll-to-top i {
  font-size: 20px !important;
  color: #ffffff !important;
}

.scroll-to-top:hover {
  background-color: #333333 !important;
  transform: translateY(-5px) !important;
}

/* Ajuste para móviles: un poco más pequeño para no estorbar */
@media (max-width: 767px) {
  .scroll-to-top {
    bottom: 20px !important;
    left: 20px !important;
    width: 45px !important;
    height: 45px !important;
  }
}

/* --- BOTÓN VOLVER ARRIBA (ENCIMA DEL CHATBOT) --- */
.scroll-to-top {
  position: fixed !important;
  /* Lo subimos lo suficiente para que el chatbot respire debajo */
  bottom: 110px !important; 
  right: 25px !important; 
  left: auto !important;

  width: 45px !important; /* Un poco más pequeño para que sea elegante */
  height: 45px !important;
  background-color: #000000 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  z-index: 999999 !important;
  
  display: none; /* Controlado por JS */
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.scroll-to-top i {
  font-size: 18px !important;
  color: #ffffff !important;
}

.scroll-to-top:hover {
  background-color: #333333 !important;
  transform: translateY(-5px) !important;
}

/* Ajuste para móviles para que no sature la pantalla */
@media (max-width: 767px) {
  .scroll-to-top {
    bottom: 95px !important;
    right: 20px !important;
    width: 40px !important;
    height: 40px !important;
  }
}

/* --- BOTÓN VOLVER ARRIBA (COLOR CORPORATIVO #002fbb) --- */
.scroll-to-top {
  position: fixed !important;
  bottom: 110px !important; 
  right: 25px !important; 
  left: auto !important;

  width: 45px !important;
  height: 45px !important;
  /* Aplicamos tu color de marca */
  background-color: #002fbb !important; 
  color: #ffffff !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  z-index: 999999 !important;
  
  display: none; 
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.scroll-to-top i {
  font-size: 18px !important;
  color: #ffffff !important;
}

.scroll-to-top:hover {
  /* Un azul un poco más oscuro para el efecto de pulsado */
  background-color: #001f7a !important; 
  transform: translateY(-5px) !important;
}

/* Ajuste para móviles */
@media (max-width: 767px) {
  .scroll-to-top {
    bottom: 95px !important;
    right: 20px !important;
    width: 40px !important;
    height: 40px !important;
  }
}

/* --- CONTENEDOR DE ACCIONES UNIFICADO --- */
.card-actions.unificada {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  align-items: center;
  gap: 6px; /* Espacio pequeño entre etiquetas */
  z-index: 10;
  flex-wrap: nowrap; /* Evita que se rompan en dos líneas */
}

/* Estilo Base para todos los Badges */
.service-badge {
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 4px;
  border: 1px solid transparent;
}

/* Colores de Badges de Estado */
.badge-nuevo { background-color: #e3f2fd; color: #1976d2; border-color: #bbdefb; }
.badge-popular { background-color: #fff3e0; color: #f57c00; border-color: #ffe0b2; }
.badge-averia { background-color: #ffebee; color: #d32f2f; border-color: #ffcdd2; }

/* Badge Específico "Sugerido" (Dorado/Premium) */
.badge-sugerido {
  background-color: #fff9c4; 
  color: #856404; 
  border-color: #ffeeba;
}
.badge-sugerido i {
  color: #fbc02d;
  font-size: 10px;
}

/* Botón de favorito de usuario (Estrella vacía/llena) */
.fav-btn {
  cursor: pointer;
  color: #ccc;
  font-size: 14px;
  padding: 2px 5px;
  transition: transform 0.2s;
}
.fav-btn.is-active { color: #fbc02d; }
.fav-btn:hover { transform: scale(1.2); }


/* 1. Aseguramos que la tarjeta ocupe todo el alto disponible y sea Flex */
.service-card {
  display: flex;
  flex-direction: column;
  height: 100%; /* Obliga a todas las tarjetas de la misma fila a medir lo mismo */
  text-decoration: none;
  position: relative;
  /* ... tus otros estilos de borde, fondo, etc ... */
}

/* 2. El contenedor de contenido también debe ser Flex */
.service-content {
  display: flex;
  flex-direction: column;
  flex-grow: 1; /* Esto hace que esta sección rellene el espacio vacío */
}

/* 3. La descripción "empuja" al botón hacia abajo */
.service-description {
  margin-bottom: 20px; /* Espacio mínimo entre texto y botón */
  flex-grow: 1;        /* ESTA ES LA CLAVE: ocupa todo el espacio sobrante */
}

/* 4. Alineamos el botón a la izquierda (por defecto ya suele estarlo) */
.service-action {
  align-self: flex-start; /* Asegura que el botón se quede a la izquierda */
  margin-top: auto;       /* Refuerza que siempre se apoye en la base */
}

/* Contenedor del contenido para asegurar la alineación */
.service-content {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.service-description {
  flex-grow: 1; /* Empuja el botón hacia abajo */
  margin-bottom: 20px;
  color: #555;
  line-height: 1.5;
}

/* El nuevo botón "Solicitar" */
.service-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #0072ef; /* Azul corporativo vibrante */
  color: #ffffff !important;
  padding: 10px 20px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 14px;
  transition: all 0.3s ease;
  border: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  align-self: flex-start; /* Alineado a la izquierda */
  text-decoration: none !important;
}

/* Efecto al pasar el ratón (Hover) */
.service-card:hover .service-action {
  background-color: #0056b3;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  transform: translateY(-2px); /* Pequeño salto hacia arriba */
}


.service-action {
  align-self: stretch; /* En lugar de flex-start, para que ocupe todo el ancho */
  text-align: center;  /* Centra el texto dentro del botón largo */
  margin: 0 -20px -20px -20px; /* Opcional: para que el botón toque los bordes de la tarjeta */
  border-radius: 0 0 8px 8px;  /* Redondea solo las esquinas de abajo */
}

/* Estilos para el botón de ancho completo elegante y sutil */
.service-action {
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* Color de fondo difuminado (Azul pastel suave) */
  background-color: #f0f4f8; 
  /* Texto en un azul oscuro para buen contraste y accesibilidad */
  color: #2c5282 !important; 
  
  padding: 12px 20px;
  
  /* Ancho completo ajustado a los bordes de la tarjeta */
  align-self: stretch; 
  margin: auto -20px -20px -20px; 
  
  /* Redondeamos solo las esquinas inferiores para encajar en la tarjeta */
  border-radius: 0 0 8px 8px; 
  
  font-weight: 600;
  font-size: 14px;
  text-decoration: none !important;
  transition: all 0.3s ease;
  border-top: 1px solid #e2e8f0; /* Una fina línea para separar de la descripción */
}

/* Efecto al pasar el ratón: un poco más de intensidad pero sin saturar */
.service-card:hover .service-action {
  background-color: #e2e8f0; /* Se oscurece ligeramente */
  color: #1a365d !important;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,0.05); /* Sutil relieve interno */
}


/* Tarjeta principal como contenedor Flex */
.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
  text-decoration: none;
  overflow: hidden; /* Importante para las esquinas del botón */
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* Contenido intermedio */
.service-content {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 20px; /* Ajusta según tu diseño */
}

.service-description {
  flex-grow: 1; /* Empuja el botón al fondo */
  margin-bottom: 20px;
  font-size: 14px;
  color: #64748b;
}

/* El botón de pie de página (Ancho Completo Pastel) */
.service-action {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f8fafc; /* Azul/Gris muy tenue */
  color: #334155 !important; /* Texto oscuro para legibilidad */
  padding: 14px;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-top: 1px solid #f1f5f9;
  transition: all 0.3s ease;
  margin-top: auto; /* Anclado abajo */
}

.service-card:hover .service-action {
  background-color: #edf2f7; /* Un poco más oscuro al pasar el ratón */
  color: #2d3748 !important;
}

/* Flecha decorativa sutil vía CSS 
.service-action::after {
  content: '\f178';
  font-family: FontAwesome;
  margin-left: 8px;
  transition: transform 0.3s ease;
}


.service-card:hover .service-action::after {
  transform: translateX(4px);
}
*/

/* El botón de pie de página: ahora más visible pero elegante */
.service-action {
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* Color de fondo: Azul acero suave (más visible que el anterior) */
  background-color: #5c7f9a; 
  /* Texto en blanco para máximo contraste y accesibilidad */
  color: #ffffff !important; 
  
  padding: 14px;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  border-top: 1px solid rgba(0,0,0,0.05);
  transition: all 0.3s ease;
  margin-top: auto; 
  text-decoration: none !important;
}

/* Efecto al pasar el ratón: un poco más oscuro para confirmar el clic */
.service-card:hover .service-action {
  background-color: #4a667d; 
  color: #ffffff !important;
}


/* Contenedor del mensaje de 'No hay resultados' */
.no-results {
  grid-column: 1 / -1; /* Ocupa todo el ancho si usas grid */
  text-align: center;
  padding: 60px 20px;
  background-color: #f8fafc; /* El mismo tono pastel sutil de los botones */
  border-radius: 12px;
  border: 2px dashed #e2e8f0; /* Un borde discontinuo da sensación de vacío */
  color: #64748b;
  font-size: 16px;
  margin: 20px 0;
}

/* Opcional: Añadir un icono de lupa triste o vacía vía CSS */
.no-results::before {
  content: '\f002'; /* Icono de lupa de FontAwesome */
  font-family: FontAwesome;
  display: block;
  font-size: 40px;
  margin-bottom: 15px;
  color: #cbd5e1;
}




.service-card {
  border: 1px solid #e2e8f0;
  overflow: hidden; /* Esto es vital para que el botón azul tape las esquinas de abajo */
}


/* 1. La Tarjeta: Asegúrate de que NO tenga padding */
.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 12px; /* Aumentamos un poco el radio para que se note el recorte */
  overflow: hidden;    /* ESTO debe recortar al hijo (.service-action) */
  padding: 0 !important; /* IMPORTANTE: Si la tarjeta tiene padding, el botón no llega al borde */
  transition: transform 0.3s ease;
}

/* 2. El Contenido: Aquí es donde va el espacio para el texto */
.service-content {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 20px; /* El espacio del texto se da aquí, no en la tarjeta */
}

/* 3. El Botón: Azul más claro y ajustado */
.service-action {
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* Azul claro suave pero bien visible */
  background-color: #7aa2c1; 
  color: #ffffff !important;
  
  padding: 15px;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  
  /* Quitamos cualquier margen que pueda sobrar */
  margin: 0; 
  width: 100%;
  border: none;
  
  transition: background-color 0.3s ease;
  
  margin-top: auto;
  border-bottom-left-radius: inherit;  /* Hereda el redondeo de la tarjeta */
  border-bottom-right-radius: inherit; /* Hereda el redondeo de la tarjeta */
}

/* Efecto hover */
.service-card:hover .service-action {
  background-color: #6389a8; /* Oscurece un pelín al pasar el ratón */
}


/* 1. La tarjeta: Limpia y sin padding para que el botón pueda tocar los bordes */
.service-card-wrapper {
  position: relative; /* Para que los badges se posicionen bien */
}

.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden; /* Esto recortará las esquinas del botón abajo */
  padding: 0 !important; /* Quitamos el padding de aquí */
}

/* 2. El encabezado (Icono + Nombre): Aquí devolvemos el padding */
.card-header-flex {
  padding: 20px 20px 0 20px; /* Arriba, Derecha, Abajo(0), Izquierda */
  display: flex;
  align-items: center;
  gap: 12px;
}

/* 3. El contenido (Descripción): También con su padding */
.service-content {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 10px 20px 20px 20px; /* Ajustamos para que no se pegue al header */
}

/* 4. Los Badges: Los bajamos un poco para que no se peguen al borde ahora que no hay padding */
.card-actions.unificada {
  position: absolute;
  top: 15px; /* Un poco más de margen desde arriba */
  right: 15px;
  z-index: 10;
  display: flex;
  gap: 5px;
}

/* 5. El Botón: Azul claro y tocando bordes */
.service-action {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #9abfd8; /* Un azul cielo suave y elegante */
  color: #ffffff !important;
  padding: 15px;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  margin-top: auto; /* Empuja el botón al final */
  border: none;
  width: 100%;
}

.service-card:hover .service-action {
  background-color: #89adc6;
}

.service-name {
  padding-right: 60px; /* Deja espacio para que los badges no tapen el texto */
}

/* 1. La tarjeta: Limpia y con recorte */
.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden; /* Esto recortará el botón abajo */
  padding: 0 !important; 
  position: relative;
}

/* 2. Contenedor superior para Badges y Estrellas */
/* Lo hacemos Flex para que los badges ocupen su sitio y no floten sobre el texto */
.card-actions.unificada {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 15px 20px 0 20px; /* Margen superior y laterales */
  justify-content: flex-start; /* Se alinean a la izquierda/inicio */
}

/* 3. El encabezado (Icono + Nombre) */
.card-header-flex {
  padding: 10px 20px; 
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.service-name {
  font-size: 16px;
  color: #1e293b;
  line-height: 1.3;
  /* Ya no necesita padding-right porque los badges están ARRIBA, no ENCIMA */
}

/* 4. El contenido (Descripción) */
.service-content {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 0 20px 20px 20px;
}

.service-description {
  flex-grow: 1;
  margin-bottom: 20px;
  color: #64748b;
}

/* 5. El Botón: Azul Cielo Claro */
.service-action {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #b2cedf; /* Un azul pastel más claro y limpio */
  color: #ffffff !important;
  padding: 15px;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  border: none;
  width: 100%;
  margin: 0;
}

.service-card:hover .service-action {
  background-color: #9abfd8;
}

/* Restauramos el padding de la tarjeta para que respire */
.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20px !important; /* Volvemos al espacio original */
  text-decoration: none;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  position: relative;
}

/* Los badges vuelven a su esquina superior derecha sin molestar */
.card-actions.unificada {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
  display: flex;
  gap: 5px;
}

/* La descripción sigue empujando el botón hacia abajo */
.service-description {
  flex-grow: 1;
  margin-bottom: 20px;
  color: #64748b;
}

/* El botón vuelve a su estilo de "píldora" a la izquierda */
.service-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start; /* Alineado a la izquierda */
  
  background-color: #b2cedf; /* El azul claro que elegimos */
  color: #ffffff !important;
  
  padding: 8px 18px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 13px;
  transition: all 0.3s ease;
}

.service-card:hover .service-action {
  background-color: #9abfd8;
  transform: translateY(-2px);
}


/* Contenedor del icono y el nombre */
.card-header-flex {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  /* Reservamos 70px a la derecha para que el texto NUNCA toque los badges */
  padding-right: 70px; 
  margin-bottom: 10px;
}

.service-name {
  font-size: 15px;
  font-weight: 700;
  color: #1e293b;
  line-height: 1.3;
  display: block;
}

/* Aseguramos que los badges tengan espacio suficiente */
.card-actions.unificada {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  display: flex;
  gap: 6px;
  /* Forzamos que los badges no crezcan hacia la izquierda infinitamente */
  max-width: 80px; 
  justify-content: flex-end;
  flex-wrap: wrap;
}

.service-action {
  display: inline-flex;
  align-self: flex-start;
  background-color: #b2cedf; /* Tu azul claro */
  color: #ffffff !important;
  padding: 8px 20px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  margin-top: auto; /* Mantiene el botón abajo */
}



/* 1. La tarjeta: ahora con Flex normal para controlar el orden vertical */
.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 15px 20px 20px 20px !important;
  text-decoration: none;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}

/* 2. Contenedor de Badges: Una línea arriba a la derecha */
.card-actions.unificada {
  display: flex;
  flex-direction: row; /* Uno al lado del otro */
  justify-content: flex-end; /* Alineados a la derecha */
  align-items: center;
  gap: 8px;
  width: 100%;
  margin-bottom: 15px; /* Separación vertical con lo de abajo */
  min-height: 24px; /* Mantiene el espacio aunque no haya badges */
}

/* 3. Icono y Nombre: Ahora aparecen debajo de los badges */
.card-header-flex {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
  padding-right: 0; /* Ya no necesita el margen lateral porque están en líneas distintas */
}

.service-name {
  font-size: 16px;
  font-weight: 700;
  color: #1e293b;
  line-height: 1.3;
}

/* 4. El Botón Azul Claro: Estilo píldora a la izquierda */
.service-action {
  display: inline-flex;
  align-self: flex-start;
  background-color: #b2cedf; /* Azul claro suave */
  color: #ffffff !important;
  padding: 8px 18px;
  border-radius: 5px;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  margin-top: auto; /* Lo empuja al fondo de la tarjeta */
}

/* Contenedor de Badges: Forzamos línea única a la derecha */
.card-actions.unificada {
  display: flex !important;
  flex-direction: row !important; /* Forzamos horizontalidad */
  flex-wrap: nowrap !important;   /* Prohibimos que bajen a otra línea */
  justify-content: flex-end;      /* Todo a la derecha */
  align-items: center;
  gap: 8px;                       /* Espacio entre badges */
  width: 100%;
  margin-bottom: 20px;            /* Espacio vertical generoso con el nombre */
  padding: 0;
}

/* Aseguramos que los elementos internos no hereden anchos extraños */
.card-actions.unificada span, 
.card-actions.unificada div,
.card-actions.unificada i {
  display: inline-flex;
  white-space: nowrap; /* Evita que el texto del badge se rompa */
}

.service-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20px !important;
  text-decoration: none;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  align-items: stretch; /* Estira los contenedores internos al ancho total */
}

/* 1. Espaciado Vertical: Bajamos el icono y nombre respecto a los badges */
.card-header-flex {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 15px; /* Esto empuja el nombre hacia abajo separándolo de los badges */
  margin-bottom: 10px;
}

/* 2. Arreglo del Popover de Instrucciones (el icono "I") */
.info-icon-container {
  position: relative;
  display: inline-flex;
}

.instructions-popover {
  display: none; /* Forzamos que esté oculto por defecto */
  position: absolute;
  top: 110%; /* Aparece justo debajo del icono */
  right: 0;
  width: 250px; /* Ancho fijo para evitar el scroll horizontal */
  background: #2d3748; /* Color oscuro profesional */
  color: #fff;
  padding: 12px;
  border-radius: 6px;
  font-size: 12px;
  z-index: 100;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  white-space: normal; /* Permite que el texto salte de línea y no genere scroll */
}

/* Triangulito del popover */
.instructions-popover::after {
  content: "";
  position: absolute;
  bottom: 100%;
  right: 10px;
  border: 6px solid transparent;
  border-bottom-color: #2d3748;
}

/* Evitamos que el scroll de la tarjeta afecte al popover */
.service-card {
  overflow: visible !important; /* Si dejamos hidden, el popover se corta */
}


/* 1. Espaciado Vertical: Bajamos el icono y nombre 1cm aproximadamente */
.card-header-flex {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 40px !important; /* Aumentamos a ~1cm de separación real */
  margin-bottom: 15px;
  clear: both; /* Asegura que no haya interferencias con floats */
}

/* 2. Contenedor de Badges: Liberamos el ancho */
.card-actions.unificada {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important; /* Evita que se amontonen en varias filas */
  justify-content: flex-end;
  align-items: center;
  gap: 10px; /* Más espacio entre iconos */
  width: 100%;
  margin-bottom: 0; 
  padding: 0;
  /* Eliminamos cualquier max-width que pudiera estar comprimiendo los iconos */
  max-width: none !important; 
}

/* 3. Asegurar que los Badges y la Estrella mantengan su forma */
.service-badge, 
.fav-btn, 
.info-icon-container {
  flex-shrink: 0 !important; /* PROHIBE que el contenedor los achate */
  white-space: nowrap !important; /* Evita que el texto de los badges se corte */
  display: inline-flex;
  align-items: center;
}

/* Ajuste para que la estrella y la 'i' no se vean pequeñas */
.card-actions.unificada i {
  font-size: 16px;
  width: auto;
  height: auto;
}

.instructions-popover {
  min-width: 280px; /* Suficiente para que el texto respire */
  max-width: 350px;
  white-space: normal !important; /* Permite saltos de línea para que no haya scroll horizontal */
  word-wrap: break-word;
  overflow-x: hidden; /* Elimina definitivamente la barra de scroll horizontal */
}



/* 1. Reducir espacio debajo del nombre */
.card-header-flex {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 40px !important; /* Mantenemos el "1cm" de separación con los badges */
  margin-bottom: 5px !important; /* Reducimos drásticamente el espacio inferior */
}

/* 2. Ajustar el contenedor de la descripción */
.service-content {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 0 20px 15px 20px !important; /* Quitamos padding superior para que suba */
}

/* 3. Pegar la descripción al nombre */
.service-description {
  margin-top: 0 !important;
  margin-bottom: 15px; /* Espacio antes del botón solicitar */
  line-height: 1.4;
  font-size: 14px;
  color: #64748b;
}

.card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  margin-bottom: 0;
}

/* Contenedor principal de la línea superior */
.card-actions.unificada {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between; /* ESTO separa los grupos: uno a cada lado */
  align-items: center;
  width: 100%;
  margin-bottom: 0;
  padding: 0;
}

/* Color personalizado para el botón SOLICITAR */
.service-action {
  background-color: #0072BA !important; /* El azul solicitado */
  color: #ffffff !important;
  padding: 8px 20px !important;
  border-radius: 4px !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  font-size: 12px;
  display: inline-flex;
  align-self: flex-start;
  margin-top: auto;
  border: none;
  transition: background-color 0.2s ease;
}

/* Efecto al pasar el ratón (un poco más oscuro para que se note la interacción) */
.service-card:hover .service-action {
  background-color: #005a92 !important; 
  text-decoration: none !important;
  color: #ffffff !important;
}

/* 1. Recortamos el margen inferior de la tarjeta al mínimo */
.service-card {
    padding-bottom: 10px !important; /* Bajamos de 20px a 10px */
}

/* 2. Eliminamos cualquier margen que el botón pueda tener debajo */
.service-action {
    margin-bottom: 0 !important;
    margin-top: auto !important; /* Esto sigue asegurando que el botón se vaya al fondo */
}

/* 3. Si tienes un contenedor intermedio para el contenido, también lo ajustamos */
.service-content {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Ajuste específico para Vista Lista si fuera necesario */
.services-grid.list-mode .service-card {
    padding-bottom: 8px !important;
}

.service-name {
    /* Color gris oscuro sofisticado en lugar de negro puro */
    color: #2D3748 !important; 
    
    /* Fuente un poco más gruesa pero no pesada */
    font-weight: 700 !important;
    
    /* Tamaño equilibrado */
    font-size: 17px !important;
    
    /* Espaciado entre letras sutil para mayor legibilidad */
    letter-spacing: -0.02em !important;
    
    /* Altura de línea para que respire */
    line-height: 1.2 !important;
    
    margin: 0 !important;
    transition: color 0.3s ease;
}

/* Efecto al pasar el ratón sobre la tarjeta */
.service-card:hover .service-name {
    color: #0072BA !important; /* Cambia al azul de tu botón al hacer hover */
}

.card-header-flex {
    display: flex !important;
    align-items: center !important; /* Centrado vertical perfecto */
    gap: 12px !important;
}

.card-icon i {
    color: #0072BA; /* El icono también en tu azul corporativo */
    font-size: 20px;
}

/* Título de la Categoría */
.category-title, 
.home-categories h2 {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #1A202C !important; /* Un tono casi negro muy sólido */
    letter-spacing: -0.03em !important;
    margin-bottom: 25px !important;
    margin-top: 40px !important;
    display: flex;
    align-items: center;
    gap: 15px;
}

/* Línea decorativa elegante al lado del nombre */
.category-title::after,
.home-categories h2::after {
    content: "";
    flex: 1; /* Hace que la línea rellene el espacio restante */
    height: 1px;
    background: linear-gradient(to right, #e2e8f0, transparent);
    margin-left: 10px;
}

/* Opcional: Si quieres un toque de tu azul corporativo */
.category-title::before,
.home-categories h2::before {
    content: "";
    width: 4px;
    height: 24px;
    background-color: #0072BA; /* Tu azul */
    border-radius: 4px;
}

/* TÍTULO DE LAS CATEGORÍAS */
.category-title, 
.home-categories h2,
.section-title {
    color: #0072BA !important;    /* Tu azul corporativo */
    font-weight: 500 !important;    /* Peso medio: mucho más ligero y elegante que la negrita dura */
    font-size: 26px !important;     /* Tamaño prominente pero refinado */
    letter-spacing: -0.02em !important;
    margin-bottom: 30px !important;
    margin-top: 45px !important;
    text-transform: none !important; /* Mantiene mayúsculas/minúsculas naturales */
    display: flex;
    align-items: center;
}

/* Opcional: Si quieres una línea fina que acompañe al título para que sea aún más elegante */
.category-title::after, 
.home-categories h2::after {
    content: "";
    height: 1px;
    background: #e2e8f0; /* Gris muy clarito */
    flex-grow: 1;
    margin-left: 20px;
}

/* Estilo para los servicios obligatorios dentro de categorías */
.is-featured-duplicate {
    opacity: 0.85; /* Un pelín más claro para diferenciarlo */
}

/* Estilos agresivos para forzar la visibilidad */
.service-card.is-featured-duplicate {
    background-color: #f9f9f9 !important;
    border: 1px dashed #bbb !important;
    opacity: 0.8 !important;
    box-shadow: inset 0 0 10px rgba(0,0,0,0.05) !important;
}

.featured-tag {
    background-color: #f1c40f !important; /* Amarillo vibrante */
    color: #000 !important;
    font-weight: bold !important;
    border: 1px solid #d4ac0d !important;
}

/* Colores de badges dinámicos */
.service-badge {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: bold;
    text-transform: uppercase;
    color: #fff !important;
}
.status-badge_nuevo { background-color: #27ae60 !important; }
.status-badge_popular { background-color: #2980b9 !important; }
.status-badge_averia { background-color: #e74c3c !important; }
.status-badge_sugerido { background-color: #7f8c8d !important; }
.featured-tag { background-color: #f1c40f !important; color: #000 !important; }

/* Clase de tarjeta sugerida en categoría */
.service-card.is-featured-duplicate {
    background-color: #f9f9f9 !important;
    border: 1px dashed #bbb !important;
    opacity: 0.85 !important;
}

/* 1. Contenedor de los badges: usamos Flex para alinearlos y separarlos */
.badges-group {
    display: flex;
    flex-wrap: wrap; /* Por si hay muchos, que bajen a la siguiente línea */
    gap: 6px;       /* Esta es la clave: separa los elementos 6px entre sí */
    align-items: center;
}

/* 2. Refuerzo opcional: margen derecho por si el navegador es antiguo */
.service-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: bold;
    text-transform: uppercase;
    color: #fff !important;
    margin-right: 2px; /* Espacio extra de seguridad */
    white-space: nowrap; /* Evita que el texto del badge se parta */
}


/* 1. Separación de badges (ya corregido, lo mantengo aquí) */
.badges-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

/* 2. Estilo Notorio para Duplicados Sugeridos */
/* Usamos el selector de cadena para máxima prioridad */
.services-grid .service-card.is-featured-duplicate {
    background-color: #f4f6f7 !important; /* Gris muy claro para diferenciar el fondo */
    border: 1.5px dashed #bcc6cc !important; /* Borde discontinuo gris azulado */
    opacity: 0.9 !important;
    box-shadow: none !important; /* Quitamos la sombra exterior si tuviera */
    transform: scale(0.98); /* Lo hacemos un 2% más pequeño para dar sensación de "secundario" */
    transition: all 0.2s ease;
}

.services-grid .service-card.is-featured-duplicate:hover {
    opacity: 1 !important;
    transform: scale(1);
    background-color: #ffffff !important;
    border-style: solid !important; /* Al pasar el ratón, vuelve a ser sólido */
}

/* 3. Badge Sugerido con efecto de relieve */
.featured-tag {
    background-color: #f1c40f !important;
    color: #000 !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    border: 1px solid #d4ac0d !important;
}

.catalog-main-title {
  font-size: 28px;
  margin-bottom: 8px;
  color: #333;
}
.catalog-main-description {
  font-size: 16px;
  color: #666;
  margin-bottom: 24px;
}

/* Contenedor del input de búsqueda */
#catalog-search-container {
  display: flex;
  justify-content: flex-end; /* Alinea el contenido a la derecha */
  width: 100%;
  margin-top: 15px;          /* Espacio respecto a la descripción superior */
  margin-bottom: 25px;       /* Espacio respecto a las tarjetas de abajo */
}

/* Opcional: Ajustar el ancho del buscador si se ve demasiado largo */
#catalog-search-input {
  max-width: 400px;
  width: 100%;
}

/* El contenedor que envuelve a ambos */
.main-catalog-wrapper {
  display: flex;
  flex-direction: column; /* Apila uno sobre otro */
}

/* Forzamos que el catálogo (con el título) sea el primero visualmente */
#dynamic-service-catalog {
  order: 1; 
}

/* Forzamos que el buscador sea el segundo */
#catalog-search-container {
  order: 2;
  display: flex;
  justify-content: flex-end; /* Alineado a la derecha */
  margin-top: 10px;          /* Espacio tras la descripción */
  margin-bottom: 25px;       /* Espacio antes de las tarjetas */
}

#catalog-search-container {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}
.catalog-search-wrapper {
  margin-left: auto; /* Empuja todo el bloque a la derecha si es necesario */
  max-width: 400px;
}

/* Espaciado y estilo del buscador en su nueva posición */
.catalog-search-wrapper {
  margin-top: 10px !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05); /* Sutil sombra para darle cuerpo */
  border-radius: 4px;
}

#catalog-search-input {
  height: 45px;
  font-size: 16px;
}

/* no va del todo
.service-catalog-hero {
    background-image: url(/hc/theming_assets/01KE0GDDJECDS5TT6JACJSW3Q8);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

*/

<i class="fa fa-wrench" aria-hidden="true"></i>