/*
Theme Name: Oliva — Cozinha & Bar
Theme URI: https://oliva.com.br
Author: Estúdio (handoff de design)
Author URI: https://oliva.com.br
Description: Tema institucional mobile-first para restaurante. Design System como fonte da verdade (cores, fontes, logo e ícones via theme.json + CSS custom properties). Acompanha CPTs de Cardápio, Galeria, Novidades e Avisos, papéis Admin/Gerente e múltiplos templates de página inicial.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: oliva
Tags: restaurant, mobile-first, custom-colors, full-site-editing, translation-ready
*/

/* ──────────────────────────────────────────────────────────────
   IMPORTANTE — NADA HARDCODED
   Todas as cores, fontes, raios e espaçamentos vêm das CSS custom
   properties geradas pelo theme.json (prefixo --wp--preset--*) e
   espelhadas em variáveis semânticas abaixo. Editar o Design System
   no admin reescreve estes valores; o CSS apenas os consome.
   ────────────────────────────────────────────────────────────── */

:root {
  /* Espelho semântico dos presets do theme.json.
     Estes são os ÚNICOS nomes que os templates devem usar. */
  --oliva-primary:  var(--wp--preset--color--primary,  #C75D36);
  --oliva-ink:      var(--wp--preset--color--ink,      #211B15);
  --oliva-bg:       var(--wp--preset--color--bg,       #F1EDE4);
  --oliva-surface:  var(--wp--preset--color--surface,  #FFFFFF);
  --oliva-accent:   var(--wp--preset--color--accent,   #5A6648);
  --oliva-muted:    var(--wp--preset--color--muted,    #8C7D6C);

  --oliva-font-display: var(--wp--preset--font-family--display, 'Fraunces', serif);
  --oliva-font-body:    var(--wp--preset--font-family--body, 'Hanken Grotesk', sans-serif);

  --oliva-radius:   var(--wp--custom--radius, 12px);
  --oliva-maxw:     460px; /* largura mobile-first do conteúdo */
}

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

body {
  margin: 0;
  /* Fundo atrás da "coluna" do site (visível só no desktop). */
  background: var(--oliva-ink);
  color: var(--oliva-ink);
  font-family: var(--oliva-font-body);
  -webkit-font-smoothing: antialiased;
}

/* ── Moldura: o site inteiro é uma coluna centrada (igual ao protótipo) ── */
.oliva-frame {
  max-width: 480px;
  margin: 0 auto;
  background: var(--oliva-bg);
  min-height: 100vh;
  position: relative;
  box-shadow: 0 0 70px rgba(0,0,0,.45);
}
/* Dentro da moldura, o shell ocupa toda a largura (a moldura já limita). */
.oliva-frame .oliva-shell { max-width: 100%; }

h1, h2, h3, .oliva-display { font-family: var(--oliva-font-display); font-weight: 500; }

a { color: inherit; }

.oliva-shell { max-width: var(--oliva-maxw); margin: 0 auto; }

.oliva-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-weight: 700; text-decoration: none; cursor: pointer; border: none;
  border-radius: var(--oliva-radius);
  padding: 14px 20px;
}
.oliva-btn--primary { background: var(--oliva-primary); color: #fff; }
.oliva-btn--ink     { background: var(--oliva-ink); color: var(--oliva-bg); }
.oliva-btn--ghost   { background: transparent; color: var(--oliva-ink); border: 1px solid color-mix(in srgb, var(--oliva-ink) 22%, transparent); }

/* Faixa de avisos global (CPT oliva_aviso) */
.oliva-notice-bar {
  background: var(--oliva-primary); color: #fff;
  font-size: 13px; font-weight: 600; text-align: center;
  padding: 9px 16px;
}

/* Respeita preferência de movimento reduzido */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* Alvo de toque mínimo 44px (acessibilidade mobile) */
.oliva-tap { min-width: 44px; min-height: 44px; }

/* ──────────────────────────────────────────────────────────────
   COMPONENTES — todos consomem as CSS custom properties acima.
   Nenhuma cor/fonte fixa: só var(--oliva-*) e color-mix sobre elas.
   ────────────────────────────────────────────────────────────── */

.oliva-shell { padding-left: 18px; padding-right: 18px; }
.oliva-main { display: block; }

/* Rótulo/kicker monoespaçado */
.oliva-kicker {
  font-family: var(--oliva-font-body);
  font-size: 10px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--oliva-muted); margin: 0 0 12px;
}
.oliva-kicker--accent { color: var(--oliva-primary); }

/* Revelar ao rolar (app.js adiciona .is-visible) */
[data-screen-label] { opacity: 1; }
@media (prefers-reduced-motion: no-preference) {
  [data-screen-label] { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
  [data-screen-label].is-visible { opacity: 1; transform: none; }
}

/* ── Header / topbar ── */
.oliva-topbar {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--oliva-bg) 88%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent);
}
.oliva-topbar__inner {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 18px; justify-content: space-between;
}
.oliva-brand { text-decoration: none; display: flex; flex-direction: column; line-height: 1.1; }
.oliva-brand__name { font-family: var(--oliva-font-display); font-size: 20px; letter-spacing: .5px; }
.oliva-brand__tag { font-size: 10px; color: var(--oliva-muted); letter-spacing: 1px; text-transform: uppercase; }
.oliva-topbar__cta { padding: 9px 16px; font-size: 13px; }
.oliva-nav { border-top: 1px solid color-mix(in srgb, var(--oliva-ink) 7%, transparent); }
.oliva-nav__list {
  list-style: none; display: flex; gap: 18px; margin: 0; padding: 10px 18px;
  overflow-x: auto; scrollbar-width: none;
}
.oliva-nav__list::-webkit-scrollbar { display: none; }
.oliva-nav__list li { white-space: nowrap; }
.oliva-nav__list a { text-decoration: none; font-size: 13px; font-weight: 600; color: var(--oliva-ink); }
.oliva-nav__list .current-menu-item a { color: var(--oliva-primary); }

/* ── Footer ── */
.oliva-footer {
  margin-top: 48px; padding: 36px 0;
  background: color-mix(in srgb, var(--oliva-ink) 96%, #000);
  color: var(--oliva-bg);
}
.oliva-footer__brand { font-size: 24px; margin-bottom: 14px; }
.oliva-footer__menu { list-style: none; display: flex; flex-wrap: wrap; gap: 14px; margin: 0 0 18px; padding: 0; }
.oliva-footer__menu a { text-decoration: none; font-size: 13px; opacity: .85; }
.oliva-footer__legal { font-size: 12px; line-height: 1.6; color: color-mix(in srgb, var(--oliva-bg) 65%, transparent); }

/* ── FAB ── */
.oliva-fab { position: fixed; right: 16px; bottom: 16px; z-index: 70; display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.oliva-fab__panel { display: flex; flex-direction: column; gap: 8px; }
.oliva-fab__panel[hidden] { display: none; } /* respeita o atributo hidden (FAB fechado) */
.oliva-fab__item {
  text-decoration: none; background: var(--oliva-surface); color: var(--oliva-ink);
  font-size: 14px; font-weight: 600; padding: 11px 16px; border-radius: 999px;
  box-shadow: 0 6px 20px rgba(0,0,0,.18); white-space: nowrap;
}
.oliva-fab__toggle {
  width: 56px; height: 56px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--oliva-primary); color: #fff; font-size: 22px;
  box-shadow: 0 8px 24px color-mix(in srgb, var(--oliva-primary) 45%, transparent);
}
/* No desktop, ancora o FAB na borda direita da coluna (não no canto da tela). */
@media (min-width: 520px) {
  .oliva-fab { right: calc(50% - 240px + 16px); }
}

/* ── Atalhos / badges ── */
.oliva-shortcuts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin: 18px auto; }
.oliva-shortcut {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  text-decoration: none; font-size: 11px; font-weight: 600;
  background: var(--oliva-surface); border-radius: var(--oliva-radius); padding: 12px 6px;
  border: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent);
}
.oliva-shortcut span { font-size: 20px; }
.oliva-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12px; font-weight: 600; padding: 6px 12px; border-radius: 999px;
  background: color-mix(in srgb, var(--oliva-surface) 80%, transparent); color: var(--oliva-ink);
}

/* ── Página: cabeçalho interno ── */
.oliva-pagehead {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 0 8px;
}
.oliva-pagehead__back { text-decoration: none; font-size: 14px; font-weight: 600; color: var(--oliva-muted); }
.oliva-pagehead__title { font-size: 20px; letter-spacing: 1px; }

/* ── HOME cinema: hero ── */
.oliva-hero { position: relative; min-height: 78vh; display: flex; align-items: flex-end; overflow: hidden; }
.oliva-hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.oliva-hero--cinema { background: radial-gradient(120% 100% at 60% 25%, color-mix(in srgb, var(--oliva-primary) 35%, var(--oliva-ink)), var(--oliva-ink)); color: #fff; }
.oliva-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.75) 100%); }
.oliva-hero__content { position: relative; padding: 0 18px 40px; }
.oliva-hero__kicker { font-size: 10px; letter-spacing: 3px; color: color-mix(in srgb, var(--oliva-primary) 60%, #fff); margin: 0 0 12px; }
.oliva-hero__title { font-family: var(--oliva-font-display); font-size: clamp(38px, 11vw, 60px); line-height: 1; margin: 0 0 12px; color: #fff; }
.oliva-hero__sub { font-size: 16px; line-height: 1.5; color: rgba(255,255,255,.82); margin: 0 0 18px; max-width: 30ch; }
.oliva-hero__badges { display: flex; gap: 8px; flex-wrap: wrap; }

/* Destaques (rail horizontal) */
.oliva-featured { margin-top: 32px; }
.oliva-featured h2 { font-size: 24px; margin: 0 0 16px; }
.oliva-featured__rail { display: flex; gap: 14px; overflow-x: auto; padding-bottom: 8px; scrollbar-width: none; }
.oliva-featured__rail::-webkit-scrollbar { display: none; }
.oliva-card {
  flex: 0 0 70%; background: var(--oliva-surface); border-radius: var(--oliva-radius); overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--oliva-ink) 7%, transparent);
}
.oliva-card img { width: 100%; height: 150px; object-fit: cover; display: block; }
.oliva-card h3 { margin: 12px 14px 4px; font-size: 18px; }
.oliva-card p { margin: 0 14px; font-size: 13px; color: var(--oliva-muted); line-height: 1.5; }
.oliva-card__price { display: block; margin: 8px 14px 14px; font-weight: 700; color: var(--oliva-primary); }
.oliva-featured .oliva-btn { margin-top: 16px; }

/* ── HOME editorial ── */
.oliva-marquee { overflow: hidden; background: var(--oliva-ink); color: var(--oliva-bg); padding: 9px 0; }
.oliva-marquee__track { display: inline-flex; white-space: nowrap; font-family: var(--oliva-font-body); font-size: 12px; letter-spacing: 2px; animation: oliva-marquee 22s linear infinite; }
@keyframes oliva-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.oliva-edhero { padding-top: 28px; }
.oliva-edhero__meta { display: flex; justify-content: space-between; font-size: 11px; letter-spacing: 1px; color: var(--oliva-muted); margin-bottom: 14px; }
.oliva-edhero__open { color: var(--oliva-accent); font-weight: 700; }
.oliva-edhero__title { font-family: var(--oliva-font-display); font-size: clamp(40px, 13vw, 68px); line-height: .98; margin: 0 0 20px; }
.oliva-edhero__title em { color: var(--oliva-primary); font-style: italic; }
.oliva-edhero__row { display: flex; gap: 16px; align-items: flex-end; justify-content: space-between; }
.oliva-edhero__lead { font-size: 15px; line-height: 1.6; color: var(--oliva-ink); margin: 0; max-width: 34ch; }
.oliva-edhero__stamp { white-space: nowrap; text-decoration: none; font-weight: 700; color: var(--oliva-primary); }
.oliva-index { margin-top: 36px; }
.oliva-index__head { display: flex; align-items: baseline; gap: 10px; border-bottom: 2px solid var(--oliva-ink); padding-bottom: 10px; margin-bottom: 8px; }
.oliva-index__head h2 { font-size: 26px; margin: 0; }
.oliva-index__sub { font-size: 11px; letter-spacing: 2px; color: var(--oliva-muted); }
.oliva-index__item { display: flex; align-items: center; gap: 14px; padding: 16px 0; text-decoration: none; border-bottom: 1px solid color-mix(in srgb, var(--oliva-ink) 10%, transparent); }
.oliva-index__num { font-family: var(--oliva-font-display); font-size: 18px; color: var(--oliva-primary); }
.oliva-index__body { flex: 1; }
.oliva-index__name { display: block; font-size: 18px; }
.oliva-index__desc { display: block; font-size: 13px; color: var(--oliva-muted); }
.oliva-index__price { font-weight: 700; color: var(--oliva-primary); }
.oliva-quote { margin: 40px auto; text-align: center; }
.oliva-quote__text { font-size: 22px; line-height: 1.45; margin: 0 0 16px; }
.oliva-quote__link { text-decoration: none; font-size: 12px; letter-spacing: 1px; font-weight: 700; color: var(--oliva-primary); }

/* ── HOME linkbio ── */
.oliva-bio { position: relative; min-height: 100vh; display: flex; align-items: center; color: #fff; overflow: hidden; }
/* Página "Links" (sem vídeo): fundo em gradiente dos tokens */
.oliva-bio--page { background: radial-gradient(120% 90% at 50% 0%, color-mix(in srgb, var(--oliva-primary) 35%, var(--oliva-ink)), var(--oliva-ink)); padding: 48px 0; }
.oliva-bio--page .oliva-bio__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, transparent, rgba(0,0,0,.35)); pointer-events: none; }
.oliva-bio__bg { position: absolute; inset: 0; background: var(--oliva-ink); }
.oliva-bio__video { width: 100%; height: 100%; object-fit: cover; }
.oliva-bio__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.8)); }
.oliva-bio__inner { position: relative; width: 100%; padding: 40px 18px; }
.oliva-bio__head { text-align: center; margin-bottom: 24px; }
.oliva-bio__name { font-size: 34px; margin: 12px 0 6px; color: #fff; }
.oliva-bio__tagline { font-size: 15px; color: rgba(255,255,255,.8); margin: 0; }
.oliva-bio__links { display: flex; flex-direction: column; gap: 10px; }
.oliva-bio__link {
  display: flex; align-items: center; gap: 14px; text-decoration: none;
  background: color-mix(in srgb, var(--oliva-surface) 14%, transparent);
  border: 1px solid rgba(255,255,255,.18); border-radius: var(--oliva-radius);
  padding: 14px 16px; color: #fff; backdrop-filter: blur(6px);
}
.oliva-bio__link.is-featured { background: var(--oliva-primary); border-color: var(--oliva-primary); }
.oliva-bio__icon { font-size: 22px; }
.oliva-bio__text { flex: 1; }
.oliva-bio__label { display: block; font-size: 16px; }
.oliva-bio__sub { display: block; font-size: 12px; color: rgba(255,255,255,.7); }
.oliva-bio__arrow { opacity: .7; }
.oliva-bio__social { display: flex; justify-content: center; gap: 22px; margin-top: 24px; font-size: 22px; }
.oliva-bio__social a { text-decoration: none; }

/* ── Cardápio (archive) ── */
.oliva-menu { padding-top: 24px; }
.oliva-menu__title { font-size: clamp(32px, 9vw, 46px); margin: 24px 0 8px; }
.oliva-menu__intro { color: var(--oliva-muted); font-size: 15px; margin: 0 0 8px; }
.oliva-menu__cat { font-size: 13px; letter-spacing: 2px; text-transform: uppercase; color: var(--oliva-primary); margin: 28px 0 10px; }
.oliva-menu__list { list-style: none; margin: 0; padding: 0; }
.oliva-menu__item { display: flex; align-items: center; gap: 12px; padding: 14px 0; border-bottom: 1px solid color-mix(in srgb, var(--oliva-ink) 10%, transparent); }
.oliva-menu__item.is-soldout { opacity: .55; }
.oliva-menu__thumb img { width: 56px; height: 56px; object-fit: cover; border-radius: 10px; display: block; }
.oliva-menu__body { flex: 1; }
.oliva-menu__name { display: block; font-size: 16px; }
.oliva-menu__badge { font-style: normal; font-size: 10px; font-weight: 700; color: var(--oliva-primary); margin-left: 6px; }
.oliva-menu__desc { display: block; font-size: 13px; color: var(--oliva-muted); }
.oliva-menu__price { font-weight: 700; color: var(--oliva-primary); white-space: nowrap; }
.oliva-menu__item .oliva-btn { padding: 9px 14px; font-size: 12px; }

/* ── Página Sobre ── */
.oliva-about { padding-bottom: 24px; }
.oliva-about__hero { position: relative; height: 320px; border-radius: var(--oliva-radius); overflow: hidden; margin: 12px 0 24px; display: flex; align-items: flex-end; background: radial-gradient(120% 100% at 60% 25%, color-mix(in srgb, var(--oliva-primary) 30%, var(--oliva-ink)), var(--oliva-ink)); }
.oliva-about__photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.oliva-about__heromask { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.85)); }
.oliva-about__herotext { position: relative; padding: 22px; color: #fff; }
.oliva-about__title { font-size: clamp(30px, 9vw, 40px); line-height: 1.05; margin: 0; color: #fff; }
.oliva-about__story p { font-size: 14.5px; line-height: 1.7; color: var(--oliva-ink); }
.oliva-about__lead { font-family: var(--oliva-font-display); font-size: 21px; line-height: 1.45; }
.oliva-about__values { margin-top: 30px; }
.oliva-values { display: flex; flex-direction: column; gap: 12px; }
.oliva-value { display: flex; gap: 14px; align-items: flex-start; padding: 16px; background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-ink) 7%, transparent); border-radius: var(--oliva-radius); }
.oliva-value__icon { font-size: 24px; }
.oliva-value__title { font-size: 17px; margin-bottom: 4px; }
.oliva-value__desc { font-size: 13px; color: var(--oliva-muted); line-height: 1.5; }
.oliva-stats { display: flex; align-items: stretch; text-align: center; margin: 24px 0; padding: 24px 0; background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-primary) 18%, transparent); border-radius: var(--oliva-radius); }
.oliva-stat { flex: 1; }
.oliva-stat__num { font-size: 30px; color: var(--oliva-primary); }
.oliva-stat__label { font-size: 10px; color: var(--oliva-muted); margin-top: 4px; }
.oliva-stats__sep { width: 1px; background: color-mix(in srgb, var(--oliva-ink) 10%, transparent); }
.oliva-about__cta, .oliva-contact__actions { display: flex; flex-direction: column; gap: 11px; margin-top: 24px; }
.oliva-about__cta .oliva-btn { flex: 1; }

/* ── Página Contato ── */
.oliva-contact { padding-bottom: 24px; }
.oliva-map { position: relative; display: block; height: 220px; border-radius: var(--oliva-radius); overflow: hidden; text-decoration: none; background: linear-gradient(135deg, color-mix(in srgb, var(--oliva-accent) 40%, var(--oliva-ink)), var(--oliva-ink)); margin: 12px 0 16px; }
.oliva-map__grid { position: absolute; inset: 0; background: repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 1px, transparent 1px 40px), repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 40px); }
.oliva-map__pin { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-60%); font-size: 34px; }
.oliva-map__hint { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); font-size: 10px; letter-spacing: 1px; color: rgba(255,255,255,.7); background: rgba(0,0,0,.4); padding: 5px 9px; border-radius: 6px; }
.oliva-infocard, .oliva-hours { background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent); border-radius: var(--oliva-radius); padding: 20px; margin-bottom: 14px; }
.oliva-info { display: flex; gap: 13px; align-items: flex-start; }
.oliva-info + .oliva-info { margin-top: 18px; }
.oliva-info__icon { font-size: 18px; width: 24px; }
.oliva-info__main { font-size: 15px; font-weight: 600; text-decoration: none; display: block; }
.oliva-info__sub { font-size: 13px; color: var(--oliva-muted); }
.oliva-hours__head { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; font-size: 18px; }
.oliva-hours__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.oliva-hours__row { display: flex; justify-content: space-between; font-size: 13.5px; padding: 11px 0; border-bottom: 1px solid color-mix(in srgb, var(--oliva-ink) 7%, transparent); }
.oliva-hours__row:last-child { border-bottom: none; }
.oliva-hours__time { font-weight: 600; color: var(--oliva-accent); }
.oliva-hours__row.is-closed .oliva-hours__time { color: var(--oliva-muted); }
.oliva-contact__row { display: flex; gap: 11px; }
.oliva-contact__row .oliva-btn { flex: 1; }

/* ── Página Galeria ── */
.oliva-chips { display: flex; gap: 8px; overflow-x: auto; padding: 8px 0 14px; scrollbar-width: none; }
.oliva-chips::-webkit-scrollbar { display: none; }
.oliva-chip { white-space: nowrap; cursor: pointer; font-family: var(--oliva-font-body); font-weight: 600; font-size: 13px; padding: 9px 16px; border-radius: 999px; background: var(--oliva-surface); color: var(--oliva-ink); border: 1px solid color-mix(in srgb, var(--oliva-ink) 12%, transparent); transition: all .2s ease; }
.oliva-chip.is-active { background: var(--oliva-primary); color: #fff; border-color: var(--oliva-primary); }
.oliva-masonry { columns: 2; column-gap: 10px; }
.oliva-tile { width: 100%; min-height: 130px; break-inside: avoid; margin-bottom: 10px; border: none; padding: 0; cursor: pointer; border-radius: var(--oliva-radius); position: relative; overflow: hidden; background: radial-gradient(100% 100% at 30% 30%, color-mix(in srgb, var(--oliva-primary) 30%, var(--oliva-ink)), var(--oliva-ink)); display: block; }
.oliva-tile__img { width: 100%; display: block; }
.oliva-tile__label { position: absolute; bottom: 8px; left: 8px; font-size: 9px; letter-spacing: 1px; color: rgba(255,255,255,.8); background: rgba(0,0,0,.45); padding: 3px 6px; border-radius: 5px; }
.oliva-lightbox { position: fixed; inset: 0; z-index: 95; background: rgba(0,0,0,.94); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; }
.oliva-lightbox[hidden] { display: none; }
.oliva-lightbox__close { position: absolute; top: 18px; right: 18px; width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.08); color: #fff; font-size: 18px; cursor: pointer; }
.oliva-lightbox__figure { margin: 0; max-width: 400px; width: 100%; }
.oliva-lightbox__img { width: 100%; max-height: 70vh; object-fit: contain; border-radius: var(--oliva-radius); }
.oliva-lightbox__cap { color: rgba(255,255,255,.75); font-size: 12px; text-align: center; margin-top: 10px; }
.oliva-lightbox__nav { display: flex; align-items: center; gap: 20px; margin-top: 22px; }
.oliva-lightbox__btn { width: 50px; height: 50px; border-radius: 50%; border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.08); color: #fff; font-size: 20px; cursor: pointer; }
.oliva-lightbox__count { font-size: 11px; color: rgba(255,255,255,.7); }

/* ── Página Avaliações ── */
.oliva-rating { background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent); border-radius: var(--oliva-radius); padding: 24px; text-align: center; margin: 12px 0 16px; }
.oliva-rating__src { display: inline-flex; align-items: center; gap: 7px; font-size: 11px; color: var(--oliva-muted); margin-bottom: 14px; }
.oliva-rating__g { width: 18px; height: 18px; border-radius: 50%; background: #fff; color: #4285F4; display: grid; place-items: center; font-weight: 800; font-size: 12px; border: 1px solid color-mix(in srgb, var(--oliva-ink) 10%, transparent); }
.oliva-rating__score { display: flex; align-items: baseline; justify-content: center; gap: 12px; }
.oliva-rating__num { font-size: 64px; line-height: 1; }
.oliva-rating__stars { color: var(--oliva-primary); font-size: 18px; letter-spacing: 2px; }
.oliva-rating__count { font-size: 11px; color: var(--oliva-muted); margin-top: 3px; }
.oliva-rating__dist { margin-top: 20px; display: flex; flex-direction: column; gap: 6px; }
.oliva-rating__bar { display: flex; align-items: center; gap: 8px; }
.oliva-rating__barlabel { font-size: 10px; color: var(--oliva-muted); width: 28px; text-align: left; }
.oliva-rating__track { flex: 1; height: 6px; border-radius: 3px; background: color-mix(in srgb, var(--oliva-ink) 10%, transparent); overflow: hidden; }
.oliva-rating__fill { display: block; height: 100%; background: var(--oliva-primary); }
.oliva-rating .oliva-btn { margin-top: 20px; width: 100%; }
.oliva-reviewlist { display: flex; flex-direction: column; gap: 11px; }
.oliva-review { background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent); border-radius: var(--oliva-radius); padding: 17px; }
.oliva-review__head { display: flex; align-items: center; gap: 11px; margin-bottom: 10px; }
.oliva-review__avatar { width: 36px; height: 36px; border-radius: 50%; background: color-mix(in srgb, var(--oliva-accent) 35%, var(--oliva-bg)); display: grid; place-items: center; font-size: 14px; font-weight: 700; }
.oliva-review__who { flex: 1; }
.oliva-review__name { font-size: 13.5px; font-weight: 600; }
.oliva-review__when { font-size: 10px; color: var(--oliva-muted); }
.oliva-review__stars { color: var(--oliva-primary); font-size: 12px; letter-spacing: 1px; }
.oliva-review__text { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--oliva-ink); }
.oliva-feedback { margin-top: 24px; background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-primary) 18%, transparent); border-radius: var(--oliva-radius); padding: 22px; }
.oliva-feedback__title { font-size: 21px; margin-bottom: 4px; }
.oliva-feedback__sub { font-size: 12.5px; color: var(--oliva-muted); margin: 0 0 14px; }
.oliva-feedback__hint { font-size: 13px; color: var(--oliva-ink); line-height: 1.6; background: color-mix(in srgb, var(--oliva-primary) 8%, transparent); padding: 12px 14px; border-radius: 10px; }

/* ── Seções da home (teasers) ── */
.oliva-arrowlink { text-decoration: none; font-weight: 700; font-size: 14px; color: var(--oliva-primary); white-space: nowrap; }

.oliva-home-sobre { margin-top: 40px; }
.oliva-home-sobre__title { font-size: 27px; line-height: 1.18; margin: 0 0 14px; }
.oliva-home-sobre__text { font-size: 14.5px; line-height: 1.6; color: var(--oliva-muted); margin: 0 0 18px; }

.oliva-home-galeria { margin-top: 40px; }
.oliva-home-galeria__head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 16px; }
.oliva-home-galeria__head h2 { font-size: 26px; margin: 0; }
.oliva-home-galeria__grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 96px; gap: 8px; }
.oliva-gtile { position: relative; border-radius: 14px; overflow: hidden; text-decoration: none; background-color: color-mix(in srgb, var(--oliva-ink) 14%, var(--oliva-bg)); background-size: cover; background-position: center; }
.oliva-gtile.is-big { grid-column: span 2; grid-row: span 2; }
.oliva-gtile__label { position: absolute; bottom: 8px; left: 8px; font-size: 9px; color: #fff; background: rgba(0,0,0,.5); padding: 3px 6px; border-radius: 5px; }

.oliva-home-reviews { margin-top: 44px; padding: 36px 0; background: color-mix(in srgb, var(--oliva-ink) 4%, var(--oliva-bg)); border-top: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent); border-bottom: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent); }
.oliva-home-reviews__head { text-align: center; margin-bottom: 22px; }
.oliva-home-reviews__head .oliva-rating__score { justify-content: center; }
.oliva-home-reviews__rail { display: flex; gap: 12px; overflow-x: auto; padding: 4px 18px; scrollbar-width: none; }
.oliva-home-reviews__rail::-webkit-scrollbar { display: none; }
.oliva-rcard { flex: 0 0 270px; background: var(--oliva-surface); border: 1px solid color-mix(in srgb, var(--oliva-ink) 8%, transparent); border-radius: var(--oliva-radius); padding: 18px; }
.oliva-rcard__stars { color: var(--oliva-primary); font-size: 13px; letter-spacing: 2px; margin-bottom: 10px; }
.oliva-rcard__text { margin: 0 0 14px; font-size: 13.5px; line-height: 1.5; color: var(--oliva-ink); }
.oliva-rcard__who { display: flex; align-items: center; gap: 10px; }
.oliva-home-reviews__cta { display: flex; gap: 11px; margin-top: 20px; }
.oliva-home-reviews__cta .oliva-btn { flex: 1; }

.oliva-home-local { margin-top: 40px; }
.oliva-home-local__title { font-size: 27px; margin: 0 0 18px; }
.oliva-map--compact { height: 170px; margin-top: 0; }
.oliva-home-local__info { display: flex; flex-direction: column; gap: 14px; margin: 20px 0; }

/* ── Ícones SVG ── */
.oliva-ic { width: 20px; height: 20px; display: inline-block; vertical-align: middle; flex: 0 0 auto; }
.oliva-btn .oliva-ic { width: 18px; height: 18px; }

/* ── Carrossel (loop, setas, dots, swipe) ── */
.oliva-carousel { position: relative; margin: 8px 0; }
.oliva-carousel__viewport { overflow: hidden; }
.oliva-carousel__track { display: flex; gap: 14px; will-change: transform; touch-action: pan-y; }
.oliva-carousel__slide { flex: 0 0 80%; }
.oliva-carousel__slide.oliva-card { flex: 0 0 80%; }
.oliva-carousel--gallery .oliva-carousel__slide { flex: 0 0 62%; }
.oliva-gcard { height: 210px; border-radius: var(--oliva-radius); background-size: cover; background-position: center; position: relative; overflow: hidden; background-color: color-mix(in srgb, var(--oliva-ink) 14%, var(--oliva-bg)); background-image: radial-gradient(100% 100% at 30% 30%, color-mix(in srgb, var(--oliva-primary) 28%, var(--oliva-ink)), var(--oliva-ink)); }
.oliva-gcard .oliva-tile__label { position: absolute; bottom: 8px; left: 8px; font-size: 9px; color: #fff; background: rgba(0,0,0,.5); padding: 3px 6px; border-radius: 5px; }
.oliva-carousel__arrow { position: absolute; top: 42%; transform: translateY(-50%); width: 38px; height: 38px; border-radius: 50%; border: none; background: var(--oliva-surface); color: var(--oliva-ink); box-shadow: 0 4px 14px rgba(0,0,0,.2); cursor: pointer; display: grid; place-items: center; z-index: 2; }
.oliva-carousel__arrow .oliva-ic { width: 18px; height: 18px; }
.oliva-carousel__arrow--prev { left: 4px; }
.oliva-carousel__arrow--prev .oliva-ic { transform: scaleX(-1); }
.oliva-carousel__arrow--next { right: 4px; }
.oliva-carousel__dots { display: flex; gap: 7px; justify-content: center; margin-top: 14px; }
.oliva-carousel__dot { width: 8px; height: 8px; border-radius: 999px; border: none; padding: 0; cursor: pointer; background: color-mix(in srgb, var(--oliva-ink) 22%, transparent); transition: all .25s ease; }
.oliva-carousel__dot.is-active { background: var(--oliva-primary); width: 22px; }

/* ── Ícones em componentes ── */
.oliva-shortcut__ic { display: grid; place-items: center; color: var(--oliva-primary); }
.oliva-shortcut__ic .oliva-ic { width: 24px; height: 24px; }
.oliva-info__icon { color: var(--oliva-primary); display: inline-flex; }
.oliva-info__icon .oliva-ic { width: 20px; height: 20px; }
.oliva-hours__head .oliva-ic { color: var(--oliva-primary); }
.oliva-map__pin { color: #fff; }
.oliva-map__pin .oliva-ic { width: 34px; height: 34px; filter: drop-shadow(0 4px 8px rgba(0,0,0,.5)); }

/* FAB com ícones (alterna abrir/fechar) */
.oliva-fab__toggle { display: grid; place-items: center; }
.oliva-fab__toggle .oliva-ic { width: 24px; height: 24px; }
.oliva-fab__ico-close { display: none; }
.oliva-fab__toggle.is-open .oliva-fab__ico-open { display: none; }
.oliva-fab__toggle.is-open .oliva-fab__ico-close { display: inline-flex; }
.oliva-fab__item { display: inline-flex; align-items: center; gap: 9px; }
.oliva-fab__item .oliva-ic { width: 18px; height: 18px; color: var(--oliva-primary); }

/* ── Conteúdo genérico ── */
.oliva-content { padding: 24px 18px 0; }
.oliva-prose { font-size: 15px; line-height: 1.7; }
.oliva-prose h2 { font-size: 24px; margin-top: 28px; }
.oliva-prose img { max-width: 100%; height: auto; border-radius: var(--oliva-radius); }
.oliva-empty { color: var(--oliva-muted); padding: 40px 0; text-align: center; }
