/* Slotly — clean booking UI (Ownware teal brand) */
:root{
  --accent:#0f766e; --accent-dark:#0b544e; --accent-soft:#e6f2f0;
  --ink:#111827; --sub:#5b6470; --line:#e5e7eb; --bg:#f6f7f9; --card:#fff;
  --ok:#15803d; --okbg:#dcfce7; --warn:#b45309; --warnbg:#fef3c7;
  --bad:#b91c1c; --badbg:#fee2e2; --blue:#1d4ed8; --bluebg:#e0e7ff;
  --radius:12px; --shadow:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
h1{font-size:1.5rem;margin:0 0 4px;letter-spacing:-.01em} h2{font-size:1.1rem;margin:0 0 12px}
.muted{color:var(--sub)} .small{font-size:.85rem} .center{text-align:center}
.num{text-align:right;font-variant-numeric:tabular-nums}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border:none;
  padding:10px 18px;border-radius:9px;font:inherit;font-weight:600;cursor:pointer;box-shadow:var(--shadow);transition:.12s}
.btn:hover{background:var(--accent-dark);text-decoration:none} .btn:disabled{opacity:.5;cursor:not-allowed}
.btn.sm{padding:6px 12px;font-size:.85rem} .btn.lg{padding:13px 24px;font-size:1.02rem}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none} .btn.ghost:hover{background:#f8fafc}
.btn.danger{background:#fff;color:var(--bad);border:1px solid #f3d3d3;box-shadow:none} .btn.danger:hover{background:#fef2f2}
.btn.block{width:100%;justify-content:center}

/* forms */
label{display:block;font-size:.85rem;font-weight:600;color:#374151;margin:0 0 5px}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field{margin-bottom:14px} .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:640px){.row{grid-template-columns:1fr}}

/* cards + pills + alerts */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.76rem;font-weight:700;text-transform:capitalize}
.pill.confirmed,.pill.paid,.pill.completed{background:var(--okbg);color:var(--ok)}
.pill.pending,.pill.deposit{background:var(--warnbg);color:var(--warn)}
.pill.cancelled,.pill.no_show,.pill.unpaid{background:var(--badbg);color:var(--bad)}
.alert{padding:11px 15px;border-radius:9px;margin-bottom:14px;font-size:.92rem}
.alert.ok{background:var(--okbg);color:#065f46;border:1px solid #a7f3d0}
.alert.err{background:var(--badbg);color:#991b1b;border:1px solid #fecaca}

/* ---------- public booking ---------- */
.pub-wrap{max-width:900px;margin:0 auto;padding:26px 20px 60px}
.pub-head{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.pub-logo{height:44px} .pub-brand{font-size:1.5rem;font-weight:800;letter-spacing:-.01em}
.steps{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}
.step{flex:1;min-width:120px;padding:10px 14px;border-radius:10px;background:#fff;border:1px solid var(--line);font-size:.82rem;font-weight:600;color:var(--sub);display:flex;gap:8px;align-items:center}
.step .n{width:22px;height:22px;border-radius:50%;background:var(--bg);display:grid;place-items:center;font-size:.78rem;color:var(--sub)}
.step.on{border-color:var(--accent);color:var(--accent)} .step.on .n{background:var(--accent);color:#fff}
.step.done .n{background:var(--ok);color:#fff}
.panel{margin-top:4px}
.svc-cat{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);font-weight:700;margin:18px 0 10px}
.svc{display:flex;justify-content:space-between;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:10px;cursor:pointer;transition:.12s}
.svc:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.svc .svc-name{font-weight:700} .svc .svc-meta{color:var(--sub);font-size:.86rem;margin-top:3px}
.svc .svc-price{font-weight:700;white-space:nowrap}
.staff-grid,.date-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.staff{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center;cursor:pointer}
.staff:hover,.staff.sel{border-color:var(--accent)} .staff .av{width:46px;height:46px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:800;margin:0 auto 8px;font-size:1.1rem}
.cal{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{text-align:center;font-size:.72rem;color:var(--sub);font-weight:700;padding:4px 0}
.cal-day{aspect-ratio:1;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer;font-weight:600;color:var(--ink);display:grid;place-items:center}
.cal-day:hover:not(:disabled){border-color:var(--accent)} .cal-day.sel{background:var(--accent);color:#fff;border-color:var(--accent)}
.cal-day:disabled{color:#cbd0d6;background:#fafbfc;cursor:not-allowed}
.cal-day.empty{border:none;background:none;cursor:default}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;margin-top:16px}
.slot{padding:10px;border:1px solid var(--line);border-radius:9px;background:#fff;text-align:center;font-weight:600;cursor:pointer}
.slot:hover,.slot.sel{border-color:var(--accent);color:var(--accent)}
.summary{background:var(--accent-soft);border-radius:10px;padding:16px;margin-bottom:18px}
.summary .r{display:flex;justify-content:space-between;padding:4px 0}
.summary .r.total{border-top:1px solid #cfe3df;margin-top:6px;padding-top:8px;font-weight:800}
.wiz-actions{display:flex;justify-content:space-between;margin-top:22px;gap:10px}
.big-ok{width:66px;height:66px;border-radius:50%;background:var(--okbg);color:var(--ok);display:grid;place-items:center;font-size:2rem;margin:0 auto 14px}

/* ---------- admin ---------- */
.app{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.side{background:#0f172a;color:#c7cdd9;display:flex;flex-direction:column;padding:16px 12px;position:sticky;top:0;height:100vh}
.side .brand{font-size:1.15rem;font-weight:800;color:#fff;margin:6px 8px 20px;display:flex;align-items:center;gap:8px}
.side .brand .dot{width:16px;height:16px;border-radius:5px;background:var(--accent);transform:rotate(45deg)}
.side nav{display:flex;flex-direction:column;gap:2px}
.side nav a{color:#aab2c5;padding:9px 12px;border-radius:8px;display:flex;gap:10px;align-items:center;font-weight:500}
.side nav a:hover{background:#1e293b;color:#fff;text-decoration:none} .side nav a.on{background:var(--accent);color:#fff}
.side .foot{margin-top:auto;border-top:1px solid #243040;padding-top:10px}
.main{padding:26px 30px;max-width:1180px}
.topbar{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
@media(max-width:820px){.app{grid-template-columns:1fr}.side{position:static;height:auto}.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow)}
.kpi .l{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--sub);font-weight:700}
.kpi .v{font-size:1.7rem;font-weight:800;margin-top:5px} .kpi.a .v{color:var(--accent)} .kpi.b .v{color:var(--bad)}
table{width:100%;border-collapse:collapse;background:#fff}
th{text-align:left;font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;color:var(--sub);font-weight:700;padding:10px 12px;border-bottom:1px solid var(--line)}
td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:last-child td{border-bottom:none} tbody tr:hover{background:#fafbfc}
.tbl{border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.tabs a{padding:7px 14px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--sub);font-weight:600;font-size:.88rem}
.tabs a.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.empty{text-align:center;color:var(--sub);padding:44px 20px}
.week{display:grid;grid-template-columns:60px repeat(7,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;font-size:.8rem}
.week .hcell{border-bottom:1px solid var(--line);border-left:1px solid var(--line);padding:8px;text-align:center;font-weight:700;color:var(--sub)}
.week .tcell{border-bottom:1px solid #f1f2f4;border-left:1px solid #f1f2f4;min-height:34px;padding:2px}
.week .tlabel{padding:2px 6px;color:var(--sub);text-align:right;border-bottom:1px solid #f1f2f4}
.ev{background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:5px;padding:3px 6px;margin:2px 0;font-size:.74rem;line-height:1.25}
.flex{display:flex;gap:10px;align-items:center} .between{justify-content:space-between} .wrap{flex-wrap:wrap}
.hours-row{display:grid;grid-template-columns:110px 1fr 1fr auto;gap:8px;align-items:center;margin-bottom:6px}
