:root{
  --primary:#3C1F8F;
  --ink:#1A1330;
  --bg:#F4F3F8;
  --card:#FFFFFF;
  --muted:#6B6485;
  --line:#E6E2F0;
  --ok:#1E8A5A;
  --err:#C22F4C;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg);color:#241C3D;font-size:14.5px;}
a{text-decoration:none;color:inherit;}

.shell{display:flex;min-height:100vh;}

/* ---------- Sidebar (inspirada no print) ---------- */
.sidebar{
  width:264px;flex-shrink:0;display:flex;flex-direction:column;
  background:linear-gradient(175deg,var(--primary),var(--ink) 85%);
  color:#EFEAFB;padding:22px 16px;position:sticky;top:0;height:100vh;overflow-y:auto;
}
.brand{display:flex;gap:12px;align-items:center;margin-bottom:8px;}
.brand-mark{
  width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:18px;letter-spacing:-1px;color:#fff;
}
.brand-name{font-weight:700;font-size:15px;line-height:1.25;}
.brand-sub{font-size:11px;opacity:.65;}
.sync{font-size:11px;opacity:.6;margin:10px 2px 18px;}

.nav-group{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.5;margin:16px 10px 6px;}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;
  font-size:14px;color:#EFEAFB;margin-bottom:2px;
}
.nav-item svg{width:19px;height:19px;flex-shrink:0;}
.nav-item:hover{background:rgba(255,255,255,.09);}
.nav-item.active{background:rgba(255,255,255,.18);font-weight:600;}
.nav-item.soon{opacity:.42;cursor:default;}
.nav-item.soon em{font-style:normal;font-size:10px;background:rgba(255,255,255,.14);padding:2px 7px;border-radius:20px;margin-left:auto;}
.nav-item.logout{margin-top:auto;opacity:.8;}

/* ---------- Main ---------- */
.main{flex:1;display:flex;flex-direction:column;min-width:0;}
.topbar{
  display:flex;align-items:center;gap:16px;background:var(--card);
  padding:16px 26px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;
}
.topbar h1{font-size:19px;font-weight:700;color:var(--ink);}
.clock{margin-left:auto;font-size:12.5px;color:var(--muted);font-variant-numeric:tabular-nums;}
.hamb{display:none;background:none;border:none;font-size:22px;cursor:pointer;color:var(--ink);}

.page{padding:26px;max-width:1100px;width:100%;}

.flash{margin:16px 26px 0;padding:12px 16px;border-radius:10px;font-size:14px;}
.flash.success{background:#E5F6EE;color:#14603E;}
.flash.error{background:#FBE9EE;color:#8F1F3A;}

/* ---------- Cards / grid ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;}
.card .big{font-size:34px;font-weight:800;color:var(--primary);line-height:1;}
.card .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:8px;}
.card.soon{opacity:.55;}

/* ---------- Tabela ---------- */
.table-wrap{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:auto;}
table{width:100%;border-collapse:collapse;font-size:14px;}
th{
  text-align:left;padding:13px 16px;font-size:11.5px;text-transform:uppercase;
  letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap;
}
td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;}
.badge.role{background:#EFEBFA;color:var(--primary);}
.badge.on{background:#E5F6EE;color:#14603E;}
.badge.off{background:#F4E9EC;color:#8F1F3A;}

/* ---------- Botões e formulários ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;
  border:none;padding:11px 20px;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;
}
.btn:hover{filter:brightness(1.12);}
.btn.ghost{background:transparent;color:var(--primary);border:1px solid var(--primary);}
.btn.sm{padding:7px 14px;font-size:12.5px;}
.btn.danger{background:transparent;color:var(--err);border:1px solid var(--err);}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap;}

.form-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:26px;max-width:560px;}
label{display:block;font-size:13px;font-weight:600;margin:16px 0 6px;color:var(--ink);}
label:first-child{margin-top:0;}
input,select{
  width:100%;padding:11px 13px;border:1px solid #D8D3E8;border-radius:9px;font-size:14.5px;background:#fff;
}
input:focus,select:focus{outline:2px solid var(--primary);border-color:transparent;}
.hint{font-size:12px;color:var(--muted);margin-top:5px;}
.form-actions{margin-top:24px;display:flex;gap:12px;}

/* ---------- Login ---------- */
.login-body{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,var(--primary),var(--ink));padding:24px;
}
.login-card{background:#fff;border-radius:16px;padding:38px;max-width:400px;width:100%;box-shadow:0 30px 60px -20px rgba(0,0,0,.45);}
.login-brand{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);font-weight:800;margin-bottom:8px;}
.login-card h1{font-size:21px;color:var(--ink);margin-bottom:22px;}

/* ---------- Responsivo ---------- */
@media (max-width:820px){
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;z-index:40;transform:translateX(-105%);
    transition:transform .25s ease;box-shadow:0 0 60px rgba(0,0,0,.4);
  }
  .sidebar.open{transform:translateX(0);}
  .hamb{display:block;}
  .page{padding:18px;}
}

/* ================= AGENDA ================= */
.agenda-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px;}
.agenda-nav{display:flex;align-items:center;gap:8px;}
.range-label{margin-left:10px;font-size:16px;color:var(--ink);text-transform:capitalize;}
.agenda-views{display:flex;gap:2px;background:#EDEAF6;border-radius:10px;padding:3px;}
.vtab{padding:8px 16px;border-radius:8px;font-size:13.5px;color:var(--muted);font-weight:500;}
.vtab.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.08);}
.agenda-subbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap;}
.prof-filter{display:flex;align-items:center;gap:10px;}

/* mês */
.cal-month{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:#F7F5FC;border-bottom:1px solid var(--line);}
.cal-hcell{padding:11px;text-align:center;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);}
.cal-cell{min-height:118px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:7px;display:flex;flex-direction:column;gap:5px;}
.cal-cell.empty{background:#FAFAFD;}
.cal-cell.today{background:#F3F0FC;}
.cal-daynum{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--ink);}
.cal-cell.today .cal-daynum a{background:var(--primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.cal-count{font-size:10px;background:#EDEAF6;color:var(--primary);padding:1px 7px;border-radius:20px;font-weight:700;}
.cal-events{display:flex;flex-direction:column;gap:3px;overflow:hidden;}
.cal-pill{display:flex;gap:5px;align-items:center;font-size:11px;padding:3px 6px;background:#F4F2FA;border-left:3px solid var(--primary);border-radius:4px;white-space:nowrap;overflow:hidden;}
.pill-time{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;}
.pill-name{color:var(--muted);overflow:hidden;text-overflow:ellipsis;}
.cal-pill.st-canceled{opacity:.5;text-decoration:line-through;}
.cal-pill.st-done{background:#E9F6EF;}
.cal-pill.st-noshow{background:#FBEDE9;}
.cal-more{font-size:10.5px;color:var(--primary);font-weight:600;}
.cal-block{font-size:10px;color:#9B6A2F;background:#FBF3E6;padding:2px 6px;border-radius:4px;}

/* grade de horários */
.day-summary{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;}
.ds-item{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 20px;display:flex;flex-direction:column;}
.ds-item.add-block{justify-content:center;}
.ds-n{font-size:22px;font-weight:800;color:var(--primary);line-height:1;}
.ds-l{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:5px;}

.timegrid{display:grid;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.tg-corner{background:#F7F5FC;border-bottom:1px solid var(--line);}
.tg-dayhead{padding:10px;text-align:center;background:#F7F5FC;border-bottom:1px solid var(--line);border-left:1px solid var(--line);}
.tg-dayhead.today{background:#F0EBFB;}
.tg-dow{display:block;font-size:11px;text-transform:uppercase;color:var(--muted);font-weight:700;}
.tg-daynum{font-size:15px;color:var(--ink);font-weight:600;}
.tg-time{padding:6px 8px;text-align:right;font-size:11.5px;color:var(--muted);border-bottom:1px solid #F0EEF6;font-variant-numeric:tabular-nums;}
.tg-cell{border-left:1px solid var(--line);border-bottom:1px solid #F0EEF6;min-height:44px;position:relative;padding:2px;}
.tg-cell.closed{background:repeating-linear-gradient(45deg,#FAFAFC,#FAFAFC 6px,#F2F1F7 6px,#F2F1F7 12px);}
.tg-cell.blocked{background:#FBF3E6;}
.tg-add{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:transparent;font-size:18px;font-weight:300;}
.tg-cell:hover .tg-add{color:var(--primary);background:rgba(60,31,143,.05);}
.tg-block{font-size:10.5px;color:#9B6A2F;padding:4px;}
.tg-appt{background:#F4F2FA;border-left:3px solid var(--primary);border-radius:5px;padding:6px 8px;margin-bottom:2px;position:relative;z-index:2;}
.tg-appt-time{font-size:10.5px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;}
.tg-appt-client{font-size:13px;font-weight:600;color:var(--ink);}
.tg-appt-svc{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tg-appt-foot{display:flex;justify-content:space-between;align-items:center;margin-top:5px;gap:6px;}
.tg-appt-actions select{font-size:11px;padding:3px 6px;border-radius:6px;width:auto;}
.badge-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;}
.st-scheduled{background:#EDEAF6;color:#4B3B8F;}
.badge-status.st-scheduled{background:#EDEAF6;color:#4B3B8F;}
.st-confirmed{border-left-color:#2E86C1 !important;}
.badge-status.st-confirmed{background:#E4F0FB;color:#1F6699;}
.badge-status.st-done{background:#E5F6EE;color:#14603E;}
.tg-appt.st-done{background:#E9F6EF;}
.badge-status.st-noshow{background:#FBEDE9;color:#A83E23;}
.tg-appt.st-noshow{background:#FBEDE9;}
.badge-status.st-canceled{background:#EFEFEF;color:#777;}
.tg-appt.st-canceled{opacity:.55;}

/* modal */
.modal{display:none;position:fixed;inset:0;background:rgba(20,15,45,.5);z-index:60;align-items:center;justify-content:center;padding:20px;}
.modal.open{display:flex;}
.modal-box{background:#fff;border-radius:14px;padding:26px;max-width:440px;width:100%;}
.modal-box h3{font-size:18px;margin-bottom:14px;color:var(--ink);}

@media (max-width:820px){
  .cal-cell{min-height:80px;}
  .pill-name{display:none;}
  .timegrid{font-size:12px;overflow-x:auto;}
}
