:root{
  --green:#96A17C; /* inspirado no logo */
  --green-dark:#6F7A59;
  --pink:#E8B4C2;
  --pink-dark:#D792A6;
  --ink:#1f2937;
  --muted:#6b7280;
  --bg:#fff7fa;
  --card:#ffffff;
  --ring: rgba(150,161,124,.35);
  --shadow: 0 12px 28px rgba(0,0,0,.10);
  --radius: 18px;
  --max: 1320px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background: radial-gradient(900px 500px at 15% 0%, rgba(232,180,194,.25), transparent 60%),
              radial-gradient(900px 500px at 85% 10%, rgba(150,161,124,.22), transparent 55%),
              linear-gradient(180deg, var(--bg), #ffffff 55%);
}

a{color:inherit;text-decoration:none}
.container{max-width:var(--max); margin:0 auto; padding:18px 18px 56px}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:14px 18px; border-radius: 22px;
  background: rgba(255,255,255,.75); backdrop-filter: blur(8px);
  border: 1px solid rgba(150,161,124,.20);
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
  position: sticky; top: 10px; z-index: 30;
}
.brand{display:flex; align-items:center; gap:12px}
.brand img{width:44px;height:44px; object-fit:contain}
.brand .name{display:flex; flex-direction:column; line-height:1.05}
.brand .name strong{letter-spacing:.06em}
.brand .name span{font-size:12px; color:var(--muted); letter-spacing:.14em}
.navlinks{display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end}
.navlinks a{
  padding:10px 12px; border-radius: 14px;
  color:var(--ink); font-weight:600; font-size:14px;
  border:1px solid transparent;
}
.navlinks a:hover{border-color: rgba(232,180,194,.55); background: rgba(232,180,194,.14)}
.navlinks a.active{border-color: rgba(150,161,124,.40); background: rgba(150,161,124,.12)}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px; border-radius: 16px; font-weight:700;
  border: 1px solid rgba(150,161,124,.35);
  background: linear-gradient(180deg, rgba(150,161,124,.18), rgba(232,180,194,.12));
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0px)}
.btn.primary{
  border-color: rgba(111,122,89,.55);
  background: linear-gradient(180deg, rgba(150,161,124,.22), rgba(150,161,124,.10));
}
.btn.pink{
  border-color: rgba(215,146,166,.55);
  background: linear-gradient(180deg, rgba(232,180,194,.25), rgba(232,180,194,.10));
}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 10px; border-radius: 999px;
  background: rgba(150,161,124,.12);
  border:1px solid rgba(150,161,124,.25);
  color: var(--green-dark);
  font-weight:800; font-size:12px;
}
.hero{
  display:grid; grid-template-columns: 1.25fr .95fr; gap:24px;
  padding-top: 18px;
}
@media (max-width: 1024px){ .hero{grid-template-columns: 1fr;}}
.card{
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(150,161,124,.18);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.card.pad{padding:18px}
.h1{font-size:40px; line-height:1.08; margin:12px 0 10px}
@media (max-width: 520px){ .h1{font-size:32px}}
.sub{color:var(--muted); font-size:16px; line-height:1.5; margin: 0 0 14px}
.kpis{display:flex; gap:10px; flex-wrap:wrap; margin-top: 10px}
.kpi{padding:10px 12px; border-radius: 16px; background: rgba(232,180,194,.10); border:1px solid rgba(232,180,194,.22); font-weight:800; font-size:13px}
.grid3{display:grid; grid-template-columns: repeat(4, 1fr); gap:14px}
@media (max-width: 980px){ .grid3{grid-template-columns: 1fr}}
.service{
  padding:16px; border-radius: 18px;
  border:1px solid rgba(150,161,124,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(232,180,194,.06));
}
.service h3{margin:10px 0 6px}
.service p{margin:0; color:var(--muted); line-height:1.45}
.service .icon{width:40px;height:40px; border-radius: 14px; display:grid; place-items:center;
  background: rgba(150,161,124,.14); border:1px solid rgba(150,161,124,.22)}
.split{
  display:grid; grid-template-columns: 1fr 1fr; gap:14px;
}
@media (max-width: 980px){ .split{grid-template-columns:1fr}}
.gallery{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:12px;
}
@media (max-width: 980px){ .gallery{grid-template-columns: repeat(2, 1fr)}}
@media (max-width: 520px){ .gallery{grid-template-columns: 1fr}}
.gallery img{
  width:100%; height:220px; object-fit:cover; border-radius: 18px;
  border:1px solid rgba(150,161,124,.18);
  box-shadow: 0 10px 20px rgba(0,0,0,.06);
}

.footer{
  margin-top: 22px; padding: 16px 18px;
  color: var(--muted); font-size: 13px; line-height:1.5;
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
  border-top:1px solid rgba(150,161,124,.20);
}
.small{font-size:13px; color:var(--muted); line-height:1.5}
.hr{height:1px; background: rgba(150,161,124,.18); margin:14px 0}

.agendaHeader{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.agendaHeader h3{margin:0}
.pill{
  font-size:12px; font-weight:800; color: var(--green-dark);
  background: rgba(150,161,124,.12);
  border:1px solid rgba(150,161,124,.22);
  padding:6px 10px; border-radius: 999px;
  white-space:nowrap;
}
.table{
  width:100%; border-collapse: separate; border-spacing:0 8px; margin-top: 10px;
}
.table th{font-size:12px; text-align:left; color: var(--muted); padding:0 8px 4px}
.row{
  background: rgba(255,255,255,.90);
  border:1px solid rgba(150,161,124,.16);
  border-radius: 14px;
}
.table td{padding:10px 8px; vertical-align:middle}
.slotBtn{
  width:100%;
  border-radius: 14px;
  padding:10px 12px;
  font-weight:900;
  border:1px solid rgba(150,161,124,.30);
  background: rgba(150,161,124,.12);
  cursor:pointer;
}
.slotBtn:hover{background: rgba(150,161,124,.16)}
.slotBtn.reserved, .slotBtn.disabled{
  background: rgba(107,114,128,.10);
  border-color: rgba(107,114,128,.20);
  color: rgba(31,41,55,.55);
  cursor:not-allowed;
}
.note{
  padding:12px 12px; border-radius: 16px;
  border:1px dashed rgba(232,180,194,.55);
  background: rgba(232,180,194,.08);
  color: var(--muted);
  font-size: 13px;
}

.modalBackdrop{
  position:fixed; inset:0; background: rgba(0,0,0,.35);
  display:none; align-items:center; justify-content:center; padding: 16px; z-index: 80;
}
.modal{
  width:min(520px, 100%);
  background: rgba(255,255,255,.96);
  border:1px solid rgba(150,161,124,.22);
  border-radius: 22px;
  box-shadow: 0 26px 60px rgba(0,0,0,.18);
  padding: 16px;
}
.modalTop{display:flex; justify-content:space-between; align-items:flex-start; gap:10px}
.modalTop h3{margin:0}
.close{
  border:none; background:transparent; font-size:22px; cursor:pointer; padding:6px 10px; border-radius: 12px;
}
.close:hover{background: rgba(107,114,128,.10)}
.branchList{display:grid; gap:10px; margin-top: 10px}
.branch{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:12px 12px; border-radius: 18px;
  border:1px solid rgba(150,161,124,.18);
  background: rgba(255,255,255,.85);
}
.branch strong{display:block}
.branch span{display:block; font-size: 12px; color: var(--muted); margin-top: 2px}
.branch button{white-space:nowrap}

.toast{
  position: fixed;
  right: 16px;
  bottom: 16px;
  background: rgba(31,41,55,.92);
  color: #fff;
  padding: 12px 14px;
  border-radius: 16px;
  box-shadow: 0 18px 40px rgba(0,0,0,.22);
  font-size: 13px;
  display:none;
  z-index: 90;
}
.navlinks a.tag-system {
  background: #c977b2;
  color: #fff;
  padding: 8px 12px;
  border-radius: 12px;
  font-weight: 700;
  white-space: nowrap; /* impede quebrar o texto do botão */
}