/* =====================================================================
   Diretório de Porto Santo — Identidade visual
   Conceito: a linha do horizonte dourada (areia + mar)
   Paleta: areia, dourado, oceano, turquesa, tinta
   ===================================================================== */

:root {
  --areia:      #FAF4E9;
  --areia-2:    #F2E7D0;
  --dourado:    #D9A441;
  --dourado-2:  #C68A2E;
  --oceano:     #1C6E8C;
  --oceano-2:   #12506A;
  --turquesa:   #4FB3C4;
  --tinta:      #2B2A26;
  --tinta-3:    #6E6B61;
  --branco:     #FFFFFF;
  --linha:      #E7DCC6;
  --sombra:     0 1px 2px rgba(43,42,38,.05), 0 8px 24px rgba(43,42,38,.06);
  --raio:       14px;
  --raio-sm:    9px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  color: var(--tinta);
  background: var(--areia);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: "Fraunces", Georgia, "Times New Roman", serif;
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.01em;
  margin: 0 0 .5em;
}

a { color: var(--oceano); text-decoration: none; }
a:hover { color: var(--oceano-2); }

img { max-width: 100%; display: block; }

.cont { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.cont--estreito { max-width: 720px; }

/* ----- Linha do horizonte (elemento de assinatura) ------------------- */
.horizonte {
  height: 2px;
  border: 0;
  margin: 0;
  background: linear-gradient(90deg, transparent, var(--dourado) 25%, var(--dourado-2) 50%, var(--dourado) 75%, transparent);
  opacity: .8;
}

/* ----- Barra de navegação -------------------------------------------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,244,233,.86);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--linha);
}
.nav__in { display: flex; align-items: center; justify-content: space-between; height: 68px; }
.marca { display: flex; align-items: center; gap: 11px; font-family: "Fraunces", serif; font-size: 1.18rem; font-weight: 600; color: var(--tinta); }
.marca__sol {
  width: 26px; height: 26px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #F4D58A, var(--dourado) 60%, var(--dourado-2));
  box-shadow: 0 0 0 4px rgba(217,164,65,.18);
  flex: 0 0 auto;
}
.marca small { display:block; font-family:"Inter",sans-serif; font-weight:500; font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color: var(--tinta-3); }
.nav__acoes { display: flex; align-items: center; gap: 10px; }

/* ----- Botões -------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px; justify-content: center;
  font: inherit; font-weight: 600; font-size: .92rem;
  padding: 11px 20px; border-radius: 999px; border: 1px solid transparent;
  cursor: pointer; transition: transform .08s ease, background .15s ease, box-shadow .15s ease;
  text-decoration: none; white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--principal { background: var(--oceano); color: #fff; }
.btn--principal:hover { background: var(--oceano-2); color:#fff; }
.btn--ouro { background: var(--dourado); color: #3a2c08; }
.btn--ouro:hover { background: var(--dourado-2); color:#3a2c08; }
.btn--linha { background: transparent; border-color: var(--linha); color: var(--tinta); }
.btn--linha:hover { border-color: var(--oceano); color: var(--oceano); }
.btn--bloco { width: 100%; }
.btn--peq { padding: 7px 14px; font-size: .82rem; }
.btn--perigo { background: #fff; border-color:#e7c3c3; color:#a33; }
.btn--perigo:hover { background:#fbeeee; }

/* ----- Hero ---------------------------------------------------------- */
.hero { position: relative; overflow: hidden; }
.hero__ceu {
  background:
    radial-gradient(1200px 380px at 50% -120px, rgba(79,179,196,.30), transparent 70%),
    linear-gradient(180deg, #EAF5F4 0%, var(--areia) 78%);
  padding: 74px 0 0;
}
.hero__txt { max-width: 760px; }
.hero h1 { font-size: clamp(2.3rem, 5.2vw, 3.7rem); }
.hero h1 .grifo { color: var(--dourado-2); font-style: italic; }
.hero p.lead { font-size: 1.16rem; color: var(--tinta-3); max-width: 560px; margin-top: .2em; }
.hero__faixa { height: 86px; margin-top: 38px;
  background:
    radial-gradient(60px 60px at 84% 8%, rgba(244,213,138,.9), transparent 60%),
    linear-gradient(180deg, #EBD9A6 0%, var(--dourado) 55%, var(--dourado-2) 100%);
  position: relative;
}
.hero__faixa::before { content:""; position:absolute; inset:0 0 auto; height:2px; background: rgba(255,255,255,.45); }

/* destaque de números no hero */
.hero__topo { display:flex; gap:36px; align-items:flex-start; justify-content:space-between; flex-wrap:wrap; }
.hero__stats { flex:0 0 auto; width:330px; max-width:100%; margin-top:6px;
  background:rgba(255,255,255,.8); -webkit-backdrop-filter:blur(5px); backdrop-filter:blur(5px);
  border:1px solid rgba(217,164,65,.45); border-radius:20px; padding:24px 26px;
  box-shadow:0 18px 44px rgba(28,110,140,.16); }
.hero__stats-topo { display:flex; align-items:center; gap:14px; text-align:left; }
.hero__stats-num { font-family:Fraunces,serif; font-weight:600; font-size:3.6rem; line-height:.9; color:var(--oceano); }
.hero__stats-rot { font-weight:600; color:var(--tinta); line-height:1.15; }
.hero__stats-cats { list-style:none; margin:16px 0 0; padding:0; }
.hero__stats-cats li { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:6px 0; border-top:1px solid rgba(217,164,65,.22); }
.hero__stats-cats li:first-child { border-top:none; }
.hero__stats-cat { color:var(--tinta); font-size:.95rem; }
.hero__stats-n { font-family:Fraunces,serif; font-weight:600; color:var(--oceano); background:var(--areia-2); min-width:30px; text-align:center; border-radius:999px; padding:1px 9px; font-size:.95rem; }
.hero__stats-linha { height:3px; width:54px; margin:16px 0; background:linear-gradient(90deg,var(--dourado),var(--dourado-2)); border-radius:3px; }
.hero__stats-ult span { display:block; font-size:.74rem; text-transform:uppercase; letter-spacing:.05em; color:var(--tinta-3); }
.hero__stats-ult strong { display:block; color:var(--oceano); font-size:1.02rem; margin-top:3px; }
@media (max-width:820px) { .hero__stats { width:100%; } .hero__topo { gap:22px; } }

/* ----- Pesquisa ------------------------------------------------------ */
.pesquisa { display: flex; gap: 10px; margin-top: 30px; max-width: 620px; }
.pesquisa input[type=search] {
  flex: 1; font: inherit; padding: 14px 18px; border-radius: 999px;
  border: 1px solid var(--linha); background: #fff; box-shadow: var(--sombra);
}
.pesquisa input[type=search]:focus { outline: 2px solid var(--turquesa); border-color: transparent; }

/* ----- Chips de categoria -------------------------------------------- */
.chips { display: flex; flex-wrap: wrap; gap: 9px; margin: 26px 0 4px; }
.chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 15px; border-radius: 999px; font-size: .88rem; font-weight: 500;
  background: #fff; border: 1px solid var(--linha); color: var(--tinta);
}
.chip:hover { border-color: var(--oceano); color: var(--oceano); }
.chip--ativo { background: var(--oceano); border-color: var(--oceano); color: #fff; }
.chip--ativo:hover { color:#fff; }

/* ----- Secções ------------------------------------------------------- */
.sec { padding: 46px 0; }
.sec__cab { display: flex; align-items: baseline; justify-content: space-between; gap: 14px; margin-bottom: 22px; }
.sec__cab h2 { font-size: 1.7rem; margin: 0; }
.eyebrow { font-family:"Inter",sans-serif; font-size: .72rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--dourado-2); margin: 0 0 4px; }

/* ----- Grelha de cartões --------------------------------------------- */
.grelha { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 22px; }
.cartao {
  background: #fff; border: 1px solid var(--linha); border-radius: var(--raio);
  overflow: hidden; box-shadow: var(--sombra); transition: transform .14s ease, box-shadow .14s ease;
  display: flex; flex-direction: column;
}
.cartao:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(43,42,38,.12); }
.cartao__img { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--areia-2), #EAF5F4); position: relative; overflow:hidden; }
.cartao__img img { width:100%; height:100%; object-fit: cover; }
.cartao__ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size: 2.6rem; opacity:.5; }
.cartao__corpo { padding: 16px 18px 18px; display:flex; flex-direction:column; gap:6px; flex:1; }
.cartao__cat { font-size: .74rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--tinta-3); }
.cartao h3 { font-size: 1.22rem; margin: 0; }
.cartao__morada { color: var(--tinta-3); font-size: .9rem; margin: 0; }
.selo {
  position: absolute; top: 12px; left: 12px;
  background: var(--dourado); color:#3a2c08; font-size:.72rem; font-weight:700;
  padding: 4px 11px; border-radius: 999px; letter-spacing:.03em;
  box-shadow: 0 2px 8px rgba(198,138,46,.4);
}

.vazio { text-align: center; color: var(--tinta-3); padding: 60px 20px; }

/* ----- Filtros: chips + interruptor "Abertos agora" ------------------ */
.filtros { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap; margin: 26px 0 4px; }
.filtros .chips { margin: 0; flex: 1; }
.toggle-abertos {
  display: inline-flex; align-items: center; gap: 9px; white-space: nowrap;
  padding: 8px 15px; border-radius: 999px; background: #fff; border: 1px solid var(--linha);
  font-size: .88rem; font-weight: 600; color: var(--tinta); transition: border-color .15s, color .15s;
}
.toggle-abertos:hover { border-color: var(--oceano); color: var(--oceano); }
.toggle-abertos .sw { width: 36px; height: 21px; border-radius: 999px; background: #d9d2c2; position: relative; transition: background .15s; flex: 0 0 auto; }
.toggle-abertos .sw i { position: absolute; top: 2px; left: 2px; width: 17px; height: 17px; border-radius: 50%; background: #fff; transition: left .15s; box-shadow: 0 1px 2px rgba(0,0,0,.25); }
.toggle-abertos.on { border-color: var(--oceano); color: var(--oceano-2); }
.toggle-abertos.on .sw { background: var(--oceano); }
.toggle-abertos.on .sw i { left: 17px; }

/* ----- Etiquetas de estado de funcionamento -------------------------- */
.estado { display: inline-block; margin-top: 5px; padding: 3px 10px; border-radius: 999px; font-size: .72rem; font-weight: 700; width: fit-content; }
.estado--aberto  { background: #E4F4EA; color: #1f6b3c; }
.estado--fecha   { background: #FBEFCF; color: #8a5e10; }
.estado--fechado { background: #EFEBE1; color: #6E6B61; }
.estado--grande  { font-size: .82rem; padding: 5px 13px; margin-top: 0; }

/* ----- Grelha de horário no backoffice ------------------------------- */
.horario-grid { display: grid; gap: 8px; }
.horario-linha { display: grid; grid-template-columns: 130px 1fr; gap: 10px; align-items: center; padding: 6px 0; border-bottom: 1px solid var(--linha); }
.horario-linha:last-child { border-bottom: 0; }
.horario-dia { display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: .9rem; }
.horario-times { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.horario-times input[type=time] { padding: 7px 8px; border: 1px solid var(--linha); border-radius: 7px; font: inherit; }
.horario-times .sep { color: var(--tinta-3); }
.horario-mais { color: var(--tinta-3); font-size: .82rem; }
@media (max-width: 560px) { .horario-linha { grid-template-columns: 1fr; } }

/* ----- Lista de horário na ficha pública ----------------------------- */
.horario-publico { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.horario-publico li { display: flex; justify-content: space-between; gap: 14px; font-size: .92rem; }
.horario-publico .dia { color: var(--tinta-3); }
.horario-publico li.hoje { font-weight: 700; }
.horario-publico li.hoje .dia { color: var(--tinta); }

/* ----- Gestão de menus (backoffice) ---------------------------------- */
.pratos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
.prato-card { display: flex; gap: 12px; background: #fff; border: 1px solid var(--linha); border-radius: var(--raio-sm); padding: 12px; }
.prato-foto { width: 64px; height: 64px; border-radius: 8px; overflow: hidden; flex: 0 0 auto; background: var(--areia-2); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.prato-foto img { width: 100%; height: 100%; object-fit: cover; }
.menu-item { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; padding: 10px 0; border-bottom: 1px solid var(--linha); }
.menu-item:last-child { border-bottom: 0; }
.menu-item-edit { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; flex: 1; }
.menu-item .mi-nome { flex: 1; min-width: 140px; font-weight: 600; }
.menu-item .mi-campo { display: flex; align-items: center; gap: 6px; font-size: .82rem; color: var(--tinta-3); }
.menu-item .mi-campo input { width: 80px; padding: 7px; border: 1px solid var(--linha); border-radius: 7px; font: inherit; }

/* ===================================================================== */
/*  EMENTA PÚBLICA (mobile-first)                                        */
/* ===================================================================== */
.ementa-body { background: var(--areia); }
.ementa-wrap { width: 100%; max-width: 600px; margin: 0 auto; padding: 0 16px 60px; }
.ementa-cab { text-align: center; padding: 30px 16px 18px; }
.ementa-cab__logo { width: 76px; height: 76px; border-radius: 16px; object-fit: cover; border: 1px solid var(--linha); margin: 0 auto 12px; background: #fff; display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.ementa-cab h1 { font-size: 1.9rem; margin: 0 0 2px; }
.ementa-cab .sub { color: var(--tinta-3); margin: 0; }
.ementa-cab .menu-nome { font-family: "Fraunces", serif; font-style: italic; color: var(--dourado-2); font-size: 1.1rem; margin: 10px 0 0; }
.ementa-estado { margin-top: 12px; }

.ementa-lista { display: grid; gap: 14px; margin-top: 22px; }
.ementa-item { display: flex; gap: 14px; background: #fff; border: 1px solid var(--linha); border-radius: var(--raio); padding: 14px; box-shadow: var(--sombra); }
.ementa-item__foto { width: 78px; height: 78px; border-radius: 10px; object-fit: cover; flex: 0 0 auto; background: var(--areia-2); }
.ementa-item__txt { flex: 1; min-width: 0; }
.ementa-item__cab { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.ementa-item__cab h3 { font-size: 1.12rem; margin: 0; line-height: 1.2; }
.ementa-item__preco { font-family: "Fraunces", serif; font-weight: 600; color: var(--oceano-2); white-space: nowrap; font-size: 1.08rem; }
.ementa-item__desc { color: var(--tinta-3); font-size: .92rem; margin: 4px 0 0; }
.ementa-item__obs { color: var(--dourado-2); font-size: .8rem; margin: 6px 0 0; }
.ementa-vazio { text-align: center; color: var(--tinta-3); padding: 50px 20px; }
.ementa-rodape { text-align: center; color: var(--tinta-3); font-size: .82rem; margin-top: 34px; }

@media (max-width: 420px) {
  .ementa-item { padding: 12px; gap: 11px; }
  .ementa-item__foto { width: 64px; height: 64px; }
  .ementa-cab h1 { font-size: 1.6rem; }
}

/* ----- Página de empresa --------------------------------------------- */
.ficha__topo { padding: 34px 0 10px; }
.ficha__cab { display:flex; gap:20px; align-items:flex-start; flex-wrap:wrap; }
.ficha__logo { width: 92px; height:92px; border-radius: var(--raio-sm); border:1px solid var(--linha); object-fit:cover; background:#fff; flex:0 0 auto; }
.ficha h1 { font-size: clamp(1.9rem, 4vw, 2.7rem); margin:0; }
.ficha__cat { color: var(--dourado-2); font-weight:600; }
.detalhe { display:grid; grid-template-columns: 1fr; gap:14px; margin-top: 4px; }
.bloco { background:#fff; border:1px solid var(--linha); border-radius: var(--raio); padding: 22px 24px; box-shadow: var(--sombra); }
.bloco h3 { font-size: 1.12rem; margin-bottom:.4em; }
.lista-info { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.lista-info li { display:flex; gap:10px; }
.lista-info b { min-width: 92px; color: var(--tinta-3); font-weight:600; font-size:.9rem; }
.galeria-fotos { display:grid; grid-template-columns: repeat(auto-fill,minmax(150px,1fr)); gap:10px; }
.galeria-fotos img { border-radius: var(--raio-sm); aspect-ratio:1; object-fit:cover; border:1px solid var(--linha); }
#mapa { height: 300px; border-radius: var(--raio); border:1px solid var(--linha); z-index:0; }
.redes-links { display:flex; gap:10px; flex-wrap:wrap; }

/* ----- Rodapé -------------------------------------------------------- */
.rodape { background: var(--oceano-2); color: #cfe6ee; margin-top: 40px; }
.rodape a { color:#fff; }
.rodape__in { padding: 40px 0; display:flex; justify-content:space-between; gap: 30px; flex-wrap:wrap; }
.rodape small { color:#9ec4d2; }

/* =====================================================================
   BACKOFFICE (empresa + admin)
   ===================================================================== */
.bo { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
.bo__lado { background: var(--oceano-2); color:#dbeaf0; padding: 22px 18px; position: sticky; top:0; height: 100vh; overflow:auto; }
.bo__marca { display:flex; align-items:center; gap:10px; color:#fff; font-family:"Fraunces",serif; font-size:1.05rem; margin-bottom: 6px; }
.bo__marca .marca__sol { box-shadow:none; }
.bo__sub { font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:#8fb6c5; margin-bottom: 22px; }
.bo__menu { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.bo__menu a { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:9px; color:#cfe2ea; font-weight:500; font-size:.93rem; }
.bo__menu a:hover { background: rgba(255,255,255,.07); color:#fff; }
.bo__menu a.ativo { background: var(--dourado); color:#3a2c08; }
.bo__rodape { margin-top: auto; padding-top: 20px; font-size:.8rem; }
.bo__main { padding: 30px 38px; max-width: 980px; }
.bo__cab { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom: 24px; flex-wrap:wrap; }
.bo__cab h1 { font-size: 1.8rem; margin:0; }

/* Cartão de trial */
.trial {
  border-radius: var(--raio); padding: 20px 24px; margin-bottom: 24px;
  background: linear-gradient(120deg, #FFF6E2, #FBE9C2); border:1px solid #EAD49A;
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
}
.trial--fim { background: linear-gradient(120deg,#FBEDED,#F6DADA); border-color:#E8BcBc; }
.trial__num { font-family:"Fraunces",serif; font-size: 2.6rem; line-height:1; color: var(--dourado-2); }
.trial--fim .trial__num { color:#b23; }
.trial__txt { flex:1; min-width: 200px; }
.trial__txt strong { display:block; font-size:1.05rem; }
.trial__txt span { color: var(--tinta-3); font-size:.92rem; }
.barra { height: 8px; border-radius:999px; background:#0001; overflow:hidden; margin-top:8px; max-width:340px; }
.barra > i { display:block; height:100%; background: var(--dourado); }

/* Painéis e cartões de stats */
.stats { display:grid; grid-template-columns: repeat(auto-fit,minmax(150px,1fr)); gap:16px; margin-bottom: 26px; }
.stat { background:#fff; border:1px solid var(--linha); border-radius: var(--raio); padding:18px 20px; box-shadow:var(--sombra); }
.stat b { display:block; font-family:"Fraunces",serif; font-size:2rem; color: var(--oceano); line-height:1; }
.stat span { color: var(--tinta-3); font-size:.88rem; }

.painel { background:#fff; border:1px solid var(--linha); border-radius: var(--raio); padding: 24px 26px; box-shadow:var(--sombra); margin-bottom: 22px; }
.painel > h2 { font-size: 1.25rem; margin-top:0; }

/* Formulários */
.campo { margin-bottom: 16px; }
.campo label { display:block; font-weight:600; font-size:.9rem; margin-bottom:6px; }
.campo .ajuda { font-weight:400; color:var(--tinta-3); font-size:.82rem; }
.campo input[type=text], .campo input[type=email], .campo input[type=password],
.campo input[type=url], .campo input[type=tel], .campo input[type=number],
.campo input[type=datetime-local], .campo select, .campo textarea {
  width:100%; font:inherit; padding:11px 13px; border:1px solid var(--linha);
  border-radius: var(--raio-sm); background:#fff;
}
.campo textarea { min-height: 96px; resize: vertical; }
.campo input:focus, .campo select:focus, .campo textarea:focus { outline:2px solid var(--turquesa); border-color:transparent; }
.grid2 { display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
@media (max-width: 640px){ .grid2 { grid-template-columns:1fr; } }

/* Avisos / flash */
.aviso { border-radius: var(--raio-sm); padding: 12px 16px; margin-bottom: 16px; font-size:.93rem; border:1px solid; }
.aviso--ok   { background:#EAF6EE; border-color:#bfe3cd; color:#1f6b3c; }
.aviso--erro { background:#FBEDED; border-color:#e8c3c3; color:#a33; }
.aviso--info { background:#EAF3F7; border-color:#c3dde8; color:#155; }

/* Tabelas */
.tabela { width:100%; border-collapse: collapse; font-size:.92rem; }
.tabela th, .tabela td { text-align:left; padding: 11px 12px; border-bottom:1px solid var(--linha); vertical-align: middle; }
.tabela th { font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--tinta-3); }
.tabela tr:hover td { background: #FCF9F1; }
.tabela .acoes { white-space: nowrap; }
.tabela .acoes .btn { vertical-align: middle; }
.tabela .acoes .btn + .btn { margin-left: 6px; }

/* Etiquetas de estado */
.tag { display:inline-block; padding:3px 10px; border-radius:999px; font-size:.74rem; font-weight:700; }
.tag--verde { background:#E4F4EA; color:#1f6b3c; }
.tag--ouro  { background:#FBEFCF; color:#8a5e10; }
.tag--cinza { background:#EFEBE1; color:#6E6B61; }
.tag--vermelho { background:#FAE3E3; color:#a33; }

/* Serviços (lista) */
.svc { display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--linha); flex-wrap: wrap; }
.svc:last-child { border-bottom:0; }
.svc__ic { width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--areia-2);font-size:1.2rem; flex:0 0 auto; }
.svc__txt { flex:1; }
.svc__txt b { display:block; }
.svc__txt span { color:var(--tinta-3); font-size:.86rem; }
.est-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; margin-top:12px; }
.est-card { display:flex; gap:12px; align-items:flex-start; padding:14px; border:1px solid var(--linha); border-radius:12px; background:#fff; }
.est-card__ic { font-size:1.6rem; line-height:1; }
.addon-ativar { display:inline-block; }
.addon-ativar summary { list-style:none; cursor:pointer; }
.addon-ativar summary::-webkit-details-marker { display:none; }
.addon-form { margin-top:10px; display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; width:100%; }
.addon-form input[type=date] { padding:7px 9px; border:1px solid var(--linha); border-radius:7px; font:inherit; }
.addon-form label { font-size:.82rem; color:var(--tinta-3); }

/* QR */
.qr-caixa { display:flex; gap:26px; flex-wrap:wrap; align-items:flex-start; }
#qr { padding:16px; background:#fff; border:1px solid var(--linha); border-radius: var(--raio); }
.link-copia { display:flex; gap:8px; }
.link-copia input { flex:1; font:inherit; padding:10px 12px; border:1px solid var(--linha); border-radius:var(--raio-sm); background:#FCF9F1; }

/* ----- Páginas de autenticação --------------------------------------- */
.auth { min-height: 100vh; display:grid; place-items:center; padding: 30px 20px;
  background: radial-gradient(900px 360px at 50% -80px, rgba(79,179,196,.25), transparent 70%), var(--areia); }
.auth__caixa { width:100%; max-width: 430px; background:#fff; border:1px solid var(--linha); border-radius: 18px; box-shadow: var(--sombra); padding: 34px 32px; }
.auth__caixa h1 { font-size: 1.7rem; }
.auth__caixa .marca { justify-content:center; margin-bottom: 8px; }
.muted { color: var(--tinta-3); }
.center { text-align:center; }
.mt { margin-top: 16px; }
.mt-lg { margin-top: 26px; }

/* ----- Responsivo ---------------------------------------------------- */
@media (max-width: 860px) {
  .bo { grid-template-columns: 1fr; }
  .bo__lado { position: static; height:auto; display:flex; flex-direction:column; }
  .bo__menu { flex-direction: row; flex-wrap:wrap; }
  .bo__main { padding: 22px 18px; }
}
@media (max-width: 560px) {
  .pesquisa { flex-direction: column; }
  .nav__acoes .btn--linha { display:none; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; transition: none !important; }
}

/* ---- Secções de pratos (ementa pública) ---- */
.ementa-sec { border-bottom:1px solid var(--linha); }
.ementa-seccao { font-family:Fraunces,serif; font-size:1.2rem; color:var(--oceano); margin:0; padding:16px 4px; cursor:pointer; list-style:none;
  display:flex; align-items:center; justify-content:space-between; gap:10px; }
.ementa-seccao::-webkit-details-marker { display:none; }
.ementa-seccao::after { content:"▾"; color:var(--dourado); font-size:1rem; transition:transform .2s; margin-left:auto; }
.ementa-sec:not([open]) .ementa-seccao::after { transform:rotate(-90deg); }
.ementa-sec__n { color:var(--tinta-3); font-weight:500; font-size:.92em; }
.ementa-item__cam { font-size:.82rem; opacity:.55; }
.ementa-sec > .ementa-lista { padding-bottom:14px; }

/* prato clicável + modal */
.ementa-item--click { cursor:pointer; position:relative; transition:background .15s; }
.ementa-item--click:hover { background:rgba(217,164,65,.08); }
.ementa-item--click:focus-visible { outline:2px solid var(--dourado); outline-offset:2px; }
.ementa-item__seta { align-self:center; color:var(--dourado); font-size:1.4rem; line-height:1; padding-left:6px; }

.pmodal { position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; padding:18px; }
.pmodal[hidden] { display:none; }
.pmodal__bg { position:absolute; inset:0; background:rgba(20,40,55,.55); backdrop-filter:blur(2px); }
.pmodal__caixa { position:relative; background:#fff; border-radius:18px; max-width:440px; width:100%; max-height:90vh; overflow:auto; box-shadow:0 20px 60px rgba(0,0,0,.3); }
.pmodal__x { position:absolute; top:10px; right:10px; z-index:2; border:none; background:rgba(255,255,255,.9); width:34px; height:34px; border-radius:50%; font-size:1rem; cursor:pointer; box-shadow:0 2px 8px rgba(0,0,0,.15); }
.pmodal__foto img { width:100%; max-height:300px; object-fit:cover; display:block; border-radius:18px 18px 0 0; }
.pmodal__foto--vazia { height:160px; background:var(--areia-2); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; border-radius:18px 18px 0 0; color:var(--tinta-3); }
.pmodal__foto--vazia span { font-size:2.6rem; }
.pmodal__corpo { padding:18px 20px 22px; }
.pmodal__cab { display:flex; justify-content:space-between; gap:12px; align-items:baseline; }
.pmodal__cab h3 { margin:0; font-family:Fraunces,serif; font-size:1.3rem; }
.pmodal__preco { font-family:Fraunces,serif; color:var(--oceano); font-weight:600; white-space:nowrap; }
.pmodal__desc { margin:.6em 0 0; color:var(--tinta); }

/* ---- Pesquisa pública de pratos (pratos.php) ---- */
.pchips { display:flex; flex-wrap:wrap; gap:10px; }
.pchip { display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border:1px solid var(--linha); border-radius:999px; background:#fff; color:var(--tinta); text-decoration:none; font-weight:500; font-size:.92rem; transition:.15s; }
.pchip:hover { border-color:var(--dourado); }
.pchip--on { background:var(--oceano); color:#fff; border-color:var(--oceano); }
.pchip__n { background:rgba(0,0,0,.08); border-radius:999px; padding:1px 8px; font-size:.78rem; }
.pchip--on .pchip__n { background:rgba(255,255,255,.25); }
.pratos-pub { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; margin-top:14px; }
.pp-card { display:flex; gap:14px; padding:14px; border:1px solid var(--linha); border-radius:14px; background:#fff; }
.pp-foto { width:84px; height:84px; flex:0 0 84px; border-radius:11px; overflow:hidden; background:var(--areia-2); display:flex; align-items:center; justify-content:center; font-size:1.8rem; }
.pp-foto img { width:100%; height:100%; object-fit:cover; }
.pp-txt { flex:1; min-width:0; }
.pp-cab { display:flex; justify-content:space-between; gap:10px; align-items:baseline; }
.pp-cab h3 { margin:0; font-size:1.05rem; }
.pp-preco { font-family:Fraunces,serif; color:var(--oceano); font-weight:600; white-space:nowrap; }
.pp-rest { margin:.3em 0 0; font-size:.9rem; }

/* ---- Barra de partilha (convite admin) ---- */
.partilhar { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }

/* Powered by HDSA */
.powered { color:var(--tinta-3); }
.powered a { color:var(--dourado-2); font-weight:600; text-decoration:none; }
.powered a:hover { text-decoration:underline; }

/* Modal de resultados de pesquisa (página inicial) */
.resmodal { position:fixed; inset:0; z-index:1000; display:flex; align-items:flex-start; justify-content:center; padding:40px 16px; overflow-y:auto; }
.resmodal__bg { position:fixed; inset:0; background:rgba(20,40,55,.55); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); }
.resmodal__caixa { position:relative; background:var(--areia); border-radius:20px; max-width:1100px; width:100%; margin:auto; padding:22px 24px 26px; box-shadow:0 30px 80px rgba(0,0,0,.35); }
.resmodal__cab { display:flex; justify-content:space-between; align-items:flex-start; gap:14px; border-bottom:1px solid var(--linha); padding-bottom:14px; margin-bottom:18px; flex-wrap:wrap; }
.resmodal__cab h2 { font-family:Fraunces,serif; color:var(--oceano); }
.resmodal__acoes { display:flex; gap:8px; align-items:center; }
.resmodal__x { border:none; background:#fff; width:38px; height:38px; border-radius:50%; font-size:1rem; cursor:pointer; box-shadow:0 2px 8px rgba(0,0,0,.12); }
.resmodal__x:hover { background:var(--areia-2); }
@media (max-width:600px){ .resmodal { padding:16px 10px; } .resmodal__caixa { padding:18px 16px 20px; } }

/* Rodapé centrado em ecrãs pequenos (smartphone) */
@media (max-width:640px) {
  .rodape__in { flex-direction:column; align-items:center; text-align:center; gap:20px; padding:34px 0; }
  .rodape__in > div { max-width:360px; }
  .rodape__in p { margin-left:auto; margin-right:auto; }
}

/* Modal de carregamento de créditos (IfthenPay) */
.cmodal { position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; padding:18px; }
.cmodal[hidden] { display:none; }
.cmodal__bg { position:absolute; inset:0; background:rgba(20,40,55,.55); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); }
.cmodal__caixa { position:relative; background:#fff; border-radius:18px; max-width:420px; width:100%; padding:24px 26px; box-shadow:0 24px 60px rgba(0,0,0,.3); }
.cmodal__x { position:absolute; top:10px; right:10px; border:none; background:var(--areia-2); width:32px; height:32px; border-radius:50%; font-size:.95rem; cursor:pointer; }
.ref-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.ref-grid > div { background:var(--areia-2); border-radius:12px; padding:12px 14px; }
.ref-grid span { display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.05em; color:var(--tinta-3); }
.ref-grid strong { display:block; font-family:Fraunces,serif; font-size:1.25rem; color:var(--oceano); margin-top:2px; letter-spacing:.5px; }