/* Horaê — estilos compartilhados. Cores em variáveis (aplicarTema() troca em runtime por tenant). */
:root{
  --bg:#f7ede9; --surface:#fffbf9; --surface-2:#f3e4dd;
  --ink:#4b2e25; --muted:#9c7466;
  --brand:#a9714f; --brand-2:#c9a057; --brand-deep:#8a5638;
  --rose:#b97f6d;
  --line:rgba(75,46,37,.12); --line-brand:rgba(169,113,79,.35);
  --ok:#3f7d4e; --danger:#a4483c;
  --display:"Fraunces",Georgia,serif;
  --body:"Manrope",system-ui,sans-serif;
  --radius:16px; --shadow:0 20px 50px -30px rgba(75,46,37,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--body);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;
  background:
    radial-gradient(90% 60% at 100% 0%,rgba(201,160,87,.14),transparent 60%),
    radial-gradient(70% 50% at 0% 100%,rgba(185,127,109,.14),transparent 60%),
    var(--bg);
  min-height:100vh}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.1}
button,input,select{font-family:var(--body)}
.wrap{width:min(760px,94vw);margin-inline:auto;padding-bottom:4rem}

.head{text-align:center;padding:2rem 0 1.4rem}
.head-logo{max-width:220px;max-height:180px;width:auto;height:auto;margin:0 auto .6rem;display:block}
.head h1{font-size:1.9rem;letter-spacing:.03em;color:var(--brand-deep)}
.head .sub{font-size:.68rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--brand);margin-top:.3rem}
.head .slogan{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--rose);margin-top:.35rem}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.4rem;margin-bottom:1rem}
.kicker{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.22em;color:var(--brand)}
.card h2{font-size:1.3rem;margin:.2rem 0 .9rem}
.hint{color:var(--muted);font-size:.82rem;margin:-.5rem 0 .9rem}

.steps{display:flex;gap:.4rem;justify-content:center;margin-bottom:1.1rem;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap}
.steps span{padding:.3rem .75rem;border-radius:999px;border:1px solid var(--line)}
.steps span.on{background:var(--brand);border-color:var(--brand);color:#fff}
.steps span.done{border-color:var(--line-brand);color:var(--brand-deep)}

.catgrid{display:grid;gap:.55rem}
.cat-title{display:flex;align-items:center;gap:.6rem;margin:1rem 0 .55rem;font-family:var(--display);font-size:1.05rem;color:var(--brand-deep)}
.cat-icon{height:52px;width:auto;flex:none}
.cat-title::after{content:"";flex:1;height:1px;background:var(--line-brand)}
.svc{display:flex;align-items:center;justify-content:space-between;gap:.8rem;text-align:left;width:100%;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem;cursor:pointer;
  transition:border-color .2s,transform .2s,box-shadow .2s}
.svc:hover{border-color:var(--brand);transform:translateY(-1px);box-shadow:0 10px 24px -18px var(--brand)}
.svc b{font-size:.95rem;font-weight:700}
.svc small{display:block;color:var(--muted);font-size:.76rem}
.svc .preco{font-family:var(--display);font-size:1.02rem;color:var(--brand-deep);white-space:nowrap}
.svc-check{flex:none;width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line-brand);display:grid;place-items:center;
  font-size:.7rem;color:transparent;transition:all .15s}
.svc.selected{border-color:var(--brand);background:linear-gradient(160deg,#fff,var(--surface-2));box-shadow:0 8px 18px -14px var(--brand)}
.svc.selected .svc-check{background:var(--brand);border-color:var(--brand);color:#fff}
.multi-bar{position:sticky;bottom:.7rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:var(--surface);border:1px solid var(--line-brand);border-radius:14px;padding:.8rem 1rem;margin-top:1rem;
  box-shadow:0 16px 34px -18px rgba(75,46,37,.5)}
.multi-info{display:flex;flex-direction:column;line-height:1.3}
.multi-info b{font-size:.85rem}
.multi-info span{font-family:var(--display);font-size:1.1rem;color:var(--brand-deep)}
.multi-bar .btn{padding:.65rem 1.3rem;font-size:.85rem}

.days{display:flex;gap:.45rem;overflow-x:auto;padding:.2rem .1rem .6rem;scrollbar-width:thin}
.day{flex:none;min-width:64px;text-align:center;border:1px solid var(--line);border-radius:12px;background:var(--surface);
  padding:.5rem .55rem;cursor:pointer;transition:border-color .2s}
.day small{display:block;font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.day b{font-family:var(--display);font-size:1.15rem;font-weight:500}
.day em{display:block;font-style:normal;font-size:.62rem;color:var(--muted)}
.day.on{border-color:var(--brand);background:linear-gradient(160deg,#fff,var(--surface-2));box-shadow:0 8px 18px -12px var(--brand)}
.day.on small,.day.on em{color:var(--brand-deep)}
.wd-week{display:grid;grid-template-columns:repeat(7,1fr);gap:.4rem;margin-bottom:.5rem}
.wd-day{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:.5rem .2rem;
  text-align:center;cursor:pointer;transition:all .15s}
.wd-day small{display:block;font-size:.58rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.wd-day b{font-family:var(--display);font-size:1.05rem;font-weight:500}
.wd-day.on{background:var(--brand);border-color:var(--brand)}
.wd-day.on small,.wd-day.on b{color:#fff}
.wd-day.past{opacity:.35;cursor:default}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:.45rem;margin-top:.6rem}
.slot{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:.5rem 0;text-align:center;
  font-weight:700;font-size:.88rem;cursor:pointer;transition:all .15s}
.slot:hover{border-color:var(--brand);color:var(--brand-deep)}
.slot.on{background:var(--brand);border-color:var(--brand);color:#fff}
.empty{color:var(--muted);font-size:.88rem;padding:.8rem 0;text-align:center}

label{display:block;font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:.8rem 0 .3rem}
input,select{width:100%;padding:.7rem .85rem;border:1px solid var(--line);border-radius:10px;background:#fff;
  font-size:.95rem;color:var(--ink)}
input:focus,select:focus{outline:2px solid var(--line-brand);border-color:var(--brand)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:800;font-size:.9rem;
  padding:.85rem 1.6rem;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .2s,box-shadow .2s}
.btn-brand{background:linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;box-shadow:0 12px 26px -14px var(--brand)}
.btn-brand:hover{transform:translateY(-2px)}
.btn-line{border-color:var(--line-brand);background:transparent;color:var(--brand-deep)}
.btn-wpp{background:#25d366;color:#08331a}
.btn-block{width:100%;margin-top:1.1rem}
.btn-back{background:none;border:0;color:var(--muted);font-size:.8rem;font-weight:700;cursor:pointer;
  display:inline-flex;align-items:center;gap:.3rem;margin-bottom:.8rem}
.btn-back:hover{color:var(--brand-deep)}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none !important}

.resumo{background:var(--surface-2);border:1px dashed var(--line-brand);border-radius:12px;padding:.9rem 1rem;font-size:.9rem}
.resumo b{font-family:var(--display);font-weight:600}
.resumo .linha{display:flex;justify-content:space-between;gap:1rem;padding:.15rem 0}

.success{text-align:center;padding:1.2rem 0}
.success .check{width:64px;height:64px;margin:0 auto .8rem;border-radius:50%;background:rgba(63,125,78,.12);
  display:grid;place-items:center;color:var(--ok);font-size:1.7rem}
.success p{color:var(--muted);font-size:.92rem;max-width:42ch;margin:.4rem auto 1.1rem}

.tabs{display:flex;gap:.45rem;margin-bottom:.8rem}
.tab{border:1px solid var(--line);background:var(--surface);color:var(--muted);font-weight:800;font-size:.78rem;
  letter-spacing:.08em;text-transform:uppercase;padding:.5rem 1.15rem;border-radius:999px;cursor:pointer;transition:all .15s}
.tab.on{background:var(--brand);border-color:var(--brand);color:#fff}
.bignum{text-align:center;background:linear-gradient(160deg,#fff,var(--surface-2));border:1px solid var(--line-brand);
  border-radius:12px;padding:1rem;margin-bottom:1rem}
.bignum small{font-size:.66rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.bignum .valor{font-family:var(--display);font-size:2.3rem;color:var(--brand-deep);line-height:1.15}
.delta{font-size:.78rem;font-weight:800;color:var(--muted)}
.delta.up{color:var(--ok)} .delta.down{color:var(--danger)}
.rel-sec{font-size:1.02rem;margin:1.25rem 0 .55rem}
.chart{display:flex;align-items:flex-end;gap:.5rem;padding:.3rem .1rem 0}
.chart .bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.25rem;cursor:pointer}
.chart .bar i{display:block;width:100%;max-width:46px;background:linear-gradient(180deg,var(--brand-2),var(--brand));
  border-radius:6px 6px 2px 2px;min-height:3px}
.chart .bar.sel i{background:linear-gradient(180deg,var(--rose),var(--brand-deep))}
.chart .bar small{font-size:.62rem;font-weight:800;text-transform:uppercase;color:var(--muted)}
.chart .bar.sel small{color:var(--brand-deep)}
.chart .bar b{font-size:.6rem;color:var(--brand-deep);white-space:nowrap}
.top-item{display:flex;align-items:center;gap:.8rem;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:.7rem .9rem;margin-bottom:.5rem}
.top-item .pos{font-family:var(--display);font-size:1.15rem;color:var(--brand-2);min-width:26px;text-align:center}
.top-item .ti-info{flex:1;min-width:0}
.top-item .ti-info b{font-size:.9rem}
.top-item .ti-info small{display:block;color:var(--muted);font-size:.74rem;margin-bottom:.3rem}
.share{height:5px;border-radius:99px;background:var(--surface-2);overflow:hidden}
.share i{display:block;height:100%;background:linear-gradient(90deg,var(--brand-2),var(--brand))}
.top-item .ti-val{font-weight:800;font-size:.88rem;color:var(--brand-deep);white-space:nowrap}

.adminbar{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:1rem;flex-wrap:wrap}
.adminbar h2{font-size:1.25rem}
.daynav{display:flex;align-items:center;gap:.5rem}
.daynav button{width:36px;height:36px;border-radius:10px;border:1px solid var(--line);background:var(--surface);
  cursor:pointer;font-size:1rem;color:var(--brand-deep)}
.daynav b{font-family:var(--display);font-weight:500;font-size:1rem;min-width:150px;text-align:center}
.chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.35rem .9rem;font-size:.78rem;font-weight:700;color:var(--muted)}
.chip b{color:var(--brand-deep);font-weight:800}
.agenda-item{display:flex;gap:.9rem;align-items:center;background:var(--surface);border:1px solid var(--line);
  border-left:4px solid var(--brand);border-radius:12px;padding:.75rem .95rem;margin-bottom:.5rem;flex-wrap:wrap}
.agenda-item.bloqueio{border-left-color:var(--muted);opacity:.85}
.agenda-item.st-concluido{border-left-color:var(--ok)}
.agenda-item.st-cancelado{border-left-color:#b9a49b;opacity:.68}
.agenda-item.st-cancelado .preco{text-decoration:line-through}
.agenda-item .hora{font-family:var(--display);font-size:1rem;color:var(--brand-deep);white-space:nowrap;min-width:96px}
.agenda-item .info{flex:1;min-width:0}
.agenda-item .info b{font-size:.93rem}
.agenda-item .info small{display:block;color:var(--muted);font-size:.76rem}
.agenda-item .preco{font-weight:800;font-size:.88rem;color:var(--brand-deep);white-space:nowrap}
.agenda-item .del{border:0;background:none;color:var(--danger);cursor:pointer;font-size:1rem;padding:.2rem .4rem}
.sttag{display:inline-block;font-size:.58rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  border-radius:99px;padding:.08rem .5rem;margin-top:.2rem}
.sttag.ok{background:rgba(63,125,78,.12);color:var(--ok)}
.sttag.canc{background:rgba(164,72,60,.12);color:var(--danger)}
.acoes{display:flex;gap:.3rem;flex:none;margin-left:auto}
.act{width:31px;height:31px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;
  font-size:.85rem;color:var(--muted);display:grid;place-items:center;transition:all .15s;padding:0}
.act:hover{border-color:var(--brand);color:var(--brand-deep)}
.act.ok:hover{border-color:var(--ok);color:var(--ok)}
.act.danger:hover{border-color:var(--danger);color:var(--danger)}
.remarcar-box{background:var(--surface-2);border:1px dashed var(--line-brand);border-radius:12px;padding:.85rem .95rem;margin:-.15rem 0 .6rem;width:100%}
details{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem;margin-bottom:.6rem}
details summary{cursor:pointer;font-weight:800;font-size:.85rem;color:var(--brand-deep);list-style:none}
details summary::before{content:"+ "}
details[open] summary::before{content:"− "}
.formrow{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.hs-dia{display:flex;align-items:flex-end;gap:.6rem;grid-template-columns:none;margin-bottom:.6rem}
.hs-dia>div{flex:1}
.wd-sem-dia{border:1px solid var(--line);border-radius:12px;padding:.7rem .85rem;margin-bottom:.6rem;background:var(--surface)}
.wd-sem-cab{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.wd-sem-cab b{font-size:.88rem;text-transform:capitalize}
.wd-sem-cab small{color:var(--muted);font-size:.72rem;text-transform:uppercase;font-weight:800;letter-spacing:.06em}
.wd-sem-dia .agenda-item{padding:.6rem .8rem}
.sv-row{display:flex;align-items:center;gap:.7rem;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:.6rem .8rem;margin-bottom:.4rem;flex-wrap:wrap}
.sv-row.off{opacity:.55}
.sv-nome{flex:1;min-width:120px}
.sv-nome small{display:block;color:var(--muted);font-size:.74rem}
.sv-preco{display:flex;align-items:center;gap:.3rem;font-weight:700;color:var(--brand-deep)}
.sv-preco input{width:5.5rem;padding:.4rem .5rem;text-align:right}
.sv-toggle{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.76rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;color:var(--muted);white-space:nowrap}
.sv-toggle input{width:auto;accent-color:var(--brand)}
.check-list{display:flex;flex-direction:column;gap:.4rem;max-height:220px;overflow-y:auto;border:1px solid var(--line);
  border-radius:10px;padding:.5rem;background:#fff}
.check-row{display:flex;align-items:center;gap:.6rem;padding:.35rem .4rem;border-radius:8px;cursor:pointer;font-size:.86rem}
.check-row:hover{background:var(--surface-2)}
.check-row input{width:auto;margin:0}
.check-row span{flex:1}
.check-row b{color:var(--brand-deep);font-weight:700;font-size:.82rem;white-space:nowrap}
.man-total{display:flex;justify-content:space-between;font-size:.85rem;font-weight:800;color:var(--brand-deep);
  padding:.5rem .2rem 0}

.client-item{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.8rem .95rem;margin-bottom:.5rem;cursor:pointer}
.client-item .ci-top{display:flex;justify-content:space-between;align-items:center;gap:.8rem}
.client-item b{font-size:.93rem}
.client-item .ci-meta{color:var(--muted);font-size:.76rem;margin-top:.15rem}
.client-item .ci-badge{font-size:.62rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;border-radius:99px;padding:.15rem .6rem;white-space:nowrap}
.ci-badge.due{background:rgba(164,72,60,.12);color:var(--danger)}
.ci-badge.ok{background:rgba(63,125,78,.12);color:var(--ok)}
.client-hist{margin-top:.7rem;padding-top:.6rem;border-top:1px dashed var(--line-brand);font-size:.8rem;color:var(--muted)}
.client-hist div{display:flex;justify-content:space-between;padding:.2rem 0}

.login-box{max-width:380px;margin:3rem auto}
.errbox{background:rgba(164,72,60,.1);border:1px solid rgba(164,72,60,.3);color:var(--danger);border-radius:10px;
  padding:.7rem .9rem;font-size:.85rem;margin-top:.8rem}

.foot{text-align:center;color:var(--muted);font-size:.72rem;padding:1.5rem 0 0}
.foot a{color:var(--brand-deep);font-weight:700;text-decoration:none;cursor:pointer}
[hidden]{display:none !important}
@media(max-width:520px){ .formrow{grid-template-columns:1fr} .agenda-item .hora{min-width:78px;font-size:.9rem} }
