/* OnPedCare — Identidade Visual v2 (aplicação plena) */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600;700&display=swap');

:root {
  --brand-teal: #3F9497;
  --brand-teal-dark: #1F574E;
  --brand-teal-50: #f0f7f7;
  --brand-teal-100: #d4e8e9;
  --brand-teal-200: #a9d1d3;
  --brand-teal-300: #7eb9bc;
  --brand-teal-400: #54a3a6;
  --brand-teal-600: #347b7e;
  --brand-teal-700: #2a6366;

  --brand-berry: #B46594;
  --brand-berry-50: #faf3f7;
  --brand-berry-100: #f2dfeb;
  --brand-berry-200: #e5c4d7;
  --brand-berry-300: #d1a2bd;
  --brand-berry-600: #9c5380;

  --brand-terra: #DD8252;
  --brand-terra-50: #fef4ed;
  --brand-terra-100: #fce0cf;

  --brand-gold: #BF9D34;
  --brand-gold-50: #fbf6e3;
  --brand-gold-100: #f5ead0;

  --brand-ink: #1F574E;
  --brand-text: #2a3d3b;
  --brand-muted: #6b7c7a;
  --brand-bg: #fbfaf7;
  --brand-bg-warm: #faf6f0;
  --brand-bg-card: #ffffff;
  --brand-border: #e3ebea;
}

[x-cloak]{display:none!important;}

html, body {
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  color: var(--brand-text);
  background-color: var(--brand-bg);
}

h1, h2, h3, h4 {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--brand-ink);
}

/* ================ Tailwind overrides ================ */
.bg-slate-50 { background-color: var(--brand-bg) !important; }
.bg-slate-100 { background-color: var(--brand-teal-50) !important; }
.text-slate-900 { color: var(--brand-ink) !important; }
.text-slate-800 { color: var(--brand-text) !important; }
.text-slate-700 { color: var(--brand-text) !important; }
.text-slate-600 { color: var(--brand-muted) !important; }
.text-slate-500 { color: var(--brand-muted) !important; }
.text-slate-400 { color: #94a09e !important; }
.border-slate-200 { border-color: var(--brand-border) !important; }
.border-slate-300 { border-color: #d2dad9 !important; }
.bg-white { background-color: var(--brand-bg-card) !important; }

.bg-rose-50 { background-color: var(--brand-teal-50) !important; }
.bg-rose-100 { background-color: var(--brand-teal-100) !important; }
.bg-rose-600 { background-color: var(--brand-teal) !important; }
.hover\:bg-rose-700:hover { background-color: var(--brand-teal-600) !important; }
.text-rose-600 { color: var(--brand-teal) !important; }
.text-rose-700 { color: var(--brand-teal-dark) !important; }
.text-rose-400 { color: var(--brand-teal-300) !important; }
.border-rose-200 { border-color: var(--brand-teal-200) !important; }
.border-rose-300 { border-color: var(--brand-teal-300) !important; }
.border-rose-400 { border-color: var(--brand-teal-400) !important; }
.border-rose-600 { border-color: var(--brand-teal) !important; }
.hover\:border-rose-300:hover { border-color: var(--brand-teal-300) !important; }
.hover\:border-rose-400:hover { border-color: var(--brand-teal-400) !important; }
.ring-rose-200 { --tw-ring-color: var(--brand-teal-200) !important; }
.from-rose-50 { --tw-gradient-from: var(--brand-teal-50) !important; }
.to-amber-50 { --tw-gradient-to: var(--brand-bg-warm) !important; }

/* status colors mapeados para nossa paleta */
.bg-emerald-50 { background-color: var(--brand-teal-50) !important; }
.bg-emerald-100 { background-color: var(--brand-teal-100) !important; }
.bg-emerald-600 { background-color: var(--brand-teal) !important; }
.hover\:bg-emerald-700:hover { background-color: var(--brand-teal-600) !important; }
.text-emerald-600 { color: var(--brand-teal) !important; }
.text-emerald-700 { color: var(--brand-teal-dark) !important; }
.border-emerald-300 { border-color: var(--brand-teal-300) !important; }
.hover\:bg-emerald-50:hover { background-color: var(--brand-teal-50) !important; }
.hover\:text-emerald-700:hover { color: var(--brand-teal-dark) !important; }
.hover\:border-emerald-300:hover { border-color: var(--brand-teal-300) !important; }

.bg-amber-50 { background-color: var(--brand-terra-50) !important; }
.bg-amber-100 { background-color: var(--brand-terra-100) !important; }
.border-amber-200 { border-color: var(--brand-terra-100) !important; }
.text-amber-700 { color: #b25826 !important; }
.text-amber-800 { color: #a64d22 !important; }
.text-amber-900 { color: var(--brand-terra) !important; }
.text-amber-600 { color: var(--brand-terra) !important; }
.ring-amber-200 { --tw-ring-color: var(--brand-gold) !important; }

.bg-purple-100 { background-color: var(--brand-berry-100) !important; }
.text-purple-700 { color: var(--brand-berry-600) !important; }

/* ================ Layout principal ================ */
main {
  background:
    radial-gradient(ellipse at top right, var(--brand-teal-50) 0%, transparent 50%),
    radial-gradient(ellipse at bottom left, var(--brand-berry-50) 0%, transparent 50%),
    var(--brand-bg);
  background-attachment: fixed;
  position: relative;
}
main::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'%3E%3Cg fill-opacity='0.5'%3E%3Cpolygon points='20,8 26,20 14,20' fill='%233F9497'/%3E%3Cpolygon points='60,40 66,52 54,52' fill='%23B46594'/%3E%3Cpolygon points='110,15 116,27 104,27' fill='%23DD8252'/%3E%3Cpolygon points='180,60 186,72 174,72' fill='%23BF9D34'/%3E%3Cpolygon points='40,90 46,102 34,102' fill='%233F9497'/%3E%3Cpolygon points='200,100 206,112 194,112' fill='%23B46594'/%3E%3Cpolygon points='100,130 106,142 94,142' fill='%23BF9D34'/%3E%3Cpolygon points='30,180 36,192 24,192' fill='%23DD8252'/%3E%3Cpolygon points='160,180 166,192 154,192' fill='%233F9497'/%3E%3Cpolygon points='220,210 226,222 214,222' fill='%23B46594'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 320px 320px;
  opacity: 0.4;
  pointer-events: none;
  z-index: 0;
}
main > * { position: relative; z-index: 1; }

/* ================ Sidebar refresh ================ */
aside {
  background: linear-gradient(180deg, #ffffff 0%, var(--brand-teal-50) 100%) !important;
  border-right: 1px solid var(--brand-border) !important;
  box-shadow: 1px 0 3px rgba(31, 87, 78, 0.04);
}
aside a.block { transition: all .15s; border-radius: 0.625rem; }
aside a.block:hover { background-color: var(--brand-teal-50); transform: translateX(2px); }
aside .bg-rose-50 { background: linear-gradient(90deg, var(--brand-teal-100), var(--brand-teal-50)) !important; box-shadow: inset 3px 0 0 var(--brand-teal); }

/* ================ Cards ================ */
.bg-white.border {
  background: var(--brand-bg-card) !important;
  border-color: var(--brand-border) !important;
  box-shadow: 0 1px 3px rgba(31, 87, 78, 0.04), 0 1px 2px rgba(31, 87, 78, 0.03);
  transition: box-shadow .2s;
}
.bg-white.border:hover {
  box-shadow: 0 4px 12px rgba(31, 87, 78, 0.08), 0 2px 4px rgba(31, 87, 78, 0.04);
}

/* ================ Botões ================ */
.bg-rose-600,
button.bg-rose-600,
a.bg-rose-600 {
  background: linear-gradient(135deg, var(--brand-teal) 0%, var(--brand-teal-600) 100%) !important;
  box-shadow: 0 2px 6px rgba(63, 148, 151, 0.25);
  transition: all .15s;
  font-weight: 500;
}
.bg-rose-600:hover,
button.bg-rose-600:hover,
a.bg-rose-600:hover {
  box-shadow: 0 4px 12px rgba(63, 148, 151, 0.35);
  transform: translateY(-1px);
}

/* ================ Empty states ================ */
.bg-white.border.border-slate-200.rounded-2xl.p-12.text-center {
  background:
    linear-gradient(var(--brand-bg-card), var(--brand-bg-card)) padding-box,
    var(--brand-bg-card) !important;
  border: 1px dashed var(--brand-teal-200) !important;
  position: relative;
  overflow: hidden;
}
.bg-white.border.border-slate-200.rounded-2xl.p-12.text-center::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cg fill-opacity='0.5'%3E%3Cpolygon points='20,8 26,20 14,20' fill='%233F9497'/%3E%3Cpolygon points='80,30 86,42 74,42' fill='%23B46594'/%3E%3Cpolygon points='130,60 136,72 124,72' fill='%23DD8252'/%3E%3Cpolygon points='40,90 46,102 34,102' fill='%23BF9D34'/%3E%3Cpolygon points='110,120 116,132 104,132' fill='%233F9497'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 200px 200px;
  opacity: 0.35;
  pointer-events: none;
}
.bg-white.border.border-slate-200.rounded-2xl.p-12.text-center > * { position: relative; z-index: 1; }

/* ================ Inputs ================ */
input, select, textarea {
  font-family: inherit;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--brand-teal) !important;
  box-shadow: 0 0 0 3px rgba(63, 148, 151, 0.15) !important;
  outline: none !important;
}

/* ================ Brand logo ================ */
.brand-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  text-decoration: none;
  color: var(--brand-ink);
}
.brand-logo svg { width: 36px; height: 36px; flex-shrink: 0; }
.brand-logo .name { font-weight: 600; font-size: 1.05rem; letter-spacing: -0.01em; line-height: 1.1; display:block; }
.brand-logo .tagline { font-size: 0.65rem; color: var(--brand-muted); font-weight: 400; letter-spacing: 0.08em; text-transform: uppercase; display: block; line-height: 1; margin-top: 3px; }

/* ================ Hero da landing ================ */
.brand-hero {
  background:
    linear-gradient(135deg, var(--brand-teal-50) 0%, var(--brand-bg-warm) 50%, var(--brand-berry-50) 100%);
  position: relative;
  overflow: hidden;
}
.brand-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'%3E%3Cg fill-opacity='0.6'%3E%3Cpolygon points='20,8 26,20 14,20' fill='%233F9497'/%3E%3Cpolygon points='60,40 66,52 54,52' fill='%23B46594'/%3E%3Cpolygon points='110,15 116,27 104,27' fill='%23DD8252'/%3E%3Cpolygon points='150,60 156,72 144,72' fill='%23BF9D34'/%3E%3Cpolygon points='40,90 46,102 34,102' fill='%233F9497'/%3E%3Cpolygon points='180,100 186,112 174,112' fill='%23B46594'/%3E%3Cpolygon points='100,130 106,142 94,142' fill='%23BF9D34'/%3E%3Cpolygon points='30,160 36,172 24,172' fill='%23DD8252'/%3E%3Cpolygon points='160,170 166,182 154,182' fill='%233F9497'/%3E%3Cpolygon points='80,180 86,192 74,192' fill='%23B46594'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 280px 280px;
  opacity: 0.8;
  pointer-events: none;
}

/* ================ Footer ================ */
.brand-footer {
  background-color: var(--brand-teal-dark);
  color: rgba(255,255,255,0.9);
  padding: 2.5rem 1rem;
  text-align: center;
  font-size: 0.875rem;
}
.brand-footer a { color: rgba(255,255,255,0.7); }

/* ================ Calendário agenda ================ */
.grid.grid-cols-7 > div {
  border-color: var(--brand-border) !important;
}
.grid.grid-cols-7 > div.bg-amber-50 {
  background: linear-gradient(135deg, var(--brand-gold-50), var(--brand-terra-50)) !important;
  border-color: var(--brand-gold) !important;
}

/* dia com consulta marcada destaque */
.grid.grid-cols-7 > div:hover {
  background-color: var(--brand-teal-50) !important;
}

/* ================ Status badges ================ */
.text-emerald-700 { color: var(--brand-teal-dark) !important; }
.text-rose-700 { color: var(--brand-berry-600) !important; }


/* ============ Anular fundos brancos das secções ============ */
section, .brand-hero { background-color: var(--brand-bg-warm) !important; }
section.brand-hero, .brand-hero { background: linear-gradient(135deg, var(--brand-teal-50) 0%, var(--brand-bg-warm) 50%, var(--brand-berry-50) 100%) !important; }
section[id="temas"] { background: var(--brand-bg-warm) !important; position: relative; overflow: hidden; }
section[id="temas"]::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260' viewBox='0 0 260 260'%3E%3Cg fill-opacity='0.35'%3E%3Cpolygon points='20,8 26,20 14,20' fill='%233F9497'/%3E%3Cpolygon points='80,40 86,52 74,52' fill='%23B46594'/%3E%3Cpolygon points='150,15 156,27 144,27' fill='%23DD8252'/%3E%3Cpolygon points='220,60 226,72 214,72' fill='%23BF9D34'/%3E%3Cpolygon points='40,90 46,102 34,102' fill='%233F9497'/%3E%3Cpolygon points='180,120 186,132 174,132' fill='%23B46594'/%3E%3Cpolygon points='100,160 106,172 94,172' fill='%23BF9D34'/%3E%3Cpolygon points='30,200 36,212 24,212' fill='%23DD8252'/%3E%3Cpolygon points='200,210 206,222 194,222' fill='%233F9497'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 320px 320px;
  opacity: 0.45;
  pointer-events: none;
  z-index: 0;
}
section[id="temas"] > * { position: relative; z-index: 1; }

section[id="preco"] { background: var(--brand-bg-warm) !important; }
header.bg-white, header { background-color: var(--brand-bg-warm) !important; border-bottom-color: var(--brand-border) !important; }

/* Cards permanecem brancos para destaque */
.bg-white { background-color: #ffffff !important; }

/* Páginas auth (login/signup) ficam com fundo warm */
body { background-color: var(--brand-bg-warm) !important; }


/* ============ Anular fundos brancos das secções ============ */
section, .brand-hero { background-color: var(--brand-bg-warm) !important; }
section.brand-hero, .brand-hero { background: linear-gradient(135deg, var(--brand-teal-50) 0%, var(--brand-bg-warm) 50%, var(--brand-berry-50) 100%) !important; }
section[id="temas"] { background: var(--brand-bg-warm) !important; position: relative; overflow: hidden; }
section[id="temas"]::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260' viewBox='0 0 260 260'%3E%3Cg fill-opacity='0.35'%3E%3Cpolygon points='20,8 26,20 14,20' fill='%233F9497'/%3E%3Cpolygon points='80,40 86,52 74,52' fill='%23B46594'/%3E%3Cpolygon points='150,15 156,27 144,27' fill='%23DD8252'/%3E%3Cpolygon points='220,60 226,72 214,72' fill='%23BF9D34'/%3E%3Cpolygon points='40,90 46,102 34,102' fill='%233F9497'/%3E%3Cpolygon points='180,120 186,132 174,132' fill='%23B46594'/%3E%3Cpolygon points='100,160 106,172 94,172' fill='%23BF9D34'/%3E%3Cpolygon points='30,200 36,212 24,212' fill='%23DD8252'/%3E%3Cpolygon points='200,210 206,222 194,222' fill='%233F9497'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 320px 320px;
  opacity: 0.45;
  pointer-events: none;
  z-index: 0;
}
section[id="temas"] > * { position: relative; z-index: 1; }

section[id="preco"] { background: var(--brand-bg-warm) !important; }
header.bg-white, header { background-color: var(--brand-bg-warm) !important; border-bottom-color: var(--brand-border) !important; }

/* Cards permanecem brancos para destaque */
.bg-white { background-color: #ffffff !important; }

/* Páginas auth (login/signup) ficam com fundo warm */
body { background-color: var(--brand-bg-warm) !important; }
