    :root {
      --bg: #ffffff;
      --bg-elevated: #ffffff;
      --ink: #111018;
      --ink-muted: #4b5568;
      --ink-faint: #7b8194;
      --line: #e2e5ec;
      --brand: #ea580c;
      --brand-deep: #c2410c;
      --brand-soft: #ffedd5;
      --accent: #ea580c;
      --accent-secondary: #fb923c;
      --accent-soft: #fff7ed;
      --ocean: #ea580c;
      --safe-bottom: env(safe-area-inset-bottom, 0px);
      --nav-h: 64px;
      --radius-lg: 18px;
      --radius-md: 12px;
      --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
      --shadow-md: 0 4px 20px rgba(15, 23, 42, 0.08);
      --font-sans: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
      --font-display: "Outfit", system-ui, sans-serif;
    }

    *,
    *::before,
    *::after { box-sizing: border-box; }

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

    html {
      -webkit-text-size-adjust: 100%;
      /* auto (padrão): reload e restauração de scroll não animam do topo */
      scroll-behavior: auto;
    }

    body {
      margin: 0;
      min-height: 100dvh;
      font-family: var(--font-sans);
      font-size: 15px;
      line-height: 1.45;
      color: var(--ink);
      background: var(--bg);
      padding-bottom: calc(var(--nav-h) + var(--safe-bottom) + 12px);
    }

    .shell {
      max-width: 480px;
      margin: 0 auto;
      padding-top: 10px;
      padding-bottom: 0;
      padding-left: calc(16px + env(safe-area-inset-left, 0px));
      padding-right: calc(16px + env(safe-area-inset-right, 0px));
    }

    @media (min-width: 900px) {
      .shell { max-width: 560px; padding-top: 24px; }
    }

    /* Topo: mesmo recuo horizontal que o conteúdo dos .card (padding 18px + shell 16px) */
    .user-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      margin-bottom: 8px;
      padding-top: max(4px, env(safe-area-inset-top));
      padding-bottom: 12px;
      padding-left: calc(18px + env(safe-area-inset-left, 0px));
      padding-right: calc(18px + env(safe-area-inset-right, 0px));
      background: transparent;
      border: none;
      box-shadow: none;
    }

    .user-header__hello {
      margin: 0 0 4px;
      font-size: 0.8125rem;
      font-weight: 500;
      color: var(--ink-faint);
      letter-spacing: 0.01em;
    }

    .user-header__name {
      margin: 0;
      font-family: var(--font-display);
      font-size: 1.5rem;
      font-weight: 800;
      letter-spacing: -0.03em;
      color: var(--ink);
      line-height: 1.15;
      display: flex;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
    }

    .user-header__wave {
      font-size: 1.35rem;
      line-height: 1;
      font-style: normal;
    }

    .user-header__avatar-link {
      position: relative;
      flex-shrink: 0;
      text-decoration: none;
      color: inherit;
      -webkit-tap-highlight-color: transparent;
    }

    .user-header__avatar-link:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 4px;
      border-radius: 50%;
    }

    .user-header__edit-badge {
      position: absolute;
      bottom: -3px;
      right: -3px;
      left: auto;
      top: auto;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: #fff;
      border: 2px solid #fff;
      display: grid;
      place-items: center;
      z-index: 2;
      box-shadow: 0 0 0 1px var(--line), 0 1px 4px rgba(15, 23, 42, 0.1);
    }

    .user-header__edit-badge svg {
      width: 12px;
      height: 12px;
      color: var(--accent);
    }

    .user-header__avatar {
      width: 54px;
      height: 54px;
      border-radius: 50%;
      background: var(--accent);
      color: #fff;
      display: grid;
      place-items: center;
      font-family: var(--font-display);
      font-weight: 800;
      font-size: 1.05rem;
      letter-spacing: -0.02em;
      box-shadow: 0 4px 14px rgba(234, 88, 12, 0.28);
      overflow: hidden;
    }

    .user-header__avatar img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    /* Cartões (clima / maré compactos) */
    .card {
      background: var(--bg-elevated);
      border-radius: var(--radius-lg);
      border: 1px solid var(--line);
      box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
      padding: 18px 18px 16px;
      margin-bottom: 14px;
    }

    .card--compact {
      padding: 11px 14px 12px;
      margin-bottom: 10px;
      border-radius: 14px;
      box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    }

    .card-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      margin-bottom: 14px;
    }

    .card--compact .card-head {
      margin-bottom: 6px;
    }

    .card-head h2 {
      margin: 0;
      font-size: 0.8125rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--ink-faint);
    }

    .card--compact .card-head h2 {
      font-size: 0.6875rem;
      letter-spacing: 0.05em;
    }

    .card-meta {
      font-size: 0.6875rem;
      color: var(--ink-faint);
      white-space: nowrap;
    }

    .card--compact .card-meta {
      font-size: 0.625rem;
      white-space: normal;
      text-align: right;
      max-width: 58%;
      line-height: 1.25;
    }

    .chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 10px;
      border-radius: 10px;
      background: var(--brand-soft);
      font-size: 0.75rem;
      font-weight: 600;
      color: var(--brand-deep);
    }

    .card--compact .chip {
      padding: 4px 7px;
      border-radius: 8px;
      font-size: 0.625rem;
      font-weight: 600;
      letter-spacing: 0.01em;
    }

    .card--compact .chip svg {
      width: 11px;
      height: 11px;
    }

    .chip svg { flex-shrink: 0; opacity: 0.85; }

    /* Painéis Tempo / Lua — mesmo cartão compacto + topo igual à Tauba da maré */
    .card.card--compact.weather-panel,
    .card.card--compact.moon-panel {
      position: relative;
      overflow: visible;
      color: var(--ink);
    }

    /* Miolo flexível tempo/lua — ícone só no canto (cartão igual à Tauba via flex stack) */
    .weather-panel__accent-zone {
      display: none;
    }

    .moon-panel__accent-zone {
      display: none;
    }

    /* Banda fixa ≈ gráfico+ticks da maré em stack — não cresce o cartão; o vão extra vai pro home-stack-fill */
    .home-carousel--stack .moon-panel__accent-zone {
      position: relative;
      flex: 0 0 auto;
      min-height: 0;
      max-height: 72px;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 4px;
      background: radial-gradient(ellipse 88% 100% at 50% 45%, rgba(99, 102, 241, 0.1), transparent 62%);
    }

    .home-carousel--stack .weather-panel__accent-zone {
      position: relative;
      flex: 0 0 auto;
      min-height: 0;
      max-height: 72px;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 4px;
      background: radial-gradient(ellipse 88% 100% at 50% 40%, rgba(251, 191, 36, 0.12), transparent 60%);
    }

    .weather-panel__forecast {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 6px;
    }

    .weather-panel__day {
      text-align: center;
      padding: 8px 6px 7px;
      border-radius: 12px;
      background: #fafbfc;
      border: 1px solid var(--line);
      min-width: 0;
    }

    .weather-panel__dow {
      display: block;
      font-size: 0.5625rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--ink-faint);
      margin-bottom: 6px;
    }

    .weather-panel__day-icon {
      display: block;
      width: 28px;
      height: 22px;
      margin: 0 auto 6px;
    }

    .weather-panel__day-temp {
      display: block;
      font-size: 0.8125rem;
      font-weight: 800;
      font-variant-numeric: tabular-nums;
      color: var(--ink);
      letter-spacing: 0.02em;
      margin-bottom: 4px;
    }

    .weather-panel__day-rain {
      display: block;
      font-size: 0.625rem;
      font-weight: 600;
      color: var(--accent);
      font-variant-numeric: tabular-nums;
    }

    .moon-panel__strip {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 6px;
    }

    .moon-panel__cell {
      text-align: center;
      padding: 8px 6px 7px;
      border-radius: 12px;
      background: #fafbfc;
      border: 1px solid var(--line);
      min-width: 0;
    }

    .moon-panel__cell-label {
      display: block;
      font-size: 0.5625rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--ink-faint);
      margin-bottom: 5px;
    }

    .moon-panel__cell-val {
      display: block;
      font-size: 0.8125rem;
      font-weight: 800;
      font-variant-numeric: tabular-nums;
      color: var(--ink);
      letter-spacing: -0.02em;
    }

    .moon-panel__cell-sub {
      display: block;
      margin-top: 2px;
      font-size: 0.5625rem;
      font-weight: 600;
      color: var(--accent);
    }

    .weather-panel__day--today,
    .moon-panel__cell--accent {
      background: var(--accent-soft);
      border-color: rgba(234, 88, 12, 0.45);
      box-shadow: 0 0 0 1px rgba(234, 88, 12, 0.12);
    }

    .moon-panel__cell--accent .moon-panel__cell-sub {
      color: var(--brand-deep);
    }

    @media (max-width: 360px) {
      .home-carousel--stack .weather-panel__daytrack-row {
        gap: 2px;
      }

      .home-carousel--stack .weather-panel__slot {
        padding: 4px 1px 3px;
        gap: 2px;
      }

      .home-carousel--stack .weather-panel__slot-time {
        font-size: 0.5rem;
      }

      .home-carousel--stack .weather-panel__slot-temp {
        font-size: 0.625rem;
      }

      .home-carousel--stack .weather-panel__slot-icon {
        width: 18px;
        height: 14px;
      }

      .home-carousel--stack .moon-panel__daytrack-row {
        gap: 2px;
      }

      .home-carousel--stack .moon-panel__slot {
        padding: 4px 1px 3px;
        gap: 2px;
      }

      .home-carousel--stack .moon-panel__slot-dow {
        font-size: 0.5rem;
      }

      .home-carousel--stack .moon-panel__slot-pct {
        font-size: 0.625rem;
      }

      .home-carousel--stack .moon-panel__slot-icon {
        width: 18px;
        height: 14px;
      }

      .weather-panel__forecast {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .weather-panel__day-temp {
        font-size: 0.75rem;
      }

      .weather-panel__day-rain {
        font-size: 0.5625rem;
      }

      .moon-panel__strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    /* Tauba da maré — layout tipo app (gráfico + cartões) */
    .tide-board__head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 10px;
      margin: 0 0 9px;
    }

    /* Maré: mesmo encaixe do cabeçalho que Tempo/Lua, só que valor mais discreto */
    .tide-board--mare .tide-board__now {
      text-align: right;
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      gap: 0;
      justify-content: flex-start;
      margin-top: 0;
      padding-top: 0;
    }

    .tide-board--mare .tide-board__now-m {
      font-size: 1.1875rem;
      font-weight: 800;
      letter-spacing: -0.035em;
      line-height: 1.05;
      color: var(--accent);
      display: block;
    }

    .tide-board--mare .tide-board__now-u {
      font-size: 0.75rem;
      font-weight: 700;
      margin-left: 2px;
    }

    .tide-board--mare .tide-board__now-label {
      display: block;
      margin-top: 4px;
      font-size: 0.53125rem;
      font-weight: 700;
      letter-spacing: 0.14em;
      color: var(--ink-faint);
    }

    .tide-board__head-left {
      min-width: 0;
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 2px;
    }

    .tide-board__title {
      margin: 0;
      font-family: var(--font-display);
      font-size: 1rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--ink);
      line-height: 1.2;
    }

    .tide-board__sub {
      margin: 0;
      font-size: 0.6875rem;
      font-weight: 500;
      color: var(--ink-muted);
    }

    .tide-board__now {
      text-align: right;
      flex-shrink: 0;
    }

    .tide-board__now-m {
      display: block;
      font-family: var(--font-display);
      font-size: 1.65rem;
      font-weight: 800;
      letter-spacing: -0.04em;
      line-height: 1;
      color: var(--accent);
    }

    .tide-board__now-u {
      font-size: 1rem;
      font-weight: 700;
      margin-left: 1px;
    }

    .tide-board__now-label {
      display: block;
      margin-top: 4px;
      font-size: 0.5625rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      color: var(--ink-faint);
    }

    .tide-board__chart {
      position: relative;
      box-sizing: border-box;
      width: 100%;
      max-width: none;
      margin: 0 0 10px;
      padding: 0;
    }

    /* Só o desenho (laranja/SVG): mesma largura útil da legenda e da grelha — sem bleed que descasava das células */
    .tide-board__curve {
      box-sizing: border-box;
      width: 100%;
      margin: 0;
      padding: 0;
      position: relative;
    }

    /* “Agora” no gráfico: fora do SVG com none, os círculos não viram oval / amassado */
    .tide-board__marker {
      position: absolute;
      left: 50%;
      top: 0;
      height: 100%;
      width: 0;
      transform: translateX(-50%);
      pointer-events: none;
    }

    .tide-board__marker-vline {
      position: absolute;
      left: 50%;
      top: 10%;
      bottom: 8%;
      width: 0;
      margin-left: -0.5px;
      border-left: 1px dashed #cbd5e1;
      transform: translateX(-50%);
    }

    .tide-board__marker-halo {
      position: absolute;
      left: 50%;
      top: 50%;
      width: 28px;
      height: 28px;
      margin: -14px 0 0 -14px;
      border-radius: 50%;
      box-sizing: border-box;
      border: 1px dashed rgba(234, 88, 12, 0.55);
      opacity: 0.45;
    }

    .tide-board__marker-dot {
      position: absolute;
      left: 50%;
      top: 50%;
      width: 10px;
      height: 10px;
      margin: -5px 0 0 -5px;
      border-radius: 50%;
      background: #ea580c;
      box-shadow: 0 0 0 2px #fff;
      box-sizing: border-box;
    }

    .tide-board__curve svg {
      display: block;
      width: 100%;
      /* max-height + aspect-ratio + meet = letterbox lateral; “none” + altura fixa preenche a coluna inteira */
      height: 74px;
      aspect-ratio: unset;
      max-height: none;
    }

    .tide-board__ticks {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 2px;
      padding: 4px 0 0;
      margin: 0;
      font-size: 0.625rem;
      font-weight: 600;
      color: var(--ink-faint);
      letter-spacing: 0.02em;
      width: 100%;
      max-width: 100%;
      box-sizing: border-box;
    }

    .tide-board__ticks span {
      min-width: 0;
      font-variant-numeric: tabular-nums;
    }

    .tide-board__events {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 6px;
    }

    @media (max-width: 360px) {
      .tide-board__events {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    .tide-board__cell {
      padding: 8px 6px 7px;
      border-radius: 12px;
      background: #fafbfc;
      border: 1px solid var(--line);
      text-align: center;
      min-width: 0;
    }

    .tide-board__cell--hl {
      background: var(--accent-soft);
      border-color: rgba(234, 88, 12, 0.45);
      box-shadow: 0 0 0 1px rgba(234, 88, 12, 0.12);
    }

    .tide-board__cell-tag {
      display: block;
      font-size: 0.5625rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      margin-bottom: 4px;
    }

    .tide-board__cell-tag--low {
      color: #64748b;
    }

    .tide-board__cell-tag--high {
      color: var(--accent);
    }

    .tide-board__cell--hl .tide-board__cell-tag--high {
      color: var(--brand-deep);
    }

    .tide-board__cell-time {
      display: block;
      font-size: 0.8125rem;
      font-weight: 700;
      font-variant-numeric: tabular-nums;
      color: var(--ink);
      letter-spacing: -0.02em;
    }

    .tide-board__cell-h {
      display: block;
      margin-top: 2px;
      font-size: 0.625rem;
      font-weight: 500;
      color: var(--ink-muted);
    }

    /* Carrosséis (topo: clima/maré/lua · promo) — ver assets/js/home-carousel.js */
    .home-carousel {
      user-select: none;
      -webkit-user-select: none;
    }

    .home-carousel__viewport {
      position: relative;
      overflow: hidden;
      touch-action: pan-y pinch-zoom;
      cursor: grab;
    }

    .home-carousel__viewport:active {
      cursor: grabbing;
    }

    .home-carousel__track {
      display: flex;
      will-change: transform;
    }

    .home-carousel__slide {
      flex-shrink: 0;
      box-sizing: border-box;
    }

    .home-carousel__dots {
      display: flex;
      gap: 7px;
      justify-content: center;
      align-items: center;
      margin-top: 9px;
      min-height: 20px;
    }

    .home-carousel__dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      border: none;
      padding: 0;
      margin: 0;
      background: var(--line);
      cursor: pointer;
      transition: background 0.2s ease, transform 0.2s ease;
      -webkit-tap-highlight-color: transparent;
    }

    .home-carousel__dot.is-active {
      background: var(--accent);
      transform: scale(1.2);
    }

    .home-carousel__dot:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 3px;
    }

    .home-carousel__dot:hover:not(.is-active) {
      background: #d1d5df;
    }

    /* Topo: clima, maré, lua — bloco único abas + conteúdo */
    .home-carousel--stack {
      margin: 0 0 8px;
    }

    .home-stack-shell {
      border-radius: var(--radius-lg);
      border: 1px solid var(--line);
      background: var(--bg-elevated);
      box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
      overflow: hidden;
    }

    /*
     * Uma só caixa: abas ocupam a largura total do topo, mesmo fundo do shell,
     * sem “pill” branca nem segunda caixa/blur sobre o conteúdo.
     */
    .home-carousel--stack .home-carousel__tabs--stack-head.home-carousel__tabs--glider {
      margin-top: 0;
      padding: 2px 4px 0;
      margin-bottom: 0;
      border-bottom: none;
      background: transparent;
    }

    .home-carousel--stack .home-carousel__tabs--stack-head .home-carousel__tabs-gl {
      width: 100%;
      margin: 0;
      padding: 2px;
      border-radius: 0;
      background: transparent;
      border: none;
      box-shadow: none;
      backdrop-filter: none;
      -webkit-backdrop-filter: none;
    }

    .home-carousel--stack .home-carousel__viewport {
      border: none;
      box-shadow: none;
      border-radius: 0;
      background: transparent;
      padding: 3px 8px 5px;
      margin-top: 0;
    }

    /* Cartões dentro do mesmo bloco visual — menos respiro interno pra poupar altura na tela */
    .home-carousel--stack .home-carousel__slide > .card.card--compact {
      padding: 6px 10px 6px !important;
    }

    .home-carousel--stack .home-carousel__slide > .card {
      margin-bottom: 0 !important;
      border: none !important;
      border-radius: 0 !important;
      box-shadow: none !important;
      background: transparent !important;
      flex: 1 1 auto;
      width: 100%;
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }

    /* Mesma altura dos três cartões (referência: Tauba da maré) */
    .home-carousel--stack .home-carousel__track {
      align-items: stretch;
    }

    .home-carousel--stack .home-carousel__slide {
      display: flex;
      flex-direction: column;
      align-self: stretch;
    }

    .home-carousel--stack .tide-board,
    .home-carousel--stack .weather-panel,
    .home-carousel--stack .moon-panel {
      flex: 1 1 auto;
      display: flex;
      flex-direction: column;
      min-height: 0;
    }

    .home-carousel--stack .tide-board__head,
    .home-carousel--stack .weather-panel > .tide-board__head,
    .home-carousel--stack .moon-panel > .tide-board__head {
      flex-shrink: 0;
      margin: 0 0 5px;
    }

    .home-carousel--stack .tide-board__chart {
      flex-shrink: 0;
      margin: 0 0 6px;
    }

    .home-carousel--stack .tide-board__curve svg {
      height: 54px;
    }

    .home-carousel--stack .tide-board__ticks {
      padding: 2px 0 0;
    }

    .home-carousel--stack .tide-board__events {
      gap: 5px;
    }

    .home-carousel--stack .tide-board__cell {
      padding: 6px 5px 5px;
      border-radius: 10px;
    }

    .home-carousel--stack .tide-board__cell-tag {
      margin-bottom: 3px;
    }

    .home-carousel--stack .tide-board__cell-h {
      margin-top: 1px;
    }

    .home-carousel--stack .tide-board--mare .tide-board__now-label {
      margin-top: 2px;
    }

    /* Miolo Tempo/Lua: ocupa o espaço entre o topo e a grelha e centra a faixa verticalmente */
    .home-carousel--stack .home-stack-mid-grow {
      flex: 1 1 auto;
      min-height: 0;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: stretch;
    }

    /* Espaço flexível entre miolo e grelha — só Tauba (maré); Tempo/Lua usam home-stack-mid-grow */
    .home-carousel--stack .home-stack-fill {
      flex: 1 1 auto;
      min-height: 0;
    }

    .home-carousel--stack .tide-board__events {
      flex-shrink: 0;
      margin-top: auto;
      padding-top: 5px;
      border-top: 1px solid rgba(234, 88, 12, 0.12);
    }

    .home-carousel--stack .weather-panel__forecast,
    .home-carousel--stack .moon-panel__strip {
      flex-shrink: 0;
      margin-top: 0;
      padding-top: 5px;
      border-top: 1px solid rgba(234, 88, 12, 0.12);
    }

    .home-carousel--stack .weather-panel__accent-icon {
      display: none;
    }

    /* Projeção do dia (substitui o ícone solto no miolo) */
    .home-carousel--stack .weather-panel__daytrack {
      width: 100%;
      max-width: 100%;
      display: flex;
      flex-direction: column;
      align-items: stretch;
      justify-content: center;
      gap: 0;
      min-height: 0;
    }

    .home-carousel--stack .weather-panel__daytrack-label {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip-path: inset(50%);
      border: 0;
      white-space: nowrap;
    }

    .home-carousel--stack .weather-panel__daytrack-row {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 3px;
      align-items: stretch;
    }

    .home-carousel--stack .weather-panel__slot {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      gap: 2px;
      padding: 3px 2px 2px;
      border-radius: 8px;
      background: rgba(255, 255, 255, 0.55);
      border: 1px solid rgba(226, 229, 236, 0.95);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
      min-width: 0;
    }

    .home-carousel--stack .weather-panel__slot--peak {
      background: rgba(255, 247, 237, 0.85);
      border-color: rgba(234, 88, 12, 0.28);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 0 0 1px rgba(234, 88, 12, 0.08);
    }

    .home-carousel--stack .weather-panel__slot-time {
      font-size: 0.5rem;
      font-weight: 700;
      font-variant-numeric: tabular-nums;
      color: var(--ink-muted);
      letter-spacing: 0.02em;
      line-height: 1.1;
    }

    .home-carousel--stack .weather-panel__slot-icon {
      display: block;
      width: 18px;
      height: 13px;
      flex-shrink: 0;
    }

    .home-carousel--stack .weather-panel__slot-temp {
      font-size: 0.625rem;
      font-weight: 800;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.03em;
      color: var(--ink);
      line-height: 1;
    }

    .home-carousel--stack .weather-panel__forecast {
      gap: 5px;
      align-items: stretch;
    }

    .home-carousel--stack .weather-panel__day {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      gap: 3px;
      padding: 6px 4px 5px;
      border-radius: 10px;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
    }

    .home-carousel--stack .weather-panel__dow {
      margin-bottom: 0;
      font-size: 0.53125rem;
      letter-spacing: 0.09em;
    }

    .home-carousel--stack .weather-panel__day-icon {
      width: 24px;
      height: 18px;
      margin: 0;
      flex-shrink: 0;
    }

    .home-carousel--stack .weather-panel__day-temp {
      font-size: 0.75rem;
      margin-bottom: 0;
      margin-top: 1px;
      letter-spacing: -0.03em;
      line-height: 1.15;
    }

    .home-carousel--stack .weather-panel__day-rain {
      font-size: 0.5625rem;
      margin-top: auto;
      padding-top: 2px;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: var(--brand-deep);
      line-height: 1.2;
    }

    .home-carousel--stack .weather-panel__day--today .weather-panel__day-rain {
      color: #9a3412;
    }

    /* Projeção da lua (5 dias ao meio-dia local — fase + luz) */
    .home-carousel--stack .moon-panel__daytrack {
      width: 100%;
      max-width: 100%;
      display: flex;
      flex-direction: column;
      align-items: stretch;
      justify-content: center;
      gap: 0;
      min-height: 0;
    }

    .home-carousel--stack .moon-panel__daytrack-label {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip-path: inset(50%);
      border: 0;
      white-space: nowrap;
    }

    .home-carousel--stack .moon-panel__daytrack-row {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 3px;
      align-items: stretch;
    }

    .home-carousel--stack .moon-panel__slot {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      gap: 2px;
      padding: 3px 2px 2px;
      border-radius: 8px;
      background: rgba(255, 255, 255, 0.55);
      border: 1px solid rgba(226, 229, 236, 0.95);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
      min-width: 0;
    }

    .home-carousel--stack .moon-panel__slot--today {
      background: rgba(238, 242, 255, 0.92);
      border-color: rgba(99, 102, 241, 0.35);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 0 0 1px rgba(99, 102, 241, 0.1);
    }

    .home-carousel--stack .moon-panel__slot-dow {
      font-size: 0.5rem;
      font-weight: 700;
      font-variant-numeric: tabular-nums;
      color: var(--ink-muted);
      letter-spacing: 0.02em;
      line-height: 1.1;
    }

    .home-carousel--stack .moon-panel__slot-icon {
      display: block;
      width: 18px;
      height: 13px;
      flex-shrink: 0;
    }

    .home-carousel--stack .moon-panel__slot-pct {
      font-size: 0.625rem;
      font-weight: 800;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.03em;
      color: var(--ink);
      line-height: 1;
    }

    .home-carousel--stack .moon-panel__strip {
      gap: 5px;
    }

    .home-carousel--stack .moon-panel__cell {
      padding: 6px 5px 5px;
      border-radius: 10px;
    }

    .home-carousel__tabs {
      display: flex;
      flex-wrap: wrap;
      gap: 5px;
      justify-content: center;
      align-items: center;
    }

    /* Abas “Maré / Tempo / Lua” dentro do topo — só o stack sobrescreve margem zero */
    .home-carousel__tabs--glider {
      width: 100%;
      padding: 0;
      margin-top: 8px;
    }

    .home-carousel__tabs--glider .home-carousel__tabs-gl {
      display: flex;
      position: relative;
      align-items: stretch;
      margin: 0 auto;
      max-width: 100%;
      width: fit-content;
      padding: 6px;
      border-radius: 999px;
      background-color: #fff;
      box-shadow:
        0 0 1px 0 rgba(234, 88, 12, 0.12),
        0 6px 12px 0 rgba(15, 23, 42, 0.08);
      gap: 0;
    }

    .home-carousel__tabs--glider .home-carousel__tab-radio {
      position: absolute;
      opacity: 0;
      width: 1px;
      height: 1px;
      margin: 0;
      pointer-events: none;
    }

    .home-carousel__tabs--glider .home-carousel__tab-radio:focus-visible + .home-carousel__tab {
      outline: 2px solid var(--accent);
      outline-offset: 2px;
    }

    .home-carousel__tabs--glider .home-carousel__tab {
      appearance: none;
      -webkit-appearance: none;
      position: relative;
      z-index: 2;
      display: flex;
      align-items: center;
      justify-content: center;
      flex: 1 1 0;
      min-width: 0;
      padding: 5px 10px;
      margin: 0;
      border: none;
      border-radius: 999px;
      font-family: inherit;
      font-size: 0.625rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      color: var(--ink-muted);
      background: transparent;
      cursor: pointer;
      transition: color 0.15s ease-in;
      -webkit-tap-highlight-color: transparent;
      text-align: center;
      white-space: nowrap;
    }

    .home-carousel__tabs--glider .home-carousel__tab:hover {
      color: var(--ink);
    }

    .home-carousel--stack .home-carousel__tabs--stack-head .home-carousel__tab {
      padding: 4px 4px;
      font-size: 0.625rem;
      font-weight: 700;
      border-radius: 7px;
    }

    .home-carousel__tabs--glider
      input.home-carousel__tab-radio:checked
      + .home-carousel__tab {
      color: var(--brand-deep);
    }

    .home-carousel__tabs--glider .home-carousel__tabs-glider {
      position: absolute;
      z-index: 1;
      top: 6px;
      bottom: 6px;
      left: 6px;
      width: calc((100% - 12px) / 3);
      border-radius: 999px;
      background-color: var(--accent-soft);
      transition: transform 0.22s ease-out;
      pointer-events: none;
      box-shadow: inset 0 0 0 1px rgba(234, 88, 12, 0.12);
    }

    /* Só no stack topo: mesmo retângulo da caixa, sem “pilula” grande */
    .home-carousel--stack .home-carousel__tabs--stack-head .home-carousel__tabs-gl .home-carousel__tabs-glider {
      top: 2px;
      bottom: 2px;
      left: 2px;
      width: calc((100% - 4px) / 3);
      border-radius: 8px;
      box-shadow: inset 0 0 0 1px rgba(234, 88, 12, 0.1);
    }

    .home-carousel__tabs--glider
      #home-stack-tab-mare:checked
      ~ .home-carousel__tabs-glider {
      transform: translateX(0);
    }

    .home-carousel__tabs--glider
      #home-stack-tab-tempo:checked
      ~ .home-carousel__tabs-glider {
      transform: translateX(100%);
    }

    .home-carousel__tabs--glider
      #home-stack-tab-lua:checked
      ~ .home-carousel__tabs-glider {
      transform: translateX(200%);
    }

    .home-carousel__tab {
      appearance: none;
      -webkit-appearance: none;
      font-family: inherit;
      font-size: 0.625rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      padding: 5px 10px;
      border-radius: 999px;
      border: 1px solid var(--line);
      background: #fafbfc;
      color: var(--ink-muted);
      cursor: pointer;
      transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
      -webkit-tap-highlight-color: transparent;
    }

    .home-carousel__tab:hover {
      border-color: #d1d5df;
      color: var(--ink);
    }

    .home-carousel__tab.is-active {
      background: var(--accent-soft);
      border-color: rgba(234, 88, 12, 0.45);
      color: var(--brand-deep);
      box-shadow: 0 0 0 1px rgba(234, 88, 12, 0.1);
    }

    .home-carousel__tab:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 1px;
    }

    /* Promo: mesmas proporções do hero do Explorar (21/9, 128px mín.) */
    .home-carousel--promo {
      margin: 2px 0 8px;
    }

    .home-carousel--promo .home-carousel__viewport {
      border-radius: 16px;
      border: 1px solid var(--line);
      box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
    }

    .home-carousel--promo .home-carousel__slide {
      min-height: 128px;
      aspect-ratio: 21 / 9;
      display: block;
      padding: 0;
      text-decoration: none;
      color: #fff;
      position: relative;
      overflow: hidden;
    }

    @supports not (aspect-ratio: 1) {
      .home-carousel--promo .home-carousel__slide {
        min-height: 128px;
      }
    }

    /* Barras de progresso (estilo iFood/Stories) */
    .home-carousel--promo .home-carousel__bars {
      position: absolute;
      left: 12px;
      right: 12px;
      bottom: 10px;
      display: flex;
      gap: 6px;
      z-index: 2;
    }
    .home-carousel__bar {
      flex: 1 1 0;
      height: 3px;
      padding: 0;
      border: 0;
      background: rgba(255, 255, 255, 0.32);
      border-radius: 999px;
      position: relative;
      overflow: hidden;
      cursor: pointer;
      -webkit-tap-highlight-color: transparent;
    }
    .home-carousel__bar.is-active {
      background: rgba(255, 255, 255, 0.45);
    }
    .home-carousel__bar-fill {
      position: absolute;
      left: 0;
      top: 0;
      bottom: 0;
      width: 0%;
      background: #fff;
      border-radius: 999px;
      pointer-events: none;
    }

    .home-carousel--promo .home-carousel__slide::after {
      display: none;
    }

    .home-carousel--promo .home-carousel__slide.promo-slide--bg {
      background-size: cover !important;
      background-position: center !important;
      background-repeat: no-repeat !important;
    }

    .home-carousel__slide--promo1 {
      background: linear-gradient(115deg, #c2410c 0%, #ea580c 42%, #fb923c 100%);
    }

    .home-carousel__slide--promo2 {
      background: linear-gradient(115deg, #1e3a5f 0%, #2563eb 45%, #38bdf8 100%);
    }

    .home-carousel__slide--promo3 {
      background: linear-gradient(115deg, #431407 0%, #9a3412 50%, #ea580c 100%);
    }

    .home-carousel--promo button.home-carousel__slide {
      font: inherit;
      border: none;
      appearance: none;
      -webkit-appearance: none;
      cursor: pointer;
      width: 100%;
      text-align: left;
      -webkit-tap-highlight-color: transparent;
    }
    .home-carousel--promo button.home-carousel__slide:focus-visible {
      outline: 2px solid rgba(255, 255, 255, 0.95);
      outline-offset: -4px;
    }

    .highlights-scroll button.highlight-card {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      padding: 0;
      margin: 0;
      font: inherit;
      color: inherit;
      text-align: left;
      appearance: none;
      -webkit-appearance: none;
      cursor: pointer;
      line-height: normal;
      box-sizing: border-box;
      -webkit-tap-highlight-color: transparent;
    }
    .highlights-scroll button.highlight-card .highlight-img {
      flex-shrink: 0;
      align-self: stretch;
      width: 100%;
    }
    .promos-scroll button.promo-card {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      padding: 16px;
      margin: 0;
      font: inherit;
      color: inherit;
      text-align: left;
      appearance: none;
      -webkit-appearance: none;
      cursor: pointer;
      line-height: normal;
      box-sizing: border-box;
      -webkit-tap-highlight-color: transparent;
    }
    button.highlight-card:focus-visible,
    button.promo-card:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 2px;
    }

    /* Section title */
    .section-title {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin: 22px 0 10px;
      padding: 0 2px;
    }

    .section-title h2 {
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }

    .section-title__icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex-shrink: 0;
    }

    .section-title h2 {
      margin: 0;
      font-family: var(--font-display);
      font-size: 1.125rem;
      font-weight: 600;
      color: var(--ink);
    }

    .section-title a {
      font-size: 0.8125rem;
      font-weight: 600;
      color: var(--brand-deep);
      text-decoration: none;
    }

    .section-title a:hover { text-decoration: underline; }

    /* SECTION HEADER (para Destaques/Promos) */
    .section-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 2px;
      margin: 22px 0 14px;
      gap: 12px;
    }

    .section-header .section-title {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--font-display);
      font-size: 1.125rem;
      font-weight: 700;
      letter-spacing: -0.3px;
      color: var(--ink);
    }

    .section-header .section-link {
      font-size: 0.8125rem;
      color: var(--brand-deep);
      font-weight: 600;
      cursor: pointer;
      text-decoration: none;
    }

    .section-header .section-link:hover { text-decoration: underline; }

    /* ── HIGHLIGHTS (Destaques da Semana) ── */
    .highlights-section { margin-bottom: 22px; }

    /* Ajuste de “respiro” entre banner e destaques */
    .home-carousel--promo + .highlights-section .section-header {
      margin-top: 12px;
    }

    .highlights-scroll {
      display: flex;
      gap: 14px;
      padding: 0 16px;
      margin: 0 -16px;
      overflow-x: auto;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
      overscroll-behavior-x: contain;
      scroll-snap-type: x mandatory;
      scroll-padding-left: 16px;
      scroll-padding-right: 16px;
    }
    .highlights-scroll::-webkit-scrollbar { display: none; }

    .highlight-card {
      flex: 0 0 220px;
      border-radius: var(--radius-lg);
      overflow: hidden;
      position: relative;
      cursor: pointer;
      background: #fff;
      border: 1px solid var(--line);
      box-shadow: var(--shadow-sm);
      transition: transform .2s;
      scroll-snap-align: start;
    }
    .highlight-card:active { transform: scale(.97); }

    .highlight-img {
      width: 100%;
      height: 140px;
      display: flex;
      align-items: center;
      justify-content: center;
      background-size: cover;
      background-position: center;
      position: relative;
    }

    .highlight-img::after {
      content: "";
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.15), transparent 55%);
      pointer-events: none;
    }

    .himg-1 { background: linear-gradient(135deg, #1a1040, #2d1b69, #4c1d95); }
    .himg-2 { background: linear-gradient(135deg, #0c2a1e, #065f46, #047857); }
    .himg-3 { background: linear-gradient(135deg, #1c1008, #92400e, #b45309); }
    .himg-4 { background: linear-gradient(135deg, #0f172a, #1e3a5f, #1e40af); }

    .himg-icon {
      width: 52px;
      height: 52px;
      display: grid;
      place-items: center;
      color: rgba(255,255,255,0.92);
      filter: drop-shadow(0 6px 22px rgba(0,0,0,.35));
      z-index: 1;
    }

    .himg-icon svg { width: 44px; height: 44px; }

    .highlight-tag {
      position: absolute;
      top: 12px; left: 12px;
      padding: 4px 10px;
      border-radius: 20px;
      font-size: 0.6875rem;
      font-weight: 700;
      letter-spacing: .5px;
      text-transform: uppercase;
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
    }
    .tag-festa { background: rgba(124,92,252,.7); color: #e9d5ff; }
    .tag-gastronomia { background: rgba(234,88,12,.7); color: #ffedd5; }
    .tag-praia { background: rgba(56,189,248,.7); color: #e0f2fe; }
    .tag-cultura { background: rgba(251,146,60,.7); color: #fff7ed; }
    .tag-bemestar { background: rgba(34,197,94,.65); color: #ecfdf5; }
    .tag-musica { background: rgba(99,102,241,.65); color: #eef2ff; }

    .highlight-body { padding: 14px 14px 16px; }
    .highlight-name {
      font-family: var(--font-display);
      font-size: 0.95rem;
      font-weight: 700;
      letter-spacing: -.2px;
      margin-bottom: 6px;
      line-height: 1.2;
      color: var(--ink);
    }
    .highlight-meta {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 0.75rem;
      color: var(--ink-faint);
    }
    .highlight-meta svg { width: 12px; height: 12px; flex-shrink: 0; }

    /* ── PROMOS (Promoções Hoje) ── */
    .promos-section { margin-bottom: 22px; }

    .promos-scroll {
      display: flex;
      gap: 12px;
      padding: 0 16px;
      margin: 0 -16px;
      overflow-x: auto;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
      overscroll-behavior-x: contain;
      scroll-snap-type: x mandatory;
      scroll-padding-left: 16px;
      scroll-padding-right: 16px;
    }
    .promos-scroll::-webkit-scrollbar { display: none; }

    .promos-scroll .promo-card {
      flex: 0 0 200px;
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-lg);
      padding: 16px;
      cursor: pointer;
      position: relative;
      overflow: hidden;
      transition: all .2s;
      box-shadow: var(--shadow-sm);
      scroll-snap-align: start;
    }
    .promos-scroll .promo-card:active { transform: scale(.97); }

    .promos-scroll .promo-badge {
      position: absolute;
      top: 0; right: 0;
      background: var(--accent);
      color: #fff;
      font-family: var(--font-display);
      font-size: 0.8125rem;
      font-weight: 800;
      padding: 6px 12px;
      border-bottom-left-radius: 12px;
    }

    .promos-scroll .promo-icon {
      width: 34px;
      height: 34px;
      border-radius: 12px;
      background: var(--accent-soft);
      border: 1px solid rgba(234, 88, 12, 0.18);
      display: grid;
      place-items: center;
      margin-bottom: 12px;
      color: var(--accent);
    }

    .promos-scroll .promo-icon svg { width: 18px; height: 18px; }

    .promos-scroll .promo-place {
      font-size: 0.6875rem;
      color: var(--ink-faint);
      text-transform: uppercase;
      letter-spacing: .8px;
      font-weight: 600;
      margin-bottom: 4px;
    }

    .promos-scroll .promo-title {
      font-family: var(--font-display);
      font-size: 0.9rem;
      font-weight: 700;
      letter-spacing: -.2px;
      line-height: 1.3;
      margin-bottom: 10px;
      color: var(--ink);
    }

    .promos-scroll .promo-expiry {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 0.75rem;
      color: var(--ink-faint);
    }
    .promos-scroll .promo-expiry svg { width: 12px; height: 12px; }

    @media (min-width: 900px) {
      .highlights {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        overflow: visible;
        margin: 0;
        padding: 0;
      }
    }

    .h-card {
      flex: 0 0 min(74%, 320px);
      scroll-snap-align: start;
      border-radius: var(--radius-lg);
      background: var(--bg-elevated);
      border: 1px solid var(--line);
      box-shadow: var(--shadow-sm);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      aspect-ratio: 1 / 1;
      min-height: 260px;
    }

    @media (min-width: 900px) {
      .h-card { flex: none; min-height: 280px; }
    }

    .h-thumb {
      flex: 1 1 auto;
      min-height: 56%;
      background: linear-gradient(135deg, #ea580c 0%, #c2410c 45%, #fb923c 100%);
      position: relative;
    }

    .h-thumb::after {
      content: "";
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.15), transparent 55%);
    }

    .h-badge {
      position: absolute;
      top: 10px;
      left: 10px;
      z-index: 1;
      font-size: 0.6875rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      padding: 5px 8px;
      border-radius: 8px;
      background: rgba(255,255,255,0.95);
      color: var(--brand-deep);
    }

    .h-body {
      padding: 12px 12px 12px;
      flex: 0 0 auto;
      display: flex;
      flex-direction: column;
    }

    .h-body h3 {
      margin: 0 0 6px;
      font-family: var(--font-display);
      font-size: 1rem;
      font-weight: 700;
      letter-spacing: -0.01em;
    }

    .h-body p {
      margin: 0;
      font-size: 0.8125rem;
      color: var(--ink-muted);
      line-height: 1.5;
      flex: 0 0 auto;
      overflow: hidden;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
    }

    .h-meta {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-top: 10px;
      font-size: 0.75rem;
      color: var(--ink-faint);
    }

    .h-meta svg { flex-shrink: 0; }
