/* ============================================================
   AgendaPro — estilos
   Paleta: navy profundo + dourado discreto. Display serifado
   (Georgia) para títulos; sans para corpo. Cantos suaves.
   ============================================================ */
:root{
  --navy:#0D1B3E; --navy2:#1A2F5E; --navy3:#2A4480;
  --steel:#4A6FA5; --steel2:#7B9CCF; --sky:#EEF3FB;
  --gold:#C9A84C; --gold2:#E2C97E; --gold3:#FBF5E6; --goldb:#D4B86A;
  --gray:#6B7280; --lgray:#E5E9F0; --charcoal:#1F2937; --line:#E5E9F0;
  --ok:#166534; --oks:#DCFCE7; --red:#991B1B; --reds:#FEE2E2;
  --warn:#92400E; --warns:#FEF3C7; --blue:#1E40AF; --blues:#DBEAFE;
  --gray-s:#E5E7EB;
  --radius:14px; --shadow:0 4px 24px rgba(13,27,62,.10);
  --maxw:1100px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;}
body{
  font-family:system-ui,"Segoe UI",Roboto,sans-serif;
  color:var(--charcoal); background:#E8EEF7; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--navy2);text-decoration:none;}
h1,h2,h3,.serif{font-family:Georgia,"Times New Roman",serif;}
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-thumb{background:var(--steel2);border-radius:10px;}

/* ---- App chrome ---- */
.topbar{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-bottom:2px solid var(--gold);
  position:sticky;top:0;z-index:50;
  box-shadow:0 3px 20px rgba(13,27,62,.4);
}
.topbar-in{
  max-width:var(--maxw);margin:0 auto;padding:0 18px;height:58px;
  display:flex;align-items:center;gap:18px;
}
.logo{font-family:Georgia,serif;font-size:21px;color:#fff;letter-spacing:.3px;white-space:nowrap;}
.logo b{color:var(--gold2);font-weight:400;}
.nav{display:flex;gap:2px;margin-left:8px;overflow-x:auto;flex:1;}
.nav a{
  color:rgba(255,255,255,.62);font-size:13.5px;padding:9px 13px;border-radius:9px;
  white-space:nowrap;transition:.15s;
}
.nav a:hover{color:#fff;background:rgba(255,255,255,.08);}
.nav a.on{color:var(--navy);background:linear-gradient(135deg,var(--gold),var(--gold2));font-weight:600;}
.topbar-right{display:flex;align-items:center;gap:12px;}
.who{color:rgba(255,255,255,.85);font-size:12.5px;text-align:right;line-height:1.25;}
.who small{color:var(--gold2);display:block;font-size:10.5px;}
.btn-ghost{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);
  color:#fff;padding:7px 12px;border-radius:9px;font-size:12.5px;cursor:pointer;
}
.btn-ghost:hover{background:rgba(255,255,255,.16);}

.wrap{max-width:var(--maxw);margin:0 auto;padding:20px 18px 60px;}

/* ---- Banner de assinatura ---- */
.subbar{
  background:var(--warns);color:var(--warn);border-bottom:1px solid #fcd34d;
  font-size:13px;text-align:center;padding:7px 14px;
}
.subbar.ok{background:var(--gold3);color:#7a5b12;border-color:var(--goldb);}
.subbar a{color:inherit;text-decoration:underline;font-weight:600;}

/* ---- Flash ---- */
.flash{
  border-radius:11px;padding:11px 15px;font-size:13.5px;margin-bottom:16px;
  border:1px solid transparent;display:flex;gap:8px;align-items:center;
}
.flash.ok{background:var(--oks);color:var(--ok);border-color:#86efac;}
.flash.red{background:var(--reds);color:var(--red);border-color:#fca5a5;}
.flash.warn{background:var(--warns);color:var(--warn);border-color:#fcd34d;}

/* ---- Page header ---- */
.page-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
.page-head h1{font-size:25px;color:var(--navy);font-weight:600;}
.page-head .sub{color:var(--gray);font-size:13px;}
.spacer{flex:1;}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:7px;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;
  border:2px solid var(--gold);padding:9px 16px;border-radius:50px;
  font-size:13.5px;font-weight:600;cursor:pointer;transition:.15s;
}
.btn:hover{filter:brightness(1.12);}
.btn.block{width:100%;}
.btn-sm{padding:6px 12px;border-radius:50px;font-size:12px;cursor:pointer;font-weight:500;
  border:1.5px solid var(--lgray);background:#fff;color:var(--navy2);}
.btn-sm:hover{border-color:var(--gold);}
.btn-2{background:#fff;color:var(--navy);border:2px solid var(--navy2);}
.btn-danger{background:#fff;color:var(--red);border-color:var(--reds);}

/* ---- Cards / grid ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);}
.card h3{font-size:16px;color:var(--navy);margin-bottom:3px;}
.card .muted{color:var(--gray);font-size:12.5px;}
.card-row{display:flex;align-items:center;gap:10px;}
.av{width:42px;height:42px;min-width:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--navy3));border:2px solid var(--gold);
  color:#fff;display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-size:17px;}
.card-acts{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;}

/* ---- Badges ---- */
.bdg{font-size:11px;padding:2px 9px;border-radius:50px;font-weight:600;white-space:nowrap;display:inline-block;}
.bdg.ok{background:var(--oks);color:var(--ok);}
.bdg.red{background:var(--reds);color:var(--red);}
.bdg.warn{background:var(--warns);color:var(--warn);}
.bdg.blue{background:var(--blues);color:var(--blue);}
.bdg.gray{background:var(--lgray);color:var(--gray);}
.bdg.gold{background:var(--gold3);color:#7a5b12;}

/* ---- Forms ---- */
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px;}
.field label{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--steel);}
.input,select.input,textarea.input{
  width:100%;padding:10px 12px;border:1.5px solid var(--lgray);border-radius:10px;
  font-family:inherit;font-size:14px;color:var(--charcoal);background:#fff;outline:none;transition:.15s;
}
.input:focus{border-color:var(--navy2);box-shadow:0 0 0 3px rgba(42,68,128,.12);}
textarea.input{resize:vertical;min-height:64px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.hint{font-size:12px;color:var(--gray);}

/* ---- Search bar ---- */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px;}
.search{flex:1;min-width:180px;padding:10px 15px;border:1.5px solid var(--lgray);
  border-radius:50px;background:#fff;font-size:14px;outline:none;}

/* ---- Modal ---- */
.overlay{display:none;position:fixed;inset:0;background:rgba(13,27,62,.6);
  backdrop-filter:blur(3px);z-index:200;align-items:center;justify-content:center;padding:16px;}
.overlay.open{display:flex;}
.modal{background:#fff;border-radius:18px;width:100%;max-width:520px;max-height:92vh;
  overflow-y:auto;box-shadow:0 20px 60px rgba(13,27,62,.4);animation:pop .2s ease;}
@keyframes pop{from{transform:translateY(14px);opacity:0;}to{transform:none;opacity:1;}}
.modal-head{background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-bottom:3px solid var(--gold);padding:16px 20px;display:flex;justify-content:space-between;
  align-items:center;position:sticky;top:0;border-radius:18px 18px 0 0;}
.modal-head h2{color:#fff;font-size:19px;}
.modal-close{background:rgba(255,255,255,.12);border:none;color:#fff;width:30px;height:30px;
  border-radius:50%;cursor:pointer;font-size:16px;}
.modal-body{padding:18px 20px;}
.modal-foot{padding:0 20px 20px;display:flex;gap:10px;}

/* ---- Agenda semanal ---- */
.weekbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.weekbar .lbl{font-family:Georgia,serif;font-size:17px;color:var(--navy);min-width:230px;text-align:center;}
.arrow{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--goldb);background:#fff;
  color:var(--navy2);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.arrow:hover{background:var(--gold);color:var(--navy);border-color:var(--gold);}
.week{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;}
.day{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;min-height:120px;
  display:flex;flex-direction:column;}
.day.today{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold3);}
.day-head{padding:8px 6px;text-align:center;background:linear-gradient(180deg,var(--sky),#fff);
  border-bottom:1px solid var(--line);}
.day-head .dn{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--steel);font-weight:700;}
.day-head .dd{font-family:Georgia,serif;font-size:20px;color:var(--navy);}
.day-body{padding:6px;display:flex;flex-direction:column;gap:5px;flex:1;}
.appt{border-left:3px solid var(--navy2);background:var(--sky);border-radius:8px;padding:6px 8px;cursor:pointer;
  transition:.12s;}
.appt:hover{box-shadow:0 2px 10px rgba(13,27,62,.14);}
.appt .t{font-weight:700;font-size:12px;color:var(--navy);}
.appt .n{font-size:12px;color:var(--charcoal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.appt .s{font-size:10.5px;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.appt.cancelled{opacity:.5;text-decoration:line-through;}
.appt.done{border-left-color:var(--ok);background:var(--oks);}
.appt.no_show{border-left-color:var(--red);background:var(--reds);}
.appt.pending{border-left-color:var(--warn);background:var(--warns);}
.day-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--steel2);font-size:11px;
  border:1.5px dashed var(--lgray);border-radius:8px;margin:2px;cursor:pointer;min-height:46px;}
.day-empty:hover{border-color:var(--gold);color:var(--gold);background:var(--gold3);}

/* ---- Plans ---- */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:8px 0 22px;}
.plan{background:#fff;border:2px solid var(--line);border-radius:var(--radius);padding:22px 18px;text-align:center;
  position:relative;box-shadow:var(--shadow);}
.plan.featured{border-color:var(--gold);}
.plan .tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:var(--navy);font-size:11px;font-weight:700;padding:3px 12px;border-radius:50px;}
.plan h3{font-size:20px;color:var(--navy);}
.plan .price{font-family:Georgia,serif;font-size:34px;color:var(--navy);margin:6px 0;}
.plan .price small{font-size:13px;color:var(--gray);font-family:system-ui;}
.plan .per{font-size:12.5px;color:var(--gray);margin-bottom:14px;}

/* ---- Slot picker (público + modal) ---- */
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(74px,1fr));gap:8px;}
.slot{padding:10px 6px;border:1.5px solid var(--lgray);border-radius:10px;text-align:center;cursor:pointer;
  font-size:14px;font-weight:600;color:var(--navy2);background:#fff;transition:.12s;}
.slot:hover{border-color:var(--gold);background:var(--gold3);}
.slot.sel{background:var(--navy);color:#fff;border-color:var(--navy);}
.slot-empty{color:var(--gray);font-size:13px;padding:18px 4px;text-align:center;grid-column:1/-1;}

/* ---- Empty state ---- */
.empty{text-align:center;padding:54px 20px;color:var(--gray);}
.empty .ic{font-size:44px;margin-bottom:10px;}

/* ---- Auth / public centered ---- */
.center-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,var(--navy),var(--navy2));}
.auth-card{background:#fff;border-radius:20px;width:100%;max-width:420px;box-shadow:0 24px 70px rgba(0,0,0,.35);
  overflow:hidden;border-top:4px solid var(--gold);}
.auth-head{padding:26px 26px 8px;text-align:center;}
.auth-head .logo{color:var(--navy);font-size:26px;}
.auth-head .logo b{color:var(--gold);}
.auth-head p{color:var(--gray);font-size:13px;margin-top:4px;}
.auth-body{padding:18px 26px 26px;}
.auth-foot{text-align:center;font-size:13px;color:var(--gray);padding:0 26px 22px;}

/* ---- Public booking ---- */
.pub-card{background:#fff;border-radius:20px;width:100%;max-width:560px;box-shadow:0 24px 70px rgba(0,0,0,.3);
  overflow:hidden;border-top:4px solid var(--gold);}
.pub-head{background:linear-gradient(135deg,var(--navy),var(--navy2));padding:24px 26px;color:#fff;text-align:center;}
.pub-head h1{font-size:23px;}
.pub-head p{color:var(--gold2);font-size:13px;margin-top:3px;}
.pub-body{padding:22px 26px 28px;}
.step-title{font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--steel);
  margin:18px 0 8px;}
.svc-list{display:flex;flex-direction:column;gap:8px;}
.svc{display:flex;align-items:center;gap:12px;border:1.5px solid var(--lgray);border-radius:12px;
  padding:12px 14px;cursor:pointer;transition:.12s;}
.svc:hover{border-color:var(--gold);background:var(--gold3);}
.svc.sel{border-color:var(--navy);background:var(--sky);box-shadow:0 0 0 2px var(--navy2) inset;}
.svc .dot{width:12px;height:12px;border-radius:50%;}
.svc .info{flex:1;}
.svc .info .nm{font-weight:600;font-size:14.5px;color:var(--navy);}
.svc .info .meta{font-size:12px;color:var(--gray);}
.svc .pr{font-weight:700;color:var(--navy);font-size:14px;}

/* ---- Settings: availability ---- */
.dayrow{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);flex-wrap:wrap;}
.dayrow .dname{width:120px;font-weight:600;color:var(--navy2);padding-top:8px;}
.blocks{display:flex;flex-direction:column;gap:8px;flex:1;min-width:220px;}
.block{display:flex;align-items:center;gap:8px;}
.block .input{max-width:120px;}
.tag-link{font-size:12.5px;color:var(--steel);cursor:pointer;border:none;background:none;font-weight:600;}

table.list{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
table.list th{background:var(--navy);color:var(--gold2);font-size:11px;text-transform:uppercase;letter-spacing:.5px;
  text-align:left;padding:11px 14px;}
table.list td{padding:11px 14px;border-bottom:1px solid var(--line);font-size:13.5px;}
table.list tr:last-child td{border-bottom:none;}

@media(max-width:860px){
  .week{grid-template-columns:1fr;}
  .day{min-height:auto;}
  .day-head{display:flex;align-items:center;justify-content:flex-start;gap:8px;text-align:left;}
  .day-head .dd{font-size:16px;}
  .who{display:none;}
}
@media(max-width:520px){
  .row2,.row3{grid-template-columns:1fr;}
  .weekbar .lbl{min-width:0;font-size:15px;}
  .page-head h1{font-size:21px;}
}
