:root{
  --brand:#6366F1; --brand-strong:#4F46E5; --brand-soft:#EEF0FE;
  --accent:#10B981; --accent-soft:#E7F7F1;
  --bg:#F7F8FB; --surface:#FFFFFF; --line:#E7EAF1; --line-strong:#D7DCE8;
  --text:#0F172A; --muted:#64748B; --dim:#94A3B8;
  --warn:#F59E0B; --danger:#EF4444;
  --r:14px; --r-sm:10px; --r-lg:22px; --pill:999px;
  --shadow:0 14px 40px -22px rgba(15,23,42,.35);
  --shadow-sm:0 6px 18px -12px rgba(15,23,42,.30);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;letter-spacing:-.02em}
img{max-width:100%;display:block}
.container{max-width:1140px;margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}

/* ---------- header ---------- */
.site{min-height:100vh;display:flex;flex-direction:column}
.hdr{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.hdr-inner{display:flex;align-items:center;gap:20px;height:66px}
.brand{font-size:23px;font-weight:800;letter-spacing:-.03em}
.brand span{color:var(--brand)}
.hdr-nav{display:flex;gap:6px;margin-left:8px}
.hdr-nav a{padding:8px 12px;border-radius:var(--r-sm);font-weight:600;color:var(--muted);font-size:14.5px}
.hdr-nav a:hover{color:var(--text);background:var(--bg)}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.hdr-business{font-weight:600;font-size:14px;color:var(--brand)}
.hdr-business:hover{text-decoration:underline}
.hdr-acct{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14px;padding:8px 12px;border-radius:var(--pill);background:var(--brand-soft);color:var(--brand-strong)}
.linkbtn{background:none;border:none;cursor:pointer;font:inherit;color:var(--muted);font-weight:600;padding:8px 10px}
.linkbtn:hover{color:var(--text)}

.site-main{flex:1}
.ftr{border-top:1px solid var(--line);background:var(--surface);margin-top:60px}
.ftr-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:26px 0;color:var(--muted);font-size:13.5px}
.ftr a{color:var(--muted)}.ftr a:hover{color:var(--text)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:46px;padding:0 22px;
  border-radius:var(--pill);font-weight:700;font-size:15px;cursor:pointer;border:1px solid transparent;
  transition:.15s;white-space:nowrap}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-strong)}
.btn-ghost{background:var(--surface);border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{filter:brightness(.96)}
.btn-sm{height:40px;padding:0 16px;font-size:14px}
.btn-block{width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed}

/* ---------- hero / busca ---------- */
.hero{background:
   radial-gradient(900px 400px at 85% -10%,#E0E7FF,transparent 60%),
   radial-gradient(700px 380px at 0% 0%,#D1FAE5,transparent 55%),var(--bg);
   padding:64px 0 40px}
.hero h1{font-size:46px;font-weight:800;line-height:1.08;max-width:680px}
.hero p{font-size:18px;color:var(--muted);margin:14px 0 26px;max-width:560px}
.searchbar{display:flex;gap:8px;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:var(--pill);padding:8px;box-shadow:var(--shadow);max-width:680px}
.searchbar .field{flex:1;display:flex;align-items:center;gap:9px;padding:0 14px;min-width:0}
.searchbar .field i{color:var(--dim);font-size:17px}
.searchbar input{border:none;outline:none;font:inherit;font-size:15px;width:100%;background:transparent;color:var(--text)}
.searchbar select{border:none;outline:none;font:inherit;font-size:15px;width:100%;background:transparent;color:var(--text);
  appearance:none;cursor:pointer;padding-right:22px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right center}
.searchbar .sep{width:1px;background:var(--line);margin:6px 0}
.cats{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.cat{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--pill);padding:8px 15px;font-weight:600;font-size:13.5px;color:var(--muted)}
.cat:hover,.cat.active{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}

/* ---------- sections / grid ---------- */
.section{padding:42px 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:22px}
.section-head h2{font-size:26px;font-weight:800}
.section-head a{color:var(--brand);font-weight:600;font-size:14.5px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:20px}

/* ---------- establishment card ---------- */
.estab{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.18s;display:flex;flex-direction:column}
.estab:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.estab-img{height:140px;background:linear-gradient(135deg,#6366F1,#4F46E5);position:relative;display:flex;
  align-items:center;justify-content:center;color:#fff;font-size:30px}
.estab-img .cat-badge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);color:var(--brand-strong);
  font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:var(--pill)}
.estab-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.estab-name{font-size:16.5px;font-weight:700}
.estab-meta{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.estab-foot{margin-top:auto;padding-top:8px;display:flex;align-items:center;justify-content:space-between}
.estab-foot .stars{color:var(--warn);font-size:13px}
.estab-foot .go{color:var(--brand);font-weight:700;font-size:13.5px}

/* ---------- panels / cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.pad{padding:24px}
.stack{display:flex;flex-direction:column}

/* ---------- forms ---------- */
.form{display:flex;flex-direction:column;gap:14px}
.field-l{display:flex;flex-direction:column;gap:6px}
.field-l label{font-size:13.5px;font-weight:600;color:var(--text)}
.inp{height:46px;border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:0 14px;font:inherit;
  font-size:15px;background:var(--surface);color:var(--text);width:100%}
textarea.inp{height:auto;padding:12px 14px;min-height:90px}
.inp:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
select.inp{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.alert{padding:12px 14px;border-radius:var(--r-sm);font-size:14px;font-weight:500}
.alert-err{background:#FEF2F2;color:#B91C1C;border:1px solid #FECACA}
.alert-ok{background:var(--accent-soft);color:#065F46;border:1px solid #A7F3D0}

/* ---------- booking ---------- */
.svc-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.svc-row:last-child{border-bottom:none}
.svc-info b{font-size:15.5px}
.svc-info .d{font-size:13px;color:var(--muted)}
.svc-price{font-weight:800;color:var(--text);font-size:16px;white-space:nowrap}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:8px}
.slot{height:40px;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--surface);
  font:inherit;font-weight:600;font-size:14px;color:var(--text);cursor:pointer}
.slot:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.pill-step{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);font-weight:600}

/* ---------- profile / list ---------- */
.appt{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);margin-bottom:10px}
.appt .when{flex-shrink:0;width:64px;text-align:center;background:var(--brand-soft);color:var(--brand-strong);border-radius:var(--r-sm);padding:7px 0}
.appt .when .d{font-size:11px;font-weight:700}.appt .when .h{font-size:15px;font-weight:800}
.appt .info{flex:1;min-width:0}.appt .info b{font-size:15px}.appt .info .s{font-size:13px;color:var(--muted)}
.badge{font-size:12px;font-weight:700;padding:3px 11px;border-radius:var(--pill)}
.badge.Agendado{background:#FEF3C7;color:#92400E}
.badge.Confirmado{background:#FEF3C7;color:#92400E}
.badge.Realizado{background:var(--accent-soft);color:#065F46}
.badge.Cancelado{background:#FEE2E2;color:#991B1B}

.empty{text-align:center;color:var(--muted);padding:50px 20px}
.empty i{font-size:40px;color:var(--dim);display:block;margin-bottom:10px}

@media(max-width:760px){
  .hero{padding:42px 0 30px}.hero h1{font-size:34px}
  .searchbar{flex-direction:column;border-radius:var(--r-lg)}
  .searchbar .sep{display:none}.searchbar .field{padding:8px 12px}
  .hdr-nav{display:none}
}
