:root{
  --bg:#0c0a10; --panel:#15121c; --panel-2:#1c1826; --line:#2c2638;
  --ink:#efe9dd; --muted:#a79e8e; --gold:#c9a24b; --gold-hi:#e7c873;
  --err:#e7746a; --ok:#76c08a; --radius:14px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}   /* the hidden attribute must win over form label{display:block} */
html,body{margin:0}
body{
  background:radial-gradient(1200px 600px at 50% -10%,#1a1622 0%,var(--bg) 60%) fixed;
  color:var(--ink);
  font:16px/1.55 system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  min-height:100vh;
}
a{color:var(--gold-hi);text-decoration:none}
a:hover{text-decoration:underline}

/* Top bar */
.pbar{
  display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  padding:.85rem 1.25rem;background:var(--panel);border-bottom:1px solid var(--line);
}
.pbar .brand{font-weight:700;letter-spacing:.04em;color:var(--gold)}
.pbar .brand span{color:var(--muted);font-weight:500}
.pbar nav{display:flex;align-items:center;gap:1.1rem;margin-left:auto;flex-wrap:wrap}
.pbar nav a{color:var(--ink)}
.pbar .who{color:var(--muted);font-size:.9rem}
.pbar .logout{color:var(--gold-hi)}

/* Layout */
.wrap{max-width:1000px;margin:0 auto;padding:1.75rem 1.25rem}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem 1.6rem;margin:0 0 1.25rem;
}
.card h1{margin:.1rem 0 .4rem;font-size:1.5rem;color:var(--gold-hi);letter-spacing:.02em}
.sub{color:var(--muted);margin:.1rem 0 1.1rem}
.muted{color:var(--muted)}

/* Login / narrow forms */
.login{max-width:420px;margin:8vh auto 0}
form label{display:block;margin:0 0 .9rem;font-size:.9rem;color:var(--muted)}
form input,form select,form textarea{
  display:block;width:100%;margin-top:.35rem;padding:.7rem .8rem;
  background:var(--panel-2);border:1px solid var(--line);border-radius:10px;
  color:var(--ink);font:inherit;
}
form input:focus,form select:focus,form textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.18)
}
.btn{
  display:inline-block;cursor:pointer;border:0;border-radius:10px;
  padding:.7rem 1.3rem;font:inherit;font-weight:600;
  background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:#241a05;
}
.btn:hover{filter:brightness(1.06)}
a.btn,a.btn:hover{text-decoration:none}
.btn-sm{padding:.4rem .8rem;font-size:.85rem}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{filter:none;border-color:var(--gold);color:var(--gold-hi)}
.btn-danger{background:transparent;border:1px solid var(--err);color:var(--err)}
.btn-danger:hover{filter:none;background:rgba(231,116,106,.12);border-color:var(--err);color:#f0b3ad}

/* Alerts */
.alert{border-radius:10px;padding:.7rem .9rem;margin:0 0 1rem;font-size:.92rem}
.alert.err{background:rgba(231,116,106,.12);border:1px solid rgba(231,116,106,.4);color:#f0b3ad}
.alert.ok{background:rgba(118,192,138,.12);border:1px solid rgba(118,192,138,.4);color:#bfe6c9}

/* Language switcher (top of the dashboard) */
.lang-switch{display:flex;justify-content:flex-end;margin:0 0 1rem}
.lang-switch label{display:inline-flex;align-items:center;gap:.5rem;margin:0;font-size:.85rem;color:var(--muted)}
.lang-switch select{width:auto;margin:0;padding:.35rem .6rem}

/* Right-to-left tweaks (Arabic). Flex layouts mirror on their own; these fix
   the few places that hard-code a side. */
[dir=rtl] th,[dir=rtl] td{text-align:right}
[dir=rtl] .row-actions{text-align:left}
[dir=rtl] .dash-sub .count{margin-left:0;margin-right:.4rem}

/* Tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:.6rem .65rem;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
tr:hover td{background:rgba(255,255,255,.02)}
.tag{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;padding:.18rem .6rem;border-radius:999px;font-size:.75rem;line-height:1.25;border:1px solid var(--line);color:var(--muted)}
.tag.on{color:var(--ok);border-color:rgba(118,192,138,.4)}
.tag.off{color:var(--muted)}
.tag.blue{color:#74a8e7;border-color:rgba(116,168,231,.45)}

/* Services manager */
.card.narrow{max-width:640px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.card-head h1{margin:0}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}
@media (max-width:560px){.grid2{grid-template-columns:1fr}}
label.check{display:flex;align-items:center;gap:.55rem;color:var(--ink);font-size:.95rem;margin:.2rem 0 1rem}
label.check input{width:auto;margin:0}
/* A bordered group of service checkboxes (work log + voucher bundle). */
fieldset.svc-checks{border:1px solid var(--line);border-radius:10px;padding:.85rem .9rem .35rem;margin:0 0 .9rem}
fieldset.svc-checks legend{padding:0 .4rem;font-size:.9rem;color:var(--muted)}
/* A responsive grid of tidy selectable pill-cards (services + permissions).
   Each highlights gold when ticked; collapses to one column on a phone. */
.svc-checks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}
.svc-checks-grid label.check{
  margin:0;gap:.6rem;padding:.55rem .7rem;border:1px solid var(--line);border-radius:10px;
  background:var(--panel-2);cursor:pointer;font-size:.9rem;line-height:1.25;
  transition:border-color .15s ease,background .15s ease;
}
.svc-checks-grid label.check:hover{border-color:var(--gold)}
.svc-checks-grid label.check:has(input:checked){border-color:var(--gold);background:rgba(201,162,75,.12);color:var(--ink)}
.svc-checks-grid label.check input{accent-color:var(--gold);flex:0 0 auto}
@media (max-width:560px){.svc-checks-grid{grid-template-columns:1fr}}
/* Grouped permission checkboxes on the Staff manage screen. */
fieldset.perm-group{border:1px solid var(--line);border-radius:10px;padding:.6rem .9rem .2rem;margin:0 0 1rem}
fieldset.perm-group legend{padding:0 .4rem;font-size:.85rem;color:var(--gold);letter-spacing:.02em}
.fe{display:block;margin-top:.35rem;color:var(--err);font-size:.82rem}
.actions{display:flex;gap:.7rem;align-items:center;margin-top:.4rem}
/* Keep row-actions a real <td> (no display:flex on the cell, or its border
   collapses and the buttons overflow the row). Right-align inline-block items. */
td.row-actions{text-align:right;vertical-align:middle}
td.row-actions form.inline{display:inline-block}
td.row-actions .btn{margin:.18rem 0 .18rem .45rem}
form.inline{display:inline}

/* Dashboard / bookings */
.dash-controls{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin:.2rem 0 1.2rem}
.dash-controls .jump{margin:0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.dash-controls .jump label{display:flex;align-items:center;gap:.5rem;margin:0;color:var(--muted)}
.dash-controls .jump input{width:auto;margin:0}
.dash-sub{font-size:1.05rem;color:var(--ink);margin:.4rem 0 .8rem;font-weight:600}
.dash-sub .count{display:inline-block;min-width:1.4rem;text-align:center;margin-left:.4rem;padding:.05rem .5rem;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);color:var(--muted);font-size:.8rem;font-weight:500}
.small{font-size:.82rem}
.nowrap{white-space:nowrap}
.tag.bad{color:var(--err);border-color:rgba(231,116,106,.4)}

/* Staff / settings */
.linkbox{background:var(--panel-2);border:1px solid var(--gold);border-radius:10px;padding:.9rem 1rem;margin:0 0 1.2rem}
.linkbox strong{color:var(--gold-hi)}
.linkbox input{margin-top:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem}
.sep{border:0;border-top:1px solid var(--line);margin:1.4rem 0}
.actions.wrap{flex-wrap:wrap}
.hours-table{max-width:520px}
.hours-table input[type=time]{width:auto;margin:0}
.hours-table input[type=checkbox]{width:auto;margin:0}
.hours-table td,.hours-table th{padding:.45rem .6rem}
.closure-add{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.closure-add label{margin:0}
.closure-add input{width:auto}

/* Vouchers */
.voucher-code{margin:.2rem 0 1rem}
.voucher-code code{font-size:1.4rem;font-weight:700;letter-spacing:.06em;color:var(--gold-hi);background:var(--panel-2);border:1px solid var(--gold);border-radius:10px;padding:.45rem .8rem;display:inline-block}
td code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--gold-hi)}
.voucher-issue,.voucher-lookup{margin:0}

/* Add-service clash warning (red, must be impossible to miss) */
.warn-clash{border:1px solid var(--err);background:rgba(231,116,106,.12);color:#f0b3ad;border-radius:10px;padding:.85rem 1rem;margin:0 0 1rem;line-height:1.5}
.warn-clash strong{color:#f5c6c0}

/* Reports / financial overview */
.report-range{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin:0}
.report-range label{margin:0}
.report-range input,.report-range select{width:auto}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.stats{grid-template-columns:1fr}}
.stat{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.25rem}
.stat-k{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.stat-v{font-size:1.7rem;font-weight:700;color:var(--ink);line-height:1.1}
.stat-v.gold{color:var(--gold-hi)}
.stat-v.red{color:var(--err)}
.stat-s{color:var(--muted);font-size:.8rem}
.chart{display:block;max-width:100%;margin:.4rem 0 .2rem}
.chart-axis{stroke:var(--line);stroke-width:1}
.chart-val{fill:var(--ink);font-size:12px;font-family:system-ui,sans-serif}
.chart-lab{fill:var(--muted);font-size:11px;font-family:system-ui,sans-serif}
.chart-seg{fill:#241a05;font-size:12px;font-weight:600;font-family:system-ui,sans-serif}
.oc-table{max-width:520px;margin-top:1rem}
.oc-table td:last-child{text-align:right}
.pl-table tr.pl-sub td{color:var(--gold-hi);border-top:1px solid var(--line)}
.pl-table td.indent{padding-left:1.6rem;border-bottom:0}
.pl-table tr.pl-net td{font-size:1.05rem;border-top:2px solid var(--gold)}
.card-head .stat-v{font-size:1.6rem}

/* Slot picker (phone-in / reschedule) */
.slotpicker .slotgrid{display:flex;flex-wrap:wrap;gap:.5rem;min-height:2.4rem;align-content:flex-start;margin:.2rem 0 1rem}
.slotpicker .bk-hint{margin:.4rem 0}
.slot{width:auto;cursor:pointer;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;color:var(--ink);padding:.5rem .8rem;font:inherit;font-size:.9rem}
.slot:hover{border-color:var(--gold);color:var(--gold-hi)}
.slot.is-on{background:linear-gradient(180deg,var(--gold-hi),var(--gold));border-color:var(--gold-hi);color:#241a05;font-weight:600}
.jump .go{margin:0}
