*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --ink:#1A1916;--terra:#4A3728;--terra-l:#7A5C44;
  --sage:#4E7A5A;--sage-l:#7AAF88;--sage-pale:#EAF2EC;
  --paper:#FAF9F7;--cream:#FAF9F7;--white:#fff;
  --txt:#2A2018;--txt-m:#6B5A4E;--txt-l:#9E8C80;
  --accent:#C4875A;--accent-pale:#F5E8DC;
  --bd:rgba(74,55,40,0.13);--ok:#2E7D32;
}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--txt);-webkit-text-size-adjust:100%;max-width:480px;margin:0 auto;}

.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--white);border-bottom:0.5px solid var(--bd);position:sticky;top:0;z-index:50;}
.logo{font-family:'DM Serif Display',serif;font-size:20px;color:var(--terra);}
.logo em{color:var(--sage);font-style:italic;}
.nav-pills{display:flex;background:var(--cream);border-radius:8px;padding:3px;gap:3px;}
.pill{border:none;background:transparent;padding:7px 12px;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--txt-m);cursor:pointer;transition:all .18s;white-space:nowrap;}
.pill.active{background:var(--white);color:var(--terra);font-weight:500;box-shadow:0 1px 3px rgba(0,0,0,.09);}

.page{display:none;}
.page.on{display:block;}

/* ── CLIENT ── */
.hero{padding:28px 20px 16px;text-align:center;}
.hero h1{font-family:'DM Serif Display',serif;font-size:30px;color:var(--terra);line-height:1.1;margin-bottom:6px;}
.hero h1 em{color:var(--sage);}
.hero p{font-size:14px;color:var(--txt-m);font-weight:300;}

.steps{display:flex;align-items:center;justify-content:center;padding:0 20px 20px;}
.step-dot{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--bd);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--txt-l);background:var(--white);transition:all .2s;flex-shrink:0;}
.step-dot.done{background:var(--sage);border-color:var(--sage);color:white;}
.step-dot.active{border-color:var(--accent);color:var(--accent);}
.step-line{flex:1;height:1.5px;background:var(--bd);margin:0 4px;}
.step-line.done{background:var(--sage);}

.svc-list{display:flex;flex-direction:column;gap:10px;padding:0 16px 8px;}
.svc-card{background:var(--white);border:0.5px solid var(--bd);border-radius:14px;padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .18s;-webkit-tap-highlight-color:transparent;}
.svc-card:active{transform:scale(.98);}
.svc-card.sel{border-color:var(--accent);background:var(--accent-pale);}
.svc-icon{width:44px;height:44px;border-radius:12px;background:var(--sage-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px;}
.svc-info{flex:1;}
.svc-name{font-size:15px;font-weight:500;color:var(--txt);margin-bottom:2px;}
.svc-meta{font-size:12px;color:var(--txt-l);}
.svc-price{font-size:17px;font-weight:500;color:var(--accent);white-space:nowrap;}
.svc-check{font-size:16px;color:var(--sage);opacity:0;transition:opacity .15s;margin-left:4px;}
.svc-card.sel .svc-check{opacity:1;}

.sec{background:var(--white);border-radius:16px;margin:0 16px 14px;padding:18px 16px;border:0.5px solid var(--bd);}
.sec-title{font-size:13px;font-weight:500;color:var(--terra);margin-bottom:14px;}

.fgroup{margin-bottom:12px;}
.fgroup label{display:block;font-size:11px;font-weight:500;color:var(--txt-m);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;}
.fgroup input,.fgroup select{width:100%;font-family:'DM Sans',sans-serif;font-size:15px;padding:12px 14px;border:0.5px solid var(--bd);border-radius:10px;background:var(--cream);color:var(--txt);outline:none;-webkit-appearance:none;transition:border-color .18s;}
.fgroup input:focus,.fgroup select:focus{border-color:var(--accent);background:var(--white);}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

.slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.tslot{padding:11px 4px;text-align:center;border:0.5px solid var(--bd);border-radius:10px;font-size:14px;cursor:pointer;color:var(--txt-m);background:var(--cream);transition:all .15s;-webkit-tap-highlight-color:transparent;}
.tslot.sel{background:var(--accent);color:white;border-color:var(--accent);font-weight:500;}
.tslot.blk{opacity:.35;pointer-events:none;background:var(--bd);}
.slots-empty{font-size:13px;color:var(--txt-l);padding:8px 0;text-align:center;}

.pay-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.pay-opt{border:0.5px solid var(--bd);border-radius:12px;padding:14px 12px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .18s;-webkit-tap-highlight-color:transparent;background:var(--cream);}
.pay-opt.sel{border-color:var(--sage);background:var(--sage-pale);}
.pay-label{font-size:14px;font-weight:500;color:var(--txt);}
.pay-sub{font-size:11px;color:var(--txt-l);margin-top:1px;}

.confirm-rows{display:flex;flex-direction:column;gap:6px;}
.confirm-row{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;background:var(--cream);border-radius:8px;}
.confirm-lbl{font-size:13px;color:var(--txt-l);}
.confirm-val{font-size:13px;font-weight:500;color:var(--txt);text-align:right;max-width:60%;}
.confirm-total{display:flex;justify-content:space-between;align-items:center;padding:11px 12px;background:var(--accent-pale);border-radius:8px;border:0.5px solid var(--accent);}

.cta-wrap{padding:4px 16px 24px;}
.btn{width:100%;padding:15px;background:var(--terra);color:white;border:none;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:16px;font-weight:500;cursor:pointer;transition:background .18s;-webkit-tap-highlight-color:transparent;}
.btn:active{background:var(--terra-l);}
.btn:disabled{background:var(--txt-l);cursor:not-allowed;}
.btn-ghost{background:transparent;color:var(--terra);border:1.5px solid var(--terra);margin-top:10px;}
.btn-sage{background:var(--sage);color:white;}
.btn-sage:active{background:var(--sage-l);}
.btn-danger{background:#C0392B;color:white;}

.success{display:none;text-align:center;padding:48px 24px 80px;}
.success.on{display:block;}
.success-ico{font-size:56px;margin-bottom:16px;}
.success h2{font-family:'DM Serif Display',serif;font-size:28px;color:var(--terra);margin-bottom:8px;}
.success p{font-size:14px;color:var(--txt-m);line-height:1.6;}
.pix-card{background:var(--white);border:1.5px dashed var(--sage);border-radius:14px;padding:18px;margin:20px 0;text-align:left;}
.pix-card-title{font-size:13px;font-weight:500;color:var(--terra);margin-bottom:4px;}
.pix-card-sub{font-size:12px;color:var(--txt-l);margin-bottom:10px;}
.pix-key{font-family:monospace;font-size:15px;color:var(--terra);background:var(--cream);padding:10px 12px;border-radius:8px;word-break:break-all;}

/* ── ADMIN ── */
.admin-hero{padding:20px 16px 0;}
.admin-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;}
.admin-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--terra);}
.admin-sub{font-size:12px;color:var(--txt-l);margin-top:2px;}
.btn-sm{background:var(--sage);color:white;border:none;border-radius:9px;padding:9px 16px;font-family:'DM Sans',sans-serif;font-size:13px;cursor:pointer;}

.admin-tabs{display:flex;gap:4px;padding:0 16px;margin-bottom:16px;}
.atab{flex:1;padding:9px;text-align:center;border:0.5px solid var(--bd);border-radius:10px;font-size:13px;color:var(--txt-m);cursor:pointer;background:var(--white);transition:all .18s;}
.atab.active{background:var(--terra);color:white;border-color:var(--terra);}

.date-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px;}
.dbn{width:38px;height:38px;border:0.5px solid var(--bd);border-radius:9px;background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--txt-m);}
.ddate{flex:1;text-align:center;font-size:14px;font-weight:500;color:var(--terra);}

.metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px;margin-bottom:14px;}
.metric{background:var(--white);border:0.5px solid var(--bd);border-radius:12px;padding:14px 12px;}
.metric-lbl{font-size:10px;color:var(--txt-l);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.metric-val{font-size:20px;font-weight:500;color:var(--terra);}
.metric-hint{font-size:10px;color:var(--txt-l);margin-top:2px;}

.panel{background:var(--white);border:0.5px solid var(--bd);border-radius:14px;margin:0 16px 12px;padding:16px;}
.panel-title{font-size:13px;font-weight:500;color:var(--terra);margin-bottom:12px;}

.appt-item{display:flex;gap:10px;padding:10px;border-radius:10px;background:var(--cream);border:0.5px solid var(--bd);margin-bottom:8px;align-items:flex-start;}
.appt-item:last-child{margin-bottom:0;}
.appt-item.conf{border-left:3px solid var(--sage);}
.appt-item.pend{border-left:3px solid var(--accent);}
.appt-time{font-size:13px;font-weight:500;color:var(--terra);min-width:42px;margin-top:1px;}
.appt-client{font-size:14px;font-weight:500;color:var(--txt);}
.appt-svc{font-size:12px;color:var(--txt-l);margin-top:1px;}
.appt-price{font-size:14px;font-weight:500;color:var(--accent);white-space:nowrap;}
.dot{width:7px;height:7px;border-radius:50%;margin-top:5px;flex-shrink:0;}
.dot-g{background:var(--sage);}
.dot-a{background:var(--accent);}

.fin-item{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:0.5px solid var(--bd);}
.fin-item:last-child{border-bottom:none;}
.fin-name{font-size:13px;color:var(--txt);}
.fin-svc{font-size:11px;color:var(--txt-l);margin-top:1px;}
.fin-amt{font-size:14px;font-weight:500;}
.fin-amt.cr{color:var(--ok);}
.fin-amt.pd{color:var(--accent);}
.fin-footer{display:flex;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:0.5px solid var(--bd);}

.client-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:0.5px solid var(--bd);}
.client-item:last-child{border-bottom:none;}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--sage-pale);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--sage);flex-shrink:0;}
.client-name{font-size:14px;font-weight:500;color:var(--txt);}
.client-meta{font-size:11px;color:var(--txt-l);margin-top:1px;}
.badge{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:500;}
.badge-g{background:var(--sage-pale);color:var(--sage);}
.badge-a{background:var(--accent-pale);color:var(--accent);}

/* ── DISPONIBILIDADE ── */
.avail-section{display:none;}
.avail-section.on{display:block;}

.weekday-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:20px;}
.wday{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.wday-label{font-size:10px;color:var(--txt-l);font-weight:500;text-transform:uppercase;}
.wday-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--bd);background:var(--cream);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--txt-m);transition:all .18s;}
.wday.on .wday-btn{background:var(--sage);border-color:var(--sage);color:white;}
.wday.on .wday-label{color:var(--sage);}

.day-schedule{background:var(--cream);border-radius:12px;padding:14px;margin-bottom:10px;border:0.5px solid var(--bd);}
.day-schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.day-schedule-name{font-size:14px;font-weight:500;color:var(--terra);}
.day-schedule-status{font-size:11px;color:var(--txt-l);}
.time-toggle-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.time-toggle{padding:8px 4px;text-align:center;border:0.5px solid var(--bd);border-radius:8px;font-size:12px;cursor:pointer;color:var(--txt-m);background:var(--white);transition:all .15s;-webkit-tap-highlight-color:transparent;}
.time-toggle.on{background:var(--sage);color:white;border-color:var(--sage);}

.blocked-dates{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.blocked-date-item{display:flex;align-items:center;justify-content:space-between;background:var(--cream);padding:10px 12px;border-radius:10px;border:0.5px solid var(--bd);}
.blocked-date-lbl{font-size:13px;color:var(--txt);}
.remove-btn{background:none;border:none;color:#C0392B;cursor:pointer;font-size:18px;padding:0 4px;}

.add-date-row{display:flex;gap:8px;margin-top:10px;}
.add-date-row input{flex:1;font-family:'DM Sans',sans-serif;font-size:14px;padding:10px 12px;border:0.5px solid var(--bd);border-radius:10px;background:var(--cream);color:var(--txt);outline:none;}
.add-date-row input:focus{border-color:var(--accent);}
.add-date-btn{background:var(--terra);color:white;border:none;border-radius:10px;padding:10px 16px;font-family:'DM Sans',sans-serif;font-size:13px;cursor:pointer;white-space:nowrap;}

.save-banner{background:var(--sage);color:white;text-align:center;padding:10px;font-size:13px;font-weight:500;border-radius:10px;margin:0 16px 12px;display:none;}
.save-banner.on{display:block;}

/* ── MODAL ── */
.overlay{display:none;position:fixed;inset:0;background:rgba(42,32,24,.5);z-index:200;align-items:flex-end;justify-content:center;}
.overlay.on{display:flex;}
.modal{background:var(--white);border-radius:20px 20px 0 0;padding:20px 16px 36px;width:100%;max-width:480px;}
.modal-handle{width:36px;height:4px;background:var(--bd);border-radius:2px;margin:0 auto 16px;}
.modal-ttl{font-size:15px;font-weight:500;color:var(--terra);margin-bottom:16px;}
.empty{font-size:13px;color:var(--txt-l);padding:8px 0;text-align:center;}
