:root{--bg:#f7f9fc;--bg2:#f2f7f3;--card:#ffffff;--muted:#60708a;--text:#122033;--line:rgba(18,32,51,.10);--primary:#2f7ef7;--primary2:#12b5a3;--accent:#ff7a59;--gold:#f6c445;--shadow:0 14px 40px rgba(18,32,51,.10);--radius:18px}
*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto;color:var(--text);background:linear-gradient(180deg,var(--bg),var(--bg2) 65%, #ffffff)}
.bg{min-height:100vh;display:grid;place-items:center;padding:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.auth .card{width:min(440px,92vw);padding:26px}
h1{margin:0 0 6px 0;font-size:28px}.muted{color:var(--muted);margin:0}
.form{display:grid;gap:10px;margin-top:14px}label{font-size:12px;color:var(--muted)}
input,select,textarea{width:100%;padding:12px;border-radius:14px;border:1px solid var(--line);background:#fbfdff;color:var(--text);outline:none}
.btn{border:1px solid var(--line);background:#ffffff;color:var(--text);padding:10px 12px;border-radius:14px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 6px 18px rgba(18,32,51,.06)}
.btn.primary{background:linear-gradient(90deg,var(--primary),var(--primary2));border:none;color:white}
.btn.small{padding:7px 10px;border-radius:12px;font-size:13px}.btn.danger{border-color:rgba(255,120,120,.25);background:rgba(255,120,120,.08)}
.topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.85);backdrop-filter:saturate(140%) blur(10px)}
.brand{font-weight:800}.right{display:flex;gap:10px;align-items:center}.pill{padding:8px 10px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:12px}
.layout{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 64px)}
.sidebar{border-right:1px solid var(--line);padding:12px;position:sticky;top:64px;height:calc(100vh - 64px);overflow:auto;background:rgba(255,255,255,.65)}
.nav{width:100%;text-align:left;padding:12px;border-radius:14px;border:1px solid transparent;background:transparent;color:var(--text);cursor:pointer;margin-bottom:6px}
.nav.active{border-color:rgba(110,168,255,.35);background:rgba(110,168,255,.08)}
.content{padding:16px}.hidden{display:none !important}
.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;vertical-align:top}
.table th{color:var(--muted);font-weight:700;font-size:12px}
.toast{position:fixed;right:16px;bottom:16px;max-width:min(520px,92vw);background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow)}
.toast.ok{border-color:rgba(120,255,180,.25)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:grid;place-items:center;padding:18px}
.modal-card{width:min(860px,96vw);background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px;border-bottom:1px solid var(--line)}
.icon{background:transparent;border:0;color:var(--muted);cursor:pointer;font-size:18px}

/* util */
.row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.chipcard{padding:10px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.03);margin-bottom:8px}
.cardhead{padding:14px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.actions{display:flex;justify-content:flex-end;margin-top:12px;gap:10px}

/* calendar */
.cal{display:grid;gap:12px}
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.cal-title{font-weight:900;font-size:18px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal-dow{color:var(--muted);font-size:12px;text-align:center}
.cal-day{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.03);padding:10px;min-height:74px;cursor:pointer;position:relative}
.cal-day:hover{border-color:rgba(110,168,255,.35)}
.cal-day.muted{opacity:.5}
.cal-num{font-weight:800;font-size:13px}
.cal-badge{position:absolute;right:10px;top:10px;font-size:11px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:2px 8px;background:rgba(0,0,0,.18)}
.cal-list{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}

.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

/* colored buttons */
.btn.accent{background:linear-gradient(90deg,var(--accent),#ffb86b);border:none;color:#1b1b1b}
.btn.success{background:linear-gradient(90deg,#22c55e,#16a34a);border:none;color:white}
.btn.warning{background:linear-gradient(90deg,var(--gold),#ffea86);border:none;color:#2a2200}
.btn.info{background:linear-gradient(90deg,#38bdf8,#6366f1);border:none;color:white}

#modalBody{max-height:72vh;overflow:auto}

/* Google Calendar-ish */
.cal-grid{gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--card)}
.cal-dow{padding:10px 0;background:rgba(47,126,247,.06);border-bottom:1px solid var(--line)}
.cal-day{border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:0;background:transparent;padding:8px 8px 10px;min-height:96px}
.cal-day:nth-child(7n){border-right:0}
.cal-day:hover{background:rgba(47,126,247,.06)}
.cal-day.today{background:rgba(47,126,247,.10)}
.cal-num{font-weight:800;font-size:12px;color:var(--muted)}
.cal-badge{right:8px;top:8px;background:rgba(18,32,51,.04);border:1px solid var(--line);color:var(--muted)}
.cal-eventchip{margin-top:6px;padding:6px 8px;border-radius:10px;background:rgba(18,32,51,.04);border:1px solid var(--line);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Calendar (Google-ish) - actual classes used by JS */
.calendar{display:grid;gap:10px}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid var(--line);border-radius:16px 16px 0 0;overflow:hidden;background:var(--card)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid var(--line);border-top:0;border-radius:0 0 16px 16px;overflow:hidden;background:var(--card)}
.cal-dow{padding:10px 0;background:rgba(47,126,247,.06);border-right:1px solid var(--line);text-align:center;color:var(--muted);font-size:12px}
.cal-dow:nth-child(7n){border-right:0}
.cal-cell{appearance:none;border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:transparent;padding:8px 8px 10px;min-height:96px;text-align:left;cursor:pointer}
.cal-cell:nth-child(7n){border-right:0}
.cal-cell:hover{background:rgba(47,126,247,.06)}
.cal-cell.other{background:rgba(18,32,51,.02);color:rgba(18,32,51,.55)}
.cal-cell.today{background:rgba(47,126,247,.10)}
.cal-cell.selected{outline:2px solid rgba(47,126,247,.35);outline-offset:-2px}
.cal-num{font-weight:800;font-size:12px;color:var(--muted)}
.cal-dots{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.dot{width:8px;height:8px;border-radius:999px;background:var(--primary)}
.dot.done{background:#22c55e}
.dot.cancel{background:#ef4444}
.dot.pending{background:#f59e0b}
.appt{padding:10px;border:1px solid var(--line);border-radius:14px;background:var(--card);margin-bottom:8px}

.dot.programada{background:#2f7ef7}
.dot.en_sala{background:#f59e0b}
.dot.atendida{background:#22c55e}
.dot.cancelada,.dot.no_show{background:#ef4444}
