/* Barbearia iaja — tema compartilhado (cliente + painel) */
* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --bg: #14100c;
  --card: #1e1813;
  --card-2: #262019;
  --border: #3a2f22;
  --gold: #c9a35b;
  --cream: #f2e8d5;
  --muted: #9b8a6a;
  --ok: #7dc98f;
  --err: #e07a6a;
}
html, body { min-height: 100%; }
body {
  font-family: 'Segoe UI', system-ui, sans-serif;
  background:
    radial-gradient(ellipse 90% 40% at 50% 0%, #2b1d1255, transparent),
    var(--bg);
  color: var(--cream);
  display: flex; flex-direction: column; align-items: center;
}
.pole-strip {
  width: 100%; height: 8px;
  background: repeating-linear-gradient(45deg,
    #b3382e 0 14px, #f2e8d5 14px 28px, #2d4a7a 28px 42px, #f2e8d5 42px 56px);
}
.wrap { width: 100%; max-width: 480px; padding: 20px 16px 48px; }
header.app { text-align: center; padding: 18px 0 6px; }
header.app h1 {
  font-family: Georgia, serif; font-weight: 400; font-size: 26px;
  letter-spacing: 3px; text-transform: uppercase;
}
header.app h1 b { color: var(--gold); font-weight: 400; }
header.app .sub { color: var(--muted); font-size: 12.5px; letter-spacing: 2px; margin-top: 2px; }

.steps { display: flex; gap: 6px; justify-content: center; margin: 16px 0 20px; }
.steps i { width: 26px; height: 4px; border-radius: 2px; background: var(--border); }
.steps i.on { background: var(--gold); }

h2.q { font-size: 17px; margin: 6px 0 14px; font-weight: 600; }

.card {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  width: 100%; text-align: left;
  background: var(--card); border: 1px solid var(--border); border-radius: 12px;
  color: var(--cream); padding: 15px 16px; margin-bottom: 10px;
  font-size: 15.5px; cursor: pointer; transition: border-color .15s, transform .1s;
}
.card:active { transform: scale(.985); }
.card:hover, .card.sel { border-color: var(--gold); }
.card .meta { color: var(--muted); font-size: 12.5px; margin-top: 3px; }
.card .price { color: var(--gold); font-weight: 700; white-space: nowrap; }

.daystrip { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 8px; margin-bottom: 14px; -webkit-overflow-scrolling: touch; }
.day {
  min-width: 64px; padding: 10px 6px; text-align: center; border-radius: 12px;
  background: var(--card); border: 1px solid var(--border); cursor: pointer; color: var(--cream);
}
.day.sel { border-color: var(--gold); background: var(--card-2); }
.day .dow { font-size: 11px; color: var(--muted); text-transform: uppercase; }
.day .num { font-size: 19px; font-weight: 700; margin-top: 2px; }

.slots { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.slot {
  padding: 11px 0; text-align: center; border-radius: 10px; font-size: 14.5px;
  background: var(--card); border: 1px solid var(--border); color: var(--cream); cursor: pointer;
}
.slot.sel { border-color: var(--gold); background: var(--card-2); color: var(--gold); font-weight: 700; }

label { display: block; font-size: 13px; color: var(--muted); margin: 14px 0 6px; }
input[type=text], input[type=tel], input[type=email], input[type=password], input[type=date], input[type=time], select {
  width: 100%; padding: 13px 14px; border-radius: 10px; font-size: 16px;
  background: var(--card); border: 1px solid var(--border); color: var(--cream);
}
input:focus, select:focus { outline: none; border-color: var(--gold); }

.btn {
  display: block; width: 100%; padding: 15px; margin-top: 18px;
  border: none; border-radius: 12px; font-size: 16px; font-weight: 700; cursor: pointer;
  background: var(--gold); color: #1a130b;
}
.btn:disabled { opacity: .45; cursor: default; }
.btn.ghost { background: transparent; border: 1px solid var(--border); color: var(--muted); margin-top: 10px; }
.btn.danger { background: transparent; border: 1px solid var(--err); color: var(--err); }

.back { background: none; border: none; color: var(--muted); font-size: 14px; cursor: pointer; padding: 4px 0; margin-bottom: 8px; }
.note { color: var(--muted); font-size: 12.5px; line-height: 1.55; margin-top: 12px; }
.errbox { background: #3a201b; border: 1px solid var(--err); color: #f3c4bb; padding: 12px 14px; border-radius: 10px; font-size: 14px; margin-top: 12px; }
.empty { text-align: center; color: var(--muted); padding: 26px 0; font-size: 14.5px; }

.success { text-align: center; padding-top: 10px; }
.success .big { font-size: 56px; }
.success .codebox {
  font-family: Consolas, monospace; font-size: 28px; letter-spacing: 2px; color: var(--gold);
  background: var(--card); border: 1px dashed var(--gold); border-radius: 12px;
  padding: 14px; margin: 16px 0 6px;
}
.kv { display: flex; justify-content: space-between; padding: 9px 0; border-bottom: 1px solid var(--border); font-size: 14.5px; }
.kv b { color: var(--cream); }
.kv span { color: var(--muted); }
.status-pill { display: inline-block; padding: 4px 12px; border-radius: 99px; font-size: 12.5px; font-weight: 700; }
.st-confirmed { background: #1d3323; color: var(--ok); }
.st-cancelled { background: #3a201b; color: var(--err); }
.st-done { background: var(--card-2); color: var(--muted); }
footer.app { margin-top: 40px; text-align: center; color: #6b5d45; font-size: 11.5px; line-height: 1.7; }
footer.app a { color: var(--muted); }
.spin { text-align: center; color: var(--muted); padding: 22px 0; }
