/* ============================================================================
   Moval theme for Dashy
   ----------------------------------------------------------------------------
   Brand source of truth: docs/brand/moval-brand-manual-v1.pdf

   Tokens applied:
     - Verde Moval            #1E4C3D   (primary, naturaleza + agua)
     - Verde Transformación   #018264   (intermedio, evolución/tecnología)
     - Cerceta                #209F76   (gradiente support)
     - Amarillo Brío          #FFBC15   (energía, contraste cálido)
     - Arena                  #EBDAAD   (paleta secundaria)
     - Naranja                #F2A743   (paleta secundaria)
     - Granada                #A10301   (paleta secundaria)
     - Blanco roto            #F1F1F1   (fondo cálido)
     - Tipografía             Inter (Helvetica / Arial fallback)

   Reglas aplicadas (manual §6.3, §7, §9):
     - Alineación a la izquierda.
     - Contraste claro de pesos y tamaños.
     - Estados hover con tinte 20% del color.
     - Texto oscuro sobre fondos claros.
     - Degradados corporativos para cabeceras/acentos, sin sacrificar
       legibilidad.
     - Sin sobrecargar portadas, sin mezclar demasiados secundarios.
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  /* ----- Brand tokens (manual §5) ----- */
  --moval-green:        #1E4C3D;   /* Verde Moval      */
  --moval-green-2:      #018264;   /* Verde Transform. */
  --moval-cerceta:      #209F76;   /* Cerceta          */
  --moval-yellow:       #FFBC15;   /* Amarillo Brío    */
  --moval-sand:         #EBDAAD;   /* Arena            */
  --moval-orange:       #F2A743;   /* Naranja          */
  --moval-granada:      #A10301;   /* Granada          */
  --moval-offwhite:     #F1F1F1;   /* Blanco roto      */
  --moval-ink:          #23342F;   /* Texto principal  */

  /* ----- Semantic tokens ----- */
  --moval-card:         #FFFDFC;
  --moval-card-2:       #F8F5EC;
  --moval-line:         rgba(30, 76, 61, 0.16);
  --moval-line-soft:    rgba(30, 76, 61, 0.08);
  --moval-shadow:       0 14px 34px rgba(30, 76, 61, 0.10);
  --moval-shadow-soft:  0 6px 16px rgba(30, 76, 61, 0.06);
  --moval-logo-url: url("https://odoo.moval.es/web/image/website/1/logo/Soporte%20Moval?unique=6db8c1a");

  /* ----- Dashy variable bridge (mantener compat con temas base) ----- */
  --primary:                            var(--moval-green);
  --primary-color:                      var(--moval-green-2);
  --background:                         var(--moval-offwhite);
  --background-darker:                  #FFFFFF;
  --curve-factor:                       20px;
  --dimming-factor:                     0.96;

  --heading-text-color:                 var(--moval-green);
  --nav-link-text-color:                var(--moval-green);
  --nav-link-background-color:          #FFFFFF;
  --nav-link-text-color-hover:          var(--moval-green);
  --nav-link-background-color-hover:    rgba(255, 188, 21, 0.20);
  --nav-link-border-color:              rgba(1, 130, 100, 0.18);
  --nav-link-border-color-hover:        var(--moval-green-2);

  --search-container-background:        rgba(255, 253, 252, 0.98);
  --search-field-background:           #FFFFFF;
  --settings-background:                #FFFFFF;
  --settings-text-color:                var(--moval-green);

  --footer-text-color:                  var(--moval-green);
  --footer-text-color-link:             var(--moval-green-2);

  --item-text-color:                    var(--moval-ink);
  --item-group-outer-background:        transparent;
  --item-group-background:              var(--moval-card);
  --item-group-heading-text-color:      #FFFFFF;
  --item-group-heading-text-color-hover:#FFFFFF;

  --config-code-background:             #FFFFFF;
  --config-code-color:                  var(--moval-ink);
  --config-settings-color:              var(--moval-ink);
  --config-settings-background:         #FFFFFF;

  --scroll-bar-color:                  var(--moval-green-2);
  --scroll-bar-background:             rgba(235, 218, 173, 0.55);
  --highlight-background:              var(--moval-yellow);
  --highlight-color:                   var(--moval-green);
  --toast-background:                  var(--moval-green);
  --toast-color:                       #FFFFFF;
  --welcome-popup-background:          rgba(255, 255, 255, 0.98);
  --welcome-popup-text-color:           var(--moval-green);
  --side-bar-background:               rgba(255, 253, 252, 0.95);
}

/* ============================================================================
   1. Tipografía (manual §6)
   ============================================================================ */

html,
body,
#app,
.home,
.dashboard-page,
.page-content,
input,
select,
textarea,
button,
.nav-item,
.settings-btn,
.option-btn,
header {
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
}

body {
  color: var(--moval-ink);
}

/* ============================================================================
   2. Fondos (manual §7.2, §9)
   - Fondo cálido blanco roto.
   - Degradados corporativos sutiles.
   ============================================================================ */

body {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 188, 21, 0.14), transparent 24%),
    radial-gradient(circle at 92% 8%,  rgba(1, 130, 100, 0.10),  transparent 26%),
    radial-gradient(circle at 50% 95%, rgba(30, 76, 61, 0.06),  transparent 30%),
    linear-gradient(180deg, #F8F5EC 0%, #F1F1F1 60%, #ECE6D7 100%) !important;
  background-attachment: fixed !important;
}

/* Pequeños acentos circulares (manual §7.4 — círculos deconstruidos) */
.page-content::before {
  content: '';
  position: fixed;
  top: -120px;
  right: -120px;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(1, 130, 100, 0.08), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.page-content::after {
  content: '';
  position: fixed;
  bottom: -160px;
  left: -120px;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 188, 21, 0.10), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* ============================================================================
   3. Header (manual §9 — verde institucional con acento amarillo)
   ============================================================================ */

header {
  position: sticky;
  top: 0;
  z-index: 30;
  background: rgba(248, 245, 236, 0.94) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--moval-line) !important;
  box-shadow: 0 10px 26px rgba(30, 76, 61, 0.06) !important;
}

/* Acento corporativo: barra tricolor inferior */
header::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4px;
  background: linear-gradient(90deg,
    var(--moval-green) 0%,
    var(--moval-green-2) 55%,
    var(--moval-yellow) 100%);
  opacity: 0.95;
}

/* ============================================================================
   4. Tipografía del header (alineación a la izquierda, contraste de pesos)
   ============================================================================ */

.page-titles h1 {
  color: var(--moval-green) !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em;
  margin-bottom: 0.05rem;
}

.page-titles,
#dashy .page-titles {
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  flex-wrap: nowrap !important;
}

.page-titles .text,
#dashy .page-titles .text {
  min-width: 0;
}

.page-titles .subtitle {
  color: rgba(35, 52, 47, 0.72) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  text-shadow: none !important;
}

.page-titles img.site-logo {
  margin-right: 1rem;
  padding: 0.45rem 0.75rem;
  width: 11rem !important;
  max-width: 11rem;
  max-height: 2.25rem;
  height: auto;
  flex: 0 0 auto;
  object-fit: contain;
  background: linear-gradient(135deg, var(--moval-green) 0%, var(--moval-green-2) 100%);
  border: 1px solid rgba(30, 76, 61, 0.12);
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(30, 76, 61, 0.10);
}

#dashy .page-titles img.site-logo {
  width: 11rem !important;
  max-width: none !important;
  min-width: 11rem !important;
  height: auto !important;
  max-height: 3.1rem !important;
}

/* ============================================================================
   5. Inputs, búsqueda, settings, modales (consistencia y estados hover)
   ============================================================================ */

.search-container,
.search-wrap,
.settings-container,
.modal-mask,
.modal-content,
.modal-dialog,
.context-menu {
  background: rgba(255, 253, 252, 0.96) !important;
  border: 1px solid var(--moval-line) !important;
  box-shadow: var(--moval-shadow) !important;
  backdrop-filter: blur(10px);
}

input,
select,
textarea {
  background: #FFFFFF !important;
  color: var(--moval-ink) !important;
  border: 1px solid rgba(30, 76, 61, 0.18) !important;
  box-shadow: none !important;
}

input:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--moval-green-2) !important;
  box-shadow: 0 0 0 3px rgba(1, 130, 100, 0.12) !important;
}

/* ============================================================================
   6. Nav items y botones del header (estado neutro + hover amarillo brío)
   ============================================================================ */

.nav-item,
header button,
header select {
  color: var(--moval-green) !important;
  background: rgba(255, 255, 255, 0.95) !important;
  border: 1px solid rgba(1, 130, 100, 0.18) !important;
  border-radius: 999px !important;
  box-shadow: var(--moval-shadow-soft) !important;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}

.nav-item:hover,
.nav-item:focus-visible,
header button:hover,
header select:hover {
  background: rgba(255, 188, 21, 0.20) !important;
  border-color: var(--moval-green-2) !important;
  transform: translateY(-1px);
}

/* ============================================================================
   7. Section headers — gradiente verde MOVAL + acento amarillo
   ============================================================================ */

.item-group {
  background: var(--moval-card) !important;
  border: 1px solid var(--moval-line) !important;
  border-radius: 22px !important;
  box-shadow: 0 18px 40px rgba(30, 76, 61, 0.10) !important;
  overflow: hidden;
  margin-bottom: 1.4rem;
}

.item-group-header,
.item-group > h2,
.item-group .section-header {
  background: linear-gradient(135deg,
    var(--moval-green) 0%,
    var(--moval-green-2) 100%) !important;
  color: #FFFFFF !important;
  border-bottom: 3px solid rgba(255, 188, 21, 0.92) !important;
  box-shadow: none !important;
  padding: 0.85rem 1.1rem !important;
}

.item-group-header *,
.item-group > h2 *,
.item-group .section-header * {
  color: #FFFFFF !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em;
}

.item-group-header svg,
.item-group-header i,
.item-group > h2 svg,
.item-group > h2 i {
  color: rgba(255, 188, 21, 0.98) !important;
}

/* ============================================================================
   8. Item cards
   ============================================================================ */

.item {
  background: #FFFFFF !important;
  border: 1px solid rgba(1, 130, 100, 0.14) !important;
  border-radius: 18px !important;
  box-shadow: var(--moval-shadow-soft) !important;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.item:hover,
.item:focus,
.item:focus-within {
  transform: translateY(-2px);
  border-color: rgba(255, 188, 21, 0.86) !important;
  box-shadow: 0 16px 28px rgba(30, 76, 61, 0.10) !important;
}

.item,
.item *:not(svg):not(i) {
  color: var(--moval-ink) !important;
}

.item svg,
.item i {
  color: var(--moval-green-2) !important;
}

.item small,
.item p,
.item .description,
.item .subtitle,
.item span[class*='desc'] {
  color: rgba(35, 52, 47, 0.68) !important;
}

/* ============================================================================
   9. Links
   ============================================================================ */

a {
  color: var(--moval-green-2) !important;
  text-underline-offset: 0.16em;
}

a:hover {
  color: var(--moval-green) !important;
}

/* ============================================================================
   10. Footer
   ============================================================================ */

.footer,
footer {
  color: rgba(35, 52, 47, 0.76) !important;
}

/* ============================================================================
   11. Scrollbar corporativo
   ============================================================================ */

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-thumb {
  background: var(--moval-green-2);
  border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--moval-green);
}

::-webkit-scrollbar-track {
  background: rgba(235, 218, 173, 0.55);
}

/* ============================================================================
   12. Responsive
   ============================================================================ */

@media (max-width: 599px) {
  .page-titles img.site-logo {
    margin-right: 0;
    margin-bottom: 0.35rem;
  }
  header::after {
    height: 3px;
  }
}

/* ============================================================================
   13. Dashy 2.1.1 runtime overrides
   ----------------------------------------------------------------------------
   The live Dashy build uses a Vue-generated DOM rooted at #dashy with selectors
   such as .home, .settings-outer, .item-group-container, .lbl-toggle and
   .item-wrapper a.item. These overrides intentionally use stronger selectors
   to beat the built-in theme shipped by Dashy.
   ============================================================================ */

#dashy,
#dashy * {
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
}

#dashy .home {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 188, 21, 0.14), transparent 24%),
    radial-gradient(circle at 92% 8%, rgba(1, 130, 100, 0.10), transparent 26%),
    radial-gradient(circle at 50% 95%, rgba(30, 76, 61, 0.06), transparent 30%),
    linear-gradient(180deg, #F8F5EC 0%, #F1F1F1 60%, #ECE6D7 100%) !important;
  color: var(--moval-ink) !important;
}

#dashy header {
  display: none !important;
}

#dashy .page-titles,
#dashy .page-titles:link,
#dashy .page-titles:visited {
  display: none !important;
}

#dashy .page-titles h1 {
  color: var(--moval-green) !important;
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em !important;
}

#dashy .page-titles .subtitle {
  color: rgba(35, 52, 47, 0.72) !important;
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
}

#dashy .settings-outer {
  display: grid !important;
  grid-template-columns: 180px minmax(220px, 320px) minmax(0, 1fr);
  align-items: center !important;
  gap: 0.65rem !important;
  max-width: calc(100% - 2.5rem);
  margin: 0.75rem auto 0.85rem !important;
  padding: 0.3rem 0.65rem !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#dashy .settings-outer::before {
  content: '';
  display: block;
  width: 160px;
  height: 30px;
  background-image: var(--moval-logo-url);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: contain;
}

#dashy .settings-outer > button.has-tooltip {
  display: none !important;
}

#dashy form.normal {
  grid-column: 2;
  width: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.55rem !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#dashy form.normal > label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

#dashy .search-wrap {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 190px !important;
  height: 36px !important;
  min-height: 36px !important;
  position: relative !important;
  background: #FFFFFF !important;
  border: 1px solid var(--moval-line) !important;
  border-radius: 10px !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8), 0 2px 8px rgba(30, 76, 61, 0.04) !important;
  overflow: hidden !important;
}

#dashy .search-wrap::before {
  content: '';
  position: absolute;
  left: 0.8rem;
  top: 50%;
  width: 0.68rem;
  height: 0.68rem;
  border: 1.6px solid rgba(30, 76, 61, 0.42);
  border-radius: 999px;
  transform: translateY(-60%);
  pointer-events: none;
}

#dashy .search-wrap::after {
  content: '';
  position: absolute;
  left: 1.42rem;
  top: 58%;
  width: 0.45rem;
  height: 1.6px;
  background: rgba(30, 76, 61, 0.42);
  transform: rotate(45deg);
  transform-origin: left center;
  pointer-events: none;
}

#dashy .search-wrap input {
  width: calc(100% - 2.8rem) !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 0.7rem 0 2.15rem !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  line-height: 36px !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--moval-ink) !important;
  font-size: 0.85rem !important;
}

#dashy .options-outer {
  grid-column: 3;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  justify-content: flex-end !important;
}

#dashy .options-container {
  width: 100% !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 0.25rem 0.55rem !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: var(--moval-ink) !important;
  border: 0 !important;
  box-shadow: none !important;
}

#dashy .options-container > div,
#dashy .theme-selector-section,
#dashy .options-container .layout-selector,
#dashy .options-container .item-size-selector,
#dashy .options-container .config-buttons {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#dashy .theme-selector-section,
#dashy .color-button {
  display: none !important;
}

#dashy label,
#dashy .search-wrap label,
#dashy .theme-selector-section,
#dashy .options-container,
#dashy .options-container * {
  color: var(--moval-green) !important;
}

#dashy .options-container > div:not(.theme-selector-section) {
  display: flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  position: relative;
}

#dashy .options-container > div:not(.theme-selector-section) + div:not(.theme-selector-section) {
  margin-left: 0.25rem !important;
  padding-left: 0.75rem !important;
}

#dashy .options-container > div:not(.theme-selector-section) + div:not(.theme-selector-section)::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 1.55rem;
  background: rgba(30, 76, 61, 0.12);
  transform: translateY(-50%);
}

#dashy input,
#dashy select,
#dashy textarea,
#dashy button {
  background: #FFFFFF !important;
  color: var(--moval-ink) !important;
  border: 1px solid rgba(30, 76, 61, 0.18) !important;
}

#dashy .theme-label,
#dashy .options-container .text,
#dashy .options-label,
#dashy .config-label,
#dashy .options-container label,
#dashy .options-container span {
  color: var(--moval-green) !important;
}

#dashy .options-label,
#dashy .config-label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

#dashy .display-options,
#dashy .config-buttons {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.2rem !important;
  margin: 0 !important;
  padding: 0.1rem !important;
  background: rgba(255, 255, 255, 0.56) !important;
  border: 1px solid rgba(30, 76, 61, 0.08) !important;
  border-radius: 999px !important;
}

#dashy .theme-selector-section .vs__dropdown-toggle,
#dashy .options-container button,
#dashy .options-container select {
  min-height: 32px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(1, 130, 100, 0.18) !important;
  background: #FFFFFF !important;
  box-shadow: var(--moval-shadow-soft) !important;
}

#dashy .display-options svg,
#dashy .config-buttons svg,
#dashy .options-container button {
  width: 18px !important;
  height: 18px !important;
  padding: 6px !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  background: #FFFFFF !important;
  box-shadow: 0 1px 3px rgba(30, 76, 61, 0.05) !important;
  transition: background 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, transform 0.14s ease;
}

#dashy .display-options svg:hover,
#dashy .config-buttons svg:hover,
#dashy .options-container button:hover {
  background: rgba(255, 188, 21, 0.10) !important;
  border-color: rgba(1, 130, 100, 0.28) !important;
  box-shadow: 0 3px 8px rgba(30, 76, 61, 0.07) !important;
  transform: none !important;
}

#dashy .config-options {
  align-items: center !important;
}

#dashy .item-group-container {
  background: transparent !important;
}

#dashy .is-open.collapsable {
  background: var(--moval-card) !important;
  border: 1px solid var(--moval-line) !important;
  border-radius: 22px !important;
  box-shadow: 0 18px 40px rgba(30, 76, 61, 0.10) !important;
  overflow: hidden !important;
}

#dashy .lbl-toggle {
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
  background: linear-gradient(135deg, var(--moval-green) 0%, var(--moval-green-2) 100%) !important;
  color: #FFFFFF !important;
  border-bottom: 3px solid rgba(255, 188, 21, 0.92) !important;
  padding: 0.85rem 1.1rem !important;
}

#dashy .lbl-toggle,
#dashy .lbl-toggle *,
#dashy .lbl-toggle h3 {
  color: #FFFFFF !important;
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
  font-weight: 600 !important;
}

#dashy .lbl-toggle .mdi,
#dashy .lbl-toggle svg,
#dashy .lbl-toggle img {
  color: rgba(255, 188, 21, 0.98) !important;
  fill: rgba(255, 188, 21, 0.98) !important;
}

#dashy .content-inner,
#dashy .collapsible-content,
#dashy .there-are-items {
  background: transparent !important;
}

#dashy .item-wrapper a.item,
#dashy a.item {
  background: #FFFFFF !important;
  color: var(--moval-ink) !important;
  border: 1px solid rgba(1, 130, 100, 0.14) !important;
  border-radius: 18px !important;
  box-shadow: var(--moval-shadow-soft) !important;
}

#dashy .item-wrapper a.item:hover,
#dashy .item-wrapper a.item:focus,
#dashy .item-wrapper a.item:focus-within {
  background: #FFFFFF !important;
  border-color: rgba(255, 188, 21, 0.86) !important;
  box-shadow: 0 16px 28px rgba(30, 76, 61, 0.10) !important;
}

#dashy .item-wrapper a.item .text,
#dashy .item-wrapper a.item .tile-title,
#dashy .item-wrapper a.item .tile-title .text {
  color: var(--moval-ink) !important;
  font-weight: 600 !important;
}

#dashy .item-wrapper a.item .description,
#dashy .item-wrapper a.item p,
#dashy .item-wrapper a.item small {
  color: rgba(35, 52, 47, 0.68) !important;
  font-weight: 400 !important;
}

#dashy .item-wrapper a.item .tile-host-meta {
  display: block !important;
  margin-top: 0.12rem;
  color: rgba(30, 76, 61, 0.56) !important;
  font-size: 0.66rem !important;
  line-height: 1.2 !important;
  letter-spacing: 0.01em;
}

#dashy .item-wrapper a.item .item-icon,
#dashy .item-wrapper a.item .mdi,
#dashy .item-wrapper a.item svg,
#dashy .item-wrapper a.item i {
  color: var(--moval-green-2) !important;
  fill: var(--moval-green-2) !important;
}

@media (max-width: 1200px) {
  #dashy .settings-outer {
    grid-template-columns: 1fr !important;
  }

  #dashy .settings-outer::before {
    width: 150px;
    margin-bottom: 0.1rem;
  }

  #dashy form.normal,
  #dashy .options-outer {
    grid-column: auto;
  }

  #dashy .options-outer,
  #dashy .options-container {
    justify-content: flex-start !important;
  }
}

/* ============================================================================
   14. Dashy 4.2.4 repair layer
   ----------------------------------------------------------------------------
   Dashy 4 keeps a similar app structure, but section/card class names changed
   enough that the old 2.x overrides made headers invisible and cards too small.
   Keep these rules last: they intentionally neutralize the legacy selectors.
   ============================================================================ */

/* The global Inter override must not break icon fonts. */
#dashy i[class^="fa"],
#dashy i[class*=" fa-"],
#dashy .svg-inline--fa {
  font-family: "Font Awesome 5 Free", "Font Awesome 6 Free", FontAwesome, sans-serif !important;
  font-style: normal !important;
  font-weight: 900 !important;
  speak: never;
}

#dashy i.fab,
#dashy i[class*=" fab "],
#dashy i[class^="fab "] {
  font-family: "Font Awesome 5 Brands", "Font Awesome 6 Brands", FontAwesome, sans-serif !important;
  font-weight: 400 !important;
}

/* Top bar: keep it minimal and hide the floating options button. */
#dashy .settings-outer {
  grid-template-columns: 96px minmax(240px, 320px) 1fr !important;
  min-height: 44px !important;
  max-width: calc(100% - 1.25rem) !important;
  margin: 0.45rem auto 0.9rem !important;
  padding: 0.28rem 0.55rem !important;
  border-radius: 14px !important;
}

#dashy .settings-outer::before {
  width: 74px !important;
  height: 32px !important;
}

#dashy .settings-outer > button,
#dashy button[aria-label="Options"],
#dashy button[aria-label="Opciones"] {
  display: none !important;
}

/* Dashy 4 section cards. */
#dashy .is-open.collapsable,
#dashy .collapsable {
  width: min(1280px, calc(100vw - 3rem)) !important;
  max-width: min(1280px, calc(100vw - 3rem)) !important;
  min-height: 0 !important;
  margin: 1rem auto !important;
  padding: 0 !important;
  background: #FFFFFF !important;
  border: 1px solid rgba(30, 76, 61, 0.12) !important;
  border-radius: 18px !important;
  box-shadow: 0 12px 28px rgba(30, 76, 61, 0.08) !important;
  overflow: hidden !important;
}

#dashy .section-header {
  min-height: 48px !important;
  height: auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.65rem !important;
  padding: 0.65rem 0.95rem !important;
  background: linear-gradient(135deg, var(--moval-green) 0%, var(--moval-green-2) 100%) !important;
  border-bottom: 3px solid rgba(255, 188, 21, 0.88) !important;
  color: #FFFFFF !important;
}

#dashy .section-header h3 {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  color: #FFFFFF !important;
  font-size: 1rem !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

#dashy .section-header .section-icon,
#dashy .section-header .item-icon,
#dashy .section-header i,
#dashy .section-header svg,
#dashy .section-header .header-action,
#dashy .section-header .collapse-toggle,
#dashy .section-header .arrow {
  color: rgba(255, 255, 255, 0.95) !important;
  fill: rgba(255, 255, 255, 0.95) !important;
}

#dashy .section-header .section-icon {
  width: 30px !important;
  min-width: 30px !important;
  height: 30px !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  border-radius: 10px !important;
  background: rgba(255, 255, 255, 0.14) !important;
}

#dashy .section-header .section-icon i {
  font-size: 0.98rem !important;
}

#dashy .section-header .header-action {
  width: 16px !important;
  height: 16px !important;
  opacity: 0.75 !important;
}

#dashy .collapsible-content,
#dashy .content-inner,
#dashy .there-are-items {
  width: 100% !important;
  min-height: 0 !important;
  background: transparent !important;
}

#dashy .content-inner {
  padding: 1rem !important;
}

#dashy .there-are-items {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(185px, 1fr)) !important;
  gap: 0.75rem !important;
  align-items: stretch !important;
}

#dashy .item-wrapper,
#dashy .item-wrapper.wrap-size-medium,
#dashy .item-wrapper.span-1 {
  width: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
}

#dashy a.item,
#dashy .item-wrapper a.item,
#dashy a.item.size-medium {
  width: 100% !important;
  min-height: 96px !important;
  height: auto !important;
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  grid-template-areas: "icon text" !important;
  column-gap: 0.75rem !important;
  align-items: center !important;
  padding: 0.85rem 0.95rem !important;
  margin: 0 !important;
  border-radius: 14px !important;
  background: #FFFFFF !important;
  border: 1px solid rgba(1, 130, 100, 0.14) !important;
  box-shadow: 0 5px 14px rgba(30, 76, 61, 0.06) !important;
  overflow: hidden !important;
}

#dashy a.item:hover,
#dashy .item-wrapper a.item:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(255, 188, 21, 0.76) !important;
  box-shadow: 0 12px 24px rgba(30, 76, 61, 0.10) !important;
}

#dashy a.item .item-icon,
#dashy .item-wrapper a.item .item-icon {
  grid-area: icon !important;
  width: 42px !important;
  height: 42px !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  border-radius: 12px !important;
  background: rgba(1, 130, 100, 0.08) !important;
  color: var(--moval-green-2) !important;
}

#dashy a.item .item-icon i,
#dashy .item-wrapper a.item .item-icon i,
#dashy a.item .item-icon svg {
  color: var(--moval-green-2) !important;
  fill: var(--moval-green-2) !important;
  font-size: 1.25rem !important;
  margin: 0 !important;
}

#dashy a.item .tile-title,
#dashy .item-wrapper a.item .tile-title {
  grid-area: text !important;
  width: 100% !important;
  min-width: 0 !important;
  height: auto !important;
  max-height: none !important;
  display: block !important;
  overflow: visible !important;
  color: var(--moval-ink) !important;
}

#dashy a.item .tile-title .text,
#dashy .item-wrapper a.item .tile-title .text {
  display: block !important;
  color: var(--moval-ink) !important;
  font-size: 0.88rem !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

#dashy a.item .description,
#dashy .item-wrapper a.item .description {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  margin: 0.22rem 0 0 !important;
  color: rgba(35, 52, 47, 0.66) !important;
  font-size: 0.72rem !important;
  line-height: 1.25 !important;
  white-space: normal !important;
  overflow: hidden !important;
  text-overflow: unset !important;
}

#dashy a.item .tile-host-meta,
#dashy .item-wrapper a.item .tile-host-meta {
  display: block !important;
  margin-top: 0.22rem !important;
  color: rgba(30, 76, 61, 0.58) !important;
  font-size: 0.67rem !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Hide duplicate URL and opening glyph noise; keep status dots. */
#dashy a.item .item-url,
#dashy a.item .opening-method-icon {
  display: none !important;
}

/* Icon-fallback images (injected by the icon-fallback script in
   overrides/index.html when an <i class="fa-..."> doesn't render a glyph). */
#dashy a.item .item-icon .moval-fallback-icon,
#dashy a.item .item-icon img.moval-fallback-icon {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  min-height: 28px !important;
  max-width: 28px !important;
  max-height: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 6px !important;
  background: #FFFFFF !important;
  object-fit: contain !important;
  display: block !important;
  box-shadow: 0 1px 2px rgba(30, 76, 61, 0.10) !important;
}

#dashy a.item .item-icon:has(img.moval-fallback-icon) {
  background: #FFFFFF !important;
}

#dashy a.item .status-indicator,
#dashy a.item .indicator.status-indicator {
  position: absolute !important;
  top: 0.55rem !important;
  right: 0.55rem !important;
  z-index: 3 !important;
}

@media (max-width: 760px) {
  #dashy .settings-outer {
    grid-template-columns: 80px 1fr !important;
  }

  #dashy .there-are-items {
    grid-template-columns: 1fr !important;
  }
}

/* Final Dashy 4 layout hardening: beat component scoped layout classes. */
#dashy .home > .item-group-container,
#dashy .item-group-container.orientation-vertical,
#dashy .item-group-container {
  width: min(1080px, calc(100vw - 3rem)) !important;
  max-width: min(1080px, calc(100vw - 3rem)) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 1rem !important;
  margin: 0 auto 2rem !important;
  padding: 0 !important;
}

#dashy .item-group-container > .collapsable,
#dashy .item-group-container > .is-open.collapsable,
#dashy .item-group-container > div[class*="section_"] {
  flex: 0 0 auto !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  grid-column: 1 / -1 !important;
}

#dashy .item-group-container > .collapsable > .section-header,
#dashy .item-group-container > .is-open.collapsable > .section-header,
#dashy .collapsable .section-header {
  background-color: var(--moval-green) !important;
  background-image: linear-gradient(135deg, var(--moval-green) 0%, var(--moval-green-2) 100%) !important;
  color: #FFFFFF !important;
}

#dashy .item-group-container > .collapsable > .section-header h3,
#dashy .item-group-container > .is-open.collapsable > .section-header h3,
#dashy .collapsable .section-header h3 {
  color: #FFFFFF !important;
  opacity: 1 !important;
}
