.app-area {
  min-height: 100vh;
  background: var(--prolar-cream);
}

.home-root {
  min-height: calc(100vh - 238px);
  padding: 34px 34px 60px;
  background:
    radial-gradient(circle at center, rgba(var(--prolar-primary-rgb), 0.05), transparent 28%),
    var(--prolar-cream);
}

.home-panel {
  max-width: 1120px;
  margin: 0 auto;
  background: var(--prolar-panel);
  border: 1px solid var(--prolar-border);
  border-radius: 16px;
  box-shadow: var(--prolar-shadow);
  overflow: hidden;
}

.home-title {
  padding: 18px 22px;
  background: var(--prolar-red);
  color: #ffffff;
}

.home-title h1 {
  margin: 0;
  font-size: 20px;
}

.home-title p {
  margin: 5px 0 0;
  font-size: 13px;
  opacity: 0.92;
}

.home-content {
  padding: 22px;
  display: grid;
  gap: 18px;
}

.home-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.home-card {
  border: 1px solid var(--prolar-border);
  border-radius: 13px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.72);
}

html[data-theme="escuro"] .home-card {
  background: #252525;
}

.home-card strong {
  display: block;
  color: var(--prolar-red);
  font-size: 14px;
}

html[data-theme="escuro"] .home-card strong {
  color: #ff607d;
}

.home-card span {
  display: block;
  margin-top: 7px;
  color: var(--prolar-muted);
  font-size: 13px;
  line-height: 1.4;
}

.home-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.home-action {
  min-height: 38px;
  border: 0;
  border-radius: 9px;
  background: var(--prolar-red);
  color: #ffffff;
  font-weight: 900;
  padding: 0 16px;
}

.home-action.secondary {
  background: #242424;
}

@media (max-width: 900px) {
  .home-cards {
    grid-template-columns: 1fr;
  }
}

/* Remove o painel inicial da tela principal */
#homeRoot .home-panel {
  display: none !important;
}

.home-root {
  min-height: calc(100vh - 238px);
  padding: 0 !important;
  background: var(--prolar-cream) !important;
}

/* ===== HOME COM ÍCONES GRANDES - INÍCIO ===== */

.home-root {
  min-height: calc(100vh - 238px) !important;
  padding: 28px 34px 56px !important;
  background:
    radial-gradient(circle at center, rgba(var(--prolar-primary-rgb), 0.045), transparent 32%),
    var(--prolar-cream) !important;
}

.home-icon-dashboard {
  width: 100% !important;
  max-width: 1220px !important;
  margin: 0 auto !important;
}

.home-icon-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(136px, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
}

.home-icon-card {
  height: 152px !important;
  display: grid !important;
  grid-template-rows: 96px 1fr !important;
  place-items: center !important;
  gap: 8px !important;

  padding: 13px 10px 12px !important;
  border: 1px solid rgba(var(--prolar-primary-rgb), 0.14) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,247,226,.98) 100%) !important;

  box-shadow:
    0 8px 20px rgba(120, 40, 20, .10),
    inset 0 1px 0 rgba(255,255,255,.90) !important;

  cursor: pointer !important;
  overflow: hidden !important;
  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease !important;
}

.home-icon-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(var(--prolar-primary-rgb), 0.38) !important;
  background:
    linear-gradient(180deg, #ffffff 0%, #fff0ca 100%) !important;
  box-shadow:
    0 12px 26px rgba(120, 40, 20, .16),
    inset 0 1px 0 rgba(255,255,255,.95) !important;
}

.home-icon-image {
  width: 92px !important;
  height: 92px !important;
  display: grid !important;
  place-items: center !important;
}

.home-icon-image img {
  width: 88px !important;
  height: 88px !important;
  max-width: 88px !important;
  max-height: 88px !important;
  object-fit: contain !important;
  display: block !important;
  filter: none !important;
  opacity: 1 !important;
  transition: transform 0.16s ease, filter 0.16s ease !important;
}

.home-icon-card:hover .home-icon-image img {
  transform: scale(1.05) !important;
  filter: brightness(1.04) contrast(1.03) !important;
}

.home-icon-label {
  width: 100% !important;
  min-height: 30px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  color: #8b0d1f !important;
  font-family: "Segoe UI", Tahoma, Arial, sans-serif !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  text-align: center !important;
}

.home-icon-placeholder {
  width: 76px !important;
  height: 76px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 18px !important;
  background: #f1f1f1 !important;
  color: var(--prolar-red) !important;
  font-size: 28px !important;
  font-weight: 900 !important;
}

/* Modo escuro preservado */
html[data-theme="escuro"] .home-root {
  background:
    radial-gradient(circle at center, rgba(var(--prolar-primary-rgb), 0.08), transparent 32%),
    #101010 !important;
}

html[data-theme="escuro"] .home-icon-card {
  border-color: rgba(255, 255, 255, 0.10) !important;
  background:
    linear-gradient(180deg, #262626 0%, #1c1c1c 100%) !important;
  box-shadow:
    0 8px 20px rgba(0,0,0,.32),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

html[data-theme="escuro"] .home-icon-card:hover {
  border-color: rgba(var(--prolar-primary-rgb), 0.55) !important;
  background:
    linear-gradient(180deg, #303030 0%, #222222 100%) !important;
  box-shadow:
    0 12px 26px rgba(0,0,0,.42),
    0 0 0 1px rgba(var(--prolar-primary-rgb),.12) !important;
}

html[data-theme="escuro"] .home-icon-label {
  color: #ffffff !important;
}

html[data-theme="escuro"] .home-icon-image img {
  filter: none !important;
  opacity: 1 !important;
}

html[data-theme="escuro"] .home-icon-card:hover .home-icon-image img {
  filter: brightness(1.08) contrast(1.04) !important;
}

html[data-theme="escuro"] .home-icon-placeholder {
  background: #333333 !important;
  color: #ff607d !important;
}

@media (max-width: 980px) {
  .home-root {
    padding: 22px 18px 44px !important;
  }

  .home-icon-grid {
    grid-template-columns: repeat(auto-fill, minmax(118px, 1fr)) !important;
    gap: 14px !important;
  }

  .home-icon-card {
    height: 138px !important;
    grid-template-rows: 84px 1fr !important;
    border-radius: 16px !important;
  }

  .home-icon-image {
    width: 82px !important;
    height: 82px !important;
  }

  .home-icon-image img {
    width: 78px !important;
    height: 78px !important;
    max-width: 78px !important;
    max-height: 78px !important;
  }

  .home-icon-label {
    font-size: 11px !important;
  }
}

@media (max-width: 520px) {
  .home-icon-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* ===== HOME COM ÍCONES GRANDES - FIM ===== */

/* ===== HOME COM ÍCONES GRANDES - INÍCIO ===== */

.home-root {
  min-height: calc(100vh - 238px) !important;
  padding: 28px 34px 56px !important;
  background:
    radial-gradient(circle at center, rgba(var(--prolar-primary-rgb), 0.045), transparent 32%),
    var(--prolar-cream) !important;
}

.home-icon-dashboard {
  width: 100% !important;
  max-width: 1220px !important;
  margin: 0 auto !important;
}

.home-icon-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(136px, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
}

.home-icon-card {
  height: 152px !important;
  display: grid !important;
  grid-template-rows: 96px 1fr !important;
  place-items: center !important;
  gap: 8px !important;

  padding: 13px 10px 12px !important;
  border: 1px solid rgba(var(--prolar-primary-rgb), 0.14) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,247,226,.98) 100%) !important;

  box-shadow:
    0 8px 20px rgba(120, 40, 20, .10),
    inset 0 1px 0 rgba(255,255,255,.90) !important;

  cursor: pointer !important;
  overflow: hidden !important;
  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease !important;
}

.home-icon-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(var(--prolar-primary-rgb), 0.38) !important;
  background:
    linear-gradient(180deg, #ffffff 0%, #fff0ca 100%) !important;
  box-shadow:
    0 12px 26px rgba(120, 40, 20, .16),
    inset 0 1px 0 rgba(255,255,255,.95) !important;
}

.home-icon-image {
  width: 92px !important;
  height: 92px !important;
  display: grid !important;
  place-items: center !important;
}

.home-icon-image img {
  width: 88px !important;
  height: 88px !important;
  max-width: 88px !important;
  max-height: 88px !important;
  object-fit: contain !important;
  display: block !important;
  filter: none !important;
  opacity: 1 !important;
  transition: transform 0.16s ease, filter 0.16s ease !important;
}

.home-icon-card:hover .home-icon-image img {
  transform: scale(1.05) !important;
  filter: brightness(1.04) contrast(1.03) !important;
}

.home-icon-label {
  width: 100% !important;
  min-height: 30px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  color: #8b0d1f !important;
  font-family: "Segoe UI", Tahoma, Arial, sans-serif !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  text-align: center !important;
}

.home-icon-placeholder {
  width: 76px !important;
  height: 76px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 18px !important;
  background: #f1f1f1 !important;
  color: var(--prolar-red) !important;
  font-size: 28px !important;
  font-weight: 900 !important;
}

/* Modo escuro preservado */
html[data-theme="escuro"] .home-root {
  background:
    radial-gradient(circle at center, rgba(var(--prolar-primary-rgb), 0.08), transparent 32%),
    #101010 !important;
}

html[data-theme="escuro"] .home-icon-card {
  border-color: rgba(255, 255, 255, 0.10) !important;
  background:
    linear-gradient(180deg, #262626 0%, #1c1c1c 100%) !important;
  box-shadow:
    0 8px 20px rgba(0,0,0,.32),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

html[data-theme="escuro"] .home-icon-card:hover {
  border-color: rgba(var(--prolar-primary-rgb), 0.55) !important;
  background:
    linear-gradient(180deg, #303030 0%, #222222 100%) !important;
  box-shadow:
    0 12px 26px rgba(0,0,0,.42),
    0 0 0 1px rgba(var(--prolar-primary-rgb),.12) !important;
}

html[data-theme="escuro"] .home-icon-label {
  color: #ffffff !important;
}

html[data-theme="escuro"] .home-icon-image img {
  filter: none !important;
  opacity: 1 !important;
}

html[data-theme="escuro"] .home-icon-card:hover .home-icon-image img {
  filter: brightness(1.08) contrast(1.04) !important;
}

html[data-theme="escuro"] .home-icon-placeholder {
  background: #333333 !important;
  color: #ff607d !important;
}

@media (max-width: 980px) {
  .home-root {
    padding: 22px 18px 44px !important;
  }

  .home-icon-grid {
    grid-template-columns: repeat(auto-fill, minmax(118px, 1fr)) !important;
    gap: 14px !important;
  }

  .home-icon-card {
    height: 138px !important;
    grid-template-rows: 84px 1fr !important;
    border-radius: 16px !important;
  }

  .home-icon-image {
    width: 82px !important;
    height: 82px !important;
  }

  .home-icon-image img {
    width: 78px !important;
    height: 78px !important;
    max-width: 78px !important;
    max-height: 78px !important;
  }

  .home-icon-label {
    font-size: 11px !important;
  }
}

@media (max-width: 520px) {
  .home-icon-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* ===== HOME COM ÍCONES GRANDES - FIM ===== */

/* ===== TEMA GRAFITE AZUL LIMPO - HOME - INÍCIO ===== */

html[data-theme="grafite"] .app-area,
html[data-theme="grafite"] .home-root {
  background:
    radial-gradient(circle at center, rgba(var(--modelo2-primary-rgb, 15, 60, 45), .045), transparent 32%),
    var(--grafite-bg, var(--modelo2-page, #eef1ef)) !important;
  color: var(--grafite-texto, var(--modelo2-text, #202829)) !important;
}

html[data-theme="grafite"] .home-icon-card {
  background: linear-gradient(180deg, #ffffff 0%, var(--modelo2-panel-soft, #f7f9f8) 100%) !important;
  border-color: var(--grafite-borda, var(--modelo2-border, #d5ddda)) !important;
  box-shadow:
    0 8px 20px rgba(var(--modelo2-secondary-rgb, 53, 56, 57), .12),
    inset 0 1px 0 rgba(255,255,255,.92) !important;
}

html[data-theme="grafite"] .home-icon-card:hover {
  background: linear-gradient(180deg, #ffffff 0%, var(--modelo2-primary-soft, #e5eee9) 100%) !important;
  border-color: rgba(var(--modelo2-primary-rgb, 15, 60, 45), .42) !important;
  box-shadow:
    0 12px 26px rgba(var(--modelo2-primary-rgb, 15, 60, 45), .16),
    inset 0 1px 0 rgba(255,255,255,.95) !important;
}

html[data-theme="grafite"] .home-icon-label {
  color: var(--modelo2-secondary, #353839) !important;
}

/* ===== TEMA GRAFITE AZUL LIMPO - HOME - FIM ===== */

/* ===== HOME ATALHOS COMPACTOS - INÍCIO ===== */

.home-root {
  --home-shortcut-max-width: 1120px;
  --home-shortcut-min-width: 118px;
  --home-shortcut-gap: 14px;
  --home-shortcut-card-height: 128px;
  --home-shortcut-image-slot: 76px;
  --home-shortcut-image-size: 72px;
  --home-shortcut-label-size: 11.5px;

  padding: 22px 28px 44px !important;
}

.home-icon-dashboard {
  max-width: var(--home-shortcut-max-width) !important;
}

.home-icon-grid {
  grid-template-columns: repeat(auto-fill, minmax(var(--home-shortcut-min-width), 1fr)) !important;
  gap: var(--home-shortcut-gap) !important;
}

.home-theme-panel {
  width: 100% !important;
  display: none !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  margin: 0 0 16px !important;
  padding: 12px 14px !important;
  border: 1px solid var(--modelo2-border, #d7dfdc) !important;
  border-radius: 10px !important;
  background: linear-gradient(180deg, #ffffff 0%, var(--modelo2-panel-soft, #fffaf1) 100%) !important;
  box-shadow: 0 6px 16px rgba(var(--modelo2-secondary-rgb, 53, 56, 57), .08) !important;
}

.home-theme-title {
  display: grid !important;
  gap: 3px !important;
  min-width: 220px !important;
}

.home-theme-title strong {
  color: var(--modelo2-primary, #007f6a) !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
}

.home-theme-title span {
  color: var(--modelo2-muted, #66706d) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
}

.home-theme-controls {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.home-theme-controls label {
  display: grid !important;
  gap: 4px !important;
  color: var(--modelo2-secondary, #353839) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.home-theme-controls select,
.home-theme-controls input[type="color"],
.home-theme-controls button {
  height: 34px !important;
  border: 1px solid var(--modelo2-border, #d7dfdc) !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  color: var(--modelo2-text, #202829) !important;
  font-family: "Segoe UI", Tahoma, Arial, sans-serif !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.home-theme-controls select {
  min-width: 150px !important;
  padding: 0 10px !important;
}

.home-theme-controls input[type="color"] {
  width: 48px !important;
  padding: 3px !important;
}

.home-theme-controls button {
  padding: 0 12px !important;
}

.home-theme-controls button:hover {
  border-color: var(--modelo2-primary, #007f6a) !important;
  color: var(--modelo2-primary, #007f6a) !important;
}

.home-theme-swatch {
  width: 34px !important;
  height: 34px !important;
  display: inline-block !important;
  border: 2px solid #ffffff !important;
  border-radius: 999px !important;
  box-shadow: 0 0 0 1px var(--modelo2-border, #d7dfdc), 0 4px 10px rgba(0,0,0,.10) !important;
}

.home-icon-card {
  height: var(--home-shortcut-card-height) !important;
  grid-template-rows: var(--home-shortcut-image-slot) 1fr !important;
  gap: 6px !important;
  padding: 10px 8px 9px !important;
  border-radius: 13px !important;
  box-shadow:
    0 6px 16px rgba(120, 40, 20, .09),
    inset 0 1px 0 rgba(255,255,255,.90) !important;
}

.home-icon-card:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 9px 20px rgba(120, 40, 20, .14),
    inset 0 1px 0 rgba(255,255,255,.95) !important;
}

.home-icon-image {
  width: var(--home-shortcut-image-slot) !important;
  height: var(--home-shortcut-image-slot) !important;
}

.home-icon-image img {
  width: var(--home-shortcut-image-size) !important;
  height: var(--home-shortcut-image-size) !important;
  max-width: var(--home-shortcut-image-size) !important;
  max-height: var(--home-shortcut-image-size) !important;
}

.home-icon-label {
  min-height: 26px !important;
  font-size: var(--home-shortcut-label-size) !important;
  line-height: 1.12 !important;
}

html[data-theme="grafite"] .home-icon-card {
  box-shadow:
    0 6px 16px rgba(var(--modelo2-secondary-rgb, 53, 56, 57), .11),
    inset 0 1px 0 rgba(255,255,255,.92) !important;
}

html[data-theme="grafite"] .home-icon-card:hover {
  box-shadow:
    0 9px 20px rgba(var(--modelo2-primary-rgb, 15, 60, 45), .14),
    inset 0 1px 0 rgba(255,255,255,.95) !important;
}

@media (max-width: 980px) {
  .home-root {
    --home-shortcut-min-width: 104px;
    --home-shortcut-gap: 12px;
    --home-shortcut-card-height: 116px;
    --home-shortcut-image-slot: 66px;
    --home-shortcut-image-size: 62px;
    --home-shortcut-label-size: 10.5px;

    padding: 18px 16px 36px !important;
  }

  .home-theme-panel {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .home-theme-controls {
    justify-content: flex-start !important;
  }
}

@media (max-width: 520px) {
  .home-root {
    --home-shortcut-card-height: 112px;
    --home-shortcut-image-slot: 62px;
    --home-shortcut-image-size: 58px;
  }
}

/* ===== HOME ATALHOS COMPACTOS - FIM ===== */

/* ===== HOME ICONES MENORES - INICIO ===== */

.home-root {
  --home-shortcut-max-width: 1060px;
  --home-shortcut-min-width: 104px;
  --home-shortcut-gap: 12px;
  --home-shortcut-card-height: 112px;
  --home-shortcut-image-slot: 62px;
  --home-shortcut-image-size: 56px;
  --home-shortcut-label-size: 10.5px;

  padding: 18px 22px 36px !important;
}

.home-icon-card {
  border-radius: 10px !important;
  gap: 5px !important;
  padding: 8px 7px !important;
}

.home-icon-card:hover {
  transform: translateY(-1px) !important;
}

.home-icon-label {
  min-height: 24px !important;
  line-height: 1.08 !important;
}

@media (max-width: 980px) {
  .home-root {
    --home-shortcut-min-width: 96px;
    --home-shortcut-gap: 10px;
    --home-shortcut-card-height: 104px;
    --home-shortcut-image-slot: 56px;
    --home-shortcut-image-size: 50px;
    --home-shortcut-label-size: 10px;
  }
}

/* ===== HOME ICONES MENORES - FIM ===== */
