:root{
  --pink:#e0359a; --pink-d:#c2185b; --purple:#7b2ff7; --purple-d:#5b1fb0;
  --grad:linear-gradient(135deg,#7b2ff7 0%,#e0359a 100%);
  --grad-soft:linear-gradient(135deg,#f7e9ff 0%,#ffe9f5 100%);
  --bg:#f7f3fb; --card:#ffffff; --ink:#2c2340; --muted:#8b7f9c;
  --line:#efe6f6; --ok:#2bb673; --warn:#f3a712; --danger:#e5484d;
  --shadow:0 4px 18px rgba(123,47,247,.08); --shadow-lg:0 10px 40px rgba(123,47,247,.16);
  --r:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);font-size:15px}
a{text-decoration:none;color:inherit}

/* ---------- Layout ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{width:250px;background:var(--grad);color:#fff;display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;z-index:40;transition:transform .25s}
.brand{display:flex;align-items:center;gap:12px;padding:22px 20px}
.brand-logo{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.2);
  display:grid;place-items:center;font-size:22px;backdrop-filter:blur(4px)}
.brand-text{display:flex;flex-direction:column;line-height:1.25}
.brand-text strong{font-size:16px}
.brand-text span{font-size:11px;opacity:.8;letter-spacing:.5px;text-transform:uppercase}
.nav{display:flex;flex-direction:column;gap:4px;padding:10px 12px;flex:1}
.nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;
  color:rgba(255,255,255,.86);font-weight:500;transition:.15s}
.nav a i{font-style:normal;font-size:18px;width:22px;text-align:center}
.nav a:hover{background:rgba(255,255,255,.14);color:#fff}
.nav a.on{background:#fff;color:var(--purple-d);box-shadow:var(--shadow)}
.sidebar-foot{padding:16px}
.sms-badge{font-size:11px;padding:8px 10px;border-radius:10px;text-align:center;font-weight:600}
.sms-badge.ok{background:rgba(43,182,115,.25)}
.sms-badge.sim{background:rgba(255,255,255,.16)}

.main{flex:1;margin-left:250px;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;padding:16px 28px;background:#fff;
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar h1{font-size:20px;font-weight:700}
.topbar-right{margin-left:auto;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.hamburger{display:none;font-size:22px;background:none;border:none;cursor:pointer;color:var(--purple-d)}
.content{padding:26px 28px 60px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;border-radius:11px;border:none;
  cursor:pointer;font-weight:600;font-size:14px;transition:.15s;font-family:inherit}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{filter:brightness(1.06);box-shadow:var(--shadow-lg)}
.btn-ghost{background:#f3ecfa;color:var(--purple-d)}
.btn-ghost:hover{background:#e9dcf7}
.btn-danger{background:#fdecec;color:var(--danger)}
.btn-danger:hover{background:#fbdcdc}
.btn-sm{padding:7px 11px;font-size:12.5px;border-radius:9px}
.btn-icon{background:none;border:none;cursor:pointer;font-size:16px;padding:6px;border-radius:8px;color:var(--muted)}
.btn-icon:hover{background:var(--line);color:var(--ink)}

/* ---------- Cards / stats ---------- */
.grid{display:grid;gap:18px}
.stats{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}
.stat{background:var(--card);border-radius:var(--r);padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.stat .ico{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:var(--grad-soft);margin-bottom:12px}
.stat .label{font-size:12.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.stat .value{font-size:28px;font-weight:800;margin-top:4px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .sub{font-size:12px;color:var(--muted);margin-top:4px}
.stat.plain .value{-webkit-text-fill-color:var(--ink);background:none}

.card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);padding:22px}
.card h2,.card h3{font-size:16px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.card h2 .count{font-size:12px;color:var(--muted);font-weight:500}
.cols{display:grid;gap:18px}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:2fr 1fr}

/* ---------- Table ---------- */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 12px;font-size:14px}
thead th{font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:2px solid var(--line);font-weight:700}
tbody tr{border-bottom:1px solid var(--line)}
tbody tr:hover{background:#faf6fe}
td .muted{color:var(--muted);font-size:12.5px}
.table-wrap{overflow-x:auto}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}
.badge.confirmat{background:#e3f7ee;color:#1d8a56}
.badge.asteptare{background:#fff3d6;color:#b8860b}
.badge.anulat{background:#fdecec;color:var(--danger)}
.badge.cash{background:#e8f5e9;color:#2e7d32}
.badge.card{background:#e7ecff;color:#3452d1}
.badge.soft{background:var(--grad-soft);color:var(--purple-d)}
.code-pill{font-family:monospace;background:var(--grad-soft);color:var(--purple-d);padding:3px 9px;border-radius:8px;font-weight:700;font-size:12.5px}

/* ---------- Forms ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);
  border-radius:11px;font-size:14px;font-family:inherit;background:#fdfbff;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--pink);background:#fff}
.field textarea{resize:vertical;min-height:70px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.searchbar{display:flex;gap:10px;align-items:center}
.searchbar input{padding:10px 14px;border:1.5px solid var(--line);border-radius:11px;background:#fff;min-width:220px}

/* ---------- Modal ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(44,35,64,.5);backdrop-filter:blur(3px);
  display:none;align-items:flex-start;justify-content:center;z-index:60;padding:40px 16px;overflow-y:auto}
.modal-backdrop.show{display:flex}
.modal{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);width:100%;max-width:520px;
  padding:26px;animation:pop .2s}
@keyframes pop{from{transform:scale(.96) translateY(8px);opacity:0}to{transform:none;opacity:1}}
.modal h3{font-size:18px;margin-bottom:18px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);
  background:var(--ink);color:#fff;padding:13px 22px;border-radius:12px;font-weight:600;
  box-shadow:var(--shadow-lg);z-index:80;transition:transform .3s;font-size:14px}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--danger)}

/* ---------- Charts ---------- */
.chart{width:100%}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:180px;padding-top:10px}
.bar-chart .bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.bar-chart .bar{width:100%;max-width:38px;background:var(--grad);border-radius:8px 8px 4px 4px;transition:height .5s;min-height:3px}
.bar-chart .bl{font-size:10.5px;color:var(--muted)}
.bar-chart .bv{font-size:10px;color:var(--ink);font-weight:700}
.legend{display:flex;flex-direction:column;gap:10px}
.legend .row{display:flex;align-items:center;gap:10px;font-size:13.5px}
.legend .dot{width:12px;height:12px;border-radius:4px;flex:none}
.legend .val{margin-left:auto;font-weight:700}
.progress{height:8px;background:var(--line);border-radius:6px;overflow:hidden;margin-top:6px}
.progress span{display:block;height:100%;background:var(--grad);border-radius:6px}

/* barcode */
.barcode-wrap{text-align:center;padding:16px;background:#fff;border:1px solid var(--line);border-radius:12px}
.barcode-wrap canvas{max-width:100%}
.barcode-wrap .code{font-family:monospace;letter-spacing:3px;font-weight:700;margin-top:6px;color:var(--ink)}

.empty{text-align:center;color:var(--muted);padding:40px 20px}
.empty .big{font-size:40px;margin-bottom:8px}
.page-head{display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.page-head .spacer{flex:1}
.back-link{color:var(--muted);font-size:13px}
.back-link:hover{color:var(--pink)}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:700;flex:none}
.list-row{display:flex;align-items:center;gap:12px}

/* ---------- Calendar ---------- */
.cal-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.cal-head .m{font-size:17px;font-weight:700;min-width:180px;text-align:center}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.calendar .dow{text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;padding:6px 0}
.calendar .day{background:#fff;border:1.5px solid var(--line);border-radius:10px;min-height:74px;padding:6px;cursor:pointer;transition:.12s;position:relative}
.calendar .day:hover{border-color:var(--pink)}
.calendar .day.other{opacity:.4}
.calendar .day.today{border-color:var(--purple);box-shadow:0 0 0 2px rgba(123,47,247,.15)}
.calendar .day.sel{background:var(--grad-soft);border-color:var(--pink)}
.calendar .day .dnum{font-size:12.5px;font-weight:700}
.calendar .day .cnt{position:absolute;bottom:6px;right:6px;background:var(--grad);color:#fff;font-size:10px;
  font-weight:700;padding:2px 7px;border-radius:20px}
.agenda-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;border:1px solid var(--line);margin-bottom:10px}
.agenda-item .time{font-weight:800;color:var(--purple-d);min-width:52px}
.agenda-item .who{flex:1}
.agenda-item .who b{display:block}
.agenda-item .who span{font-size:12.5px;color:var(--muted)}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .cols-2,.cols-3{grid-template-columns:1fr}
}
@media(max-width:820px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:none;box-shadow:var(--shadow-lg)}
  .main{margin-left:0}
  .hamburger{display:block}
  .content{padding:18px 16px 50px}
  .topbar{padding:14px 16px}
}

/* ---------- User chip / logout ---------- */
.avatar.sm{width:32px;height:32px;font-size:13px}
.user-chip{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.14);padding:8px 10px;border-radius:12px}
.user-meta{display:flex;flex-direction:column;line-height:1.2;flex:1;min-width:0}
.user-meta b{font-size:13px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-meta span{font-size:11px;opacity:.8}
.user-chip .btn-icon{color:#fff}
.user-chip .btn-icon:hover{background:rgba(255,255,255,.2)}

/* ---------- Install banner ---------- */
.install-banner{position:fixed;left:50%;bottom:20px;transform:translateX(-50%) translateY(160px);
  display:flex;align-items:center;gap:12px;background:#fff;padding:12px 14px;border-radius:16px;
  box-shadow:var(--shadow-lg);z-index:70;max-width:calc(100vw - 28px);transition:transform .35s}
.install-banner.show{transform:translateX(-50%) translateY(0)}
.install-banner .ib-icon{width:40px;height:40px;border-radius:11px;background:var(--grad);color:#fff;
  display:grid;place-items:center;font-size:20px;flex:none}
.install-banner .ib-text{display:flex;flex-direction:column;line-height:1.25}
.install-banner .ib-text b{font-size:14px}
.install-banner .ib-text span{font-size:12px;color:var(--muted)}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--grad);padding:20px}
.login-card{background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);padding:36px 32px;width:100%;max-width:400px}
.login-card .logo{width:64px;height:64px;border-radius:18px;background:var(--grad);color:#fff;
  display:grid;place-items:center;font-size:32px;margin:0 auto 16px}
.login-card h1{text-align:center;font-size:22px}
.login-card .sub{text-align:center;color:var(--muted);font-size:13.5px;margin:6px 0 22px}
.login-card .btn{width:100%;justify-content:center;margin-top:6px}
.login-err{background:#fdecec;color:var(--danger);padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:14px;text-align:center}
.login-hint{margin-top:18px;padding:12px;background:var(--grad-soft);border-radius:12px;font-size:12px;color:var(--purple-d);line-height:1.6}

/* ---------- Portal angajate ---------- */
.portal-hero{background:var(--grad);color:#fff;border-radius:var(--r);padding:22px;margin-bottom:18px}
.portal-hero .live{display:inline-flex;align-items:center;gap:6px;font-size:11px;background:rgba(255,255,255,.2);padding:4px 10px;border-radius:20px}
.portal-hero .live .dot{width:8px;height:8px;border-radius:50%;background:#7CFFB2;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.ro-note{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);background:#f3ecfa;padding:5px 10px;border-radius:8px}

/* ---------- Calendar (week/day grid) ---------- */
.cal-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.cal-toolbar .title{font-size:17px;font-weight:800;min-width:150px}
.seg{display:inline-flex;background:#f0e9f8;border-radius:10px;padding:3px}
.seg button{border:none;background:none;padding:7px 14px;border-radius:8px;cursor:pointer;font-weight:600;font-size:13px;color:var(--muted)}
.seg button.on{background:#fff;color:var(--purple-d);box-shadow:var(--shadow)}
.calgrid-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:#fff}
.calgrid{display:grid;min-width:680px;position:relative}
.calgrid .corner{position:sticky;left:0;background:#fff;z-index:3;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.calgrid .colhead{padding:8px 6px;text-align:center;border-bottom:1px solid var(--line);font-size:12px;position:sticky;top:0;background:#fff;z-index:2}
.calgrid .colhead b{display:block;font-size:14px}
.calgrid .colhead.today{color:var(--pink)}
.calgrid .colhead .badge{margin-top:3px}
.calgrid .timecol{position:sticky;left:0;background:#fff;z-index:1;border-right:1px solid var(--line)}
.calgrid .timecell{height:56px;font-size:11px;color:var(--muted);text-align:right;padding:2px 8px;transform:translateY(-7px)}
.calgrid .daycol{position:relative;border-right:1px solid var(--line)}
.calgrid .slot{height:56px;border-bottom:1px dashed #f0eaf6;cursor:pointer;transition:background .1s}
.calgrid .slot:hover{background:#faf4ff}
.ev{position:absolute;left:3px;right:3px;border-radius:8px;padding:4px 7px;font-size:11.5px;color:#fff;
  overflow:hidden;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.12);border-left:3px solid rgba(255,255,255,.6)}
.ev b{display:block;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev small{opacity:.9;font-size:10.5px}
.ev.anulat{opacity:.5;text-decoration:line-through}
.ev.asteptare{background:#f3a712}
.ev.confirmat{background:linear-gradient(135deg,#7b2ff7,#e0359a)}
.cal-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;font-size:12.5px;color:var(--muted)}
.cal-legend .row{display:flex;align-items:center;gap:6px}
.cal-legend .sw{width:14px;height:14px;border-radius:4px}

/* ---------- Responsive fine-tuning telefon ---------- */
@media(max-width:820px){
  .stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stat{padding:16px}
  .stat .value{font-size:23px}
  .stat .ico{width:38px;height:38px;font-size:19px;margin-bottom:8px}
  .portal-hero{padding:18px}
  .install-banner{left:12px;right:12px;transform:translateX(0) translateY(160px)}
  .install-banner.show{transform:translateX(0) translateY(0)}
  .topbar-right .btn{padding:9px 12px;font-size:13px}
}
@media(max-width:400px){
  .stats{grid-template-columns:1fr}
}

/* ---------- Fix overflow orizontal pe telefon ---------- */
html,body{overflow-x:hidden;max-width:100%}
.main{overflow-x:hidden}
.ro-note{white-space:normal}
@media(max-width:820px){
  .topbar{flex-wrap:wrap;row-gap:8px;padding:12px 16px}
  .topbar h1{font-size:17px;min-width:0}
  .topbar-right{width:100%;margin-left:0}
  .content{padding:16px 14px 70px}
}

/* safety lățime */
.stat,.card,.portal-hero{max-width:100%}
.portal-hero>div{max-width:100%;flex-wrap:wrap}

/* ---------- Taburi principale ---------- */
.tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.tab{border:none;background:#f0e9f8;color:var(--muted);padding:11px 20px;border-radius:12px;font-weight:700;
  font-size:14px;cursor:pointer;font-family:inherit;transition:.15s}
.tab.on{background:var(--grad);color:#fff;box-shadow:var(--shadow)}

/* ---------- Wizard ---------- */
.wiz-steps{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.wiz-step{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:12px;background:#f3ecfa;
  color:var(--muted);font-weight:600;font-size:13px}
.wiz-step span{width:22px;height:22px;border-radius:50%;background:#fff;display:grid;place-items:center;font-size:12px;font-weight:800}
.wiz-step.on{background:var(--grad);color:#fff}
.wiz-step.on span{color:var(--purple-d)}
.wiz-step.done{background:#e3f7ee;color:#1d8a56}
.wiz-step.done span{background:#1d8a56;color:#fff}
.slot-pick{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-top:14px;padding:14px 16px;background:var(--grad-soft);border-radius:12px;border:1px solid var(--gold,#e4d8c8)}
.recap{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}

/* sloturi clicabile (wizard) */
.calgrid .slot.pick:hover{background:#f0e3ff}
.calgrid .slot.sel{background:var(--grad-soft);box-shadow:inset 0 0 0 2px var(--pink)}

/* ---------- Istoric client (jurnal tehnic) ---------- */
.hist-entry{border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:10px}
.hist-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.hist-chips{display:flex;gap:6px;flex-wrap:wrap}
.hist-chip{background:var(--grad-soft);color:var(--purple-d);padding:4px 10px;border-radius:8px;font-size:12.5px;font-weight:600}
.hist-notes{margin-top:8px;font-size:13px;color:var(--ink);background:#faf6fe;padding:8px 10px;border-radius:8px}

/* variabile în Setări */
.var{display:inline-block;font-family:monospace;background:var(--grad-soft);color:var(--purple-d);
  padding:2px 7px;border-radius:6px;font-size:12px;font-weight:700;margin:0 2px}

/* carduri dashboard clicabile */
.stat.clickable{cursor:pointer;transition:.15s}
.stat.clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.stat.clickable .sub{color:var(--pink);font-weight:600}

/* ---------- Checklist servicii (angajate) ---------- */
.svc-check{border:1.5px solid var(--line);border-radius:12px;padding:10px 12px;max-height:230px;overflow-y:auto;background:#fdfbff}
.svc-cat{margin-bottom:8px}
.svc-cat-h{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.4px;margin:6px 0 4px}
.svc-all{font-size:11px;color:var(--pink);text-transform:none;letter-spacing:0}
.svc-item{display:flex;align-items:center;gap:8px;font-size:13.5px;padding:4px 2px;cursor:pointer}
.svc-item input{width:auto;margin:0}

/* ---------- Butoane mari Programări ---------- */
.big-tabs{display:flex;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.big-tab{flex:1;min-width:200px;display:flex;align-items:center;justify-content:center;gap:12px;
  border:2px solid var(--line);background:#fff;color:var(--muted);padding:22px;border-radius:18px;
  font-weight:800;font-size:18px;cursor:pointer;font-family:inherit;transition:.15s}
.big-tab .bt-ic{font-size:26px}
.big-tab:hover{border-color:var(--pink);color:var(--ink)}
.big-tab.on{background:var(--grad);color:#fff;border-color:transparent;box-shadow:var(--shadow-lg)}

.wiz-head{display:flex;align-items:center;justify-content:space-between;gap:10px}

/* ---------- Grile de selecție (serviciu / angajată) ---------- */
.pick-cat{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;margin:14px 0 8px}
.pick-cat:first-child{margin-top:0}
.pick-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}
.pick-card{border:1.5px solid var(--line);border-radius:14px;padding:16px;cursor:pointer;transition:.15s;background:#fff}
.pick-card:hover{border-color:var(--pink);box-shadow:var(--shadow);transform:translateY(-2px)}
.pick-card b{display:block;font-size:15px}
.pick-card span{font-size:12.5px;color:var(--muted)}
.pick-card.emp{display:flex;align-items:center;gap:12px}
.pick-card.emp .avatar{color:#fff}

/* ---------- Roți dată & oră (stil iPhone) ---------- */
.dt-layout{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.wheels{position:relative;display:flex;gap:2px;justify-content:center;align-items:center;
  background:#fff;border:1.5px solid var(--line);border-radius:18px;padding:0 14px}
.wheel{height:200px;overflow-y:scroll;scroll-snap-type:y mandatory;scrollbar-width:none;text-align:center;min-width:58px}
.wheel::-webkit-scrollbar{display:none}
.wheel-pad{height:80px}
.wheel-item{height:40px;line-height:40px;scroll-snap-align:center;font-size:16px;color:var(--muted);
  transition:color .1s,font-size .1s;white-space:nowrap}
.wheel-item.sel{color:var(--purple-d);font-weight:800;font-size:19px}
#wheelDay{min-width:118px}
.wheel-sep{min-width:8px;font-size:22px;font-weight:800;color:var(--ink);overflow:visible;height:auto}
.wheel-band{position:absolute;top:80px;left:8px;right:8px;height:40px;border-radius:10px;pointer-events:none;
  background:rgba(224,53,154,.07);box-shadow:inset 0 0 0 2px rgba(224,53,154,.35)}

.day-busy{background:#faf6fe;border:1px solid var(--line);border-radius:14px;padding:14px;min-height:200px}
.busy-item{display:flex;flex-direction:column;padding:8px 10px;border-radius:10px;background:#fff;
  border:1px solid var(--line);margin-bottom:8px}
.busy-item b{font-size:13.5px;color:var(--purple-d)}
.busy-item span{font-size:12.5px;color:var(--muted)}

@media(max-width:760px){ .dt-layout{grid-template-columns:1fr} }

/* ---------- Căutare client (pas 4) ---------- */
.cli-results{margin:8px 0 4px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.cli-results:empty{display:none}
.cli-row{display:flex;align-items:center;gap:10px;padding:11px 12px;cursor:pointer;border-bottom:1px solid var(--line);transition:.1s}
.cli-row:last-child{border-bottom:none}
.cli-row:hover{background:#faf4ff}
.cli-row .avatar.sm{background:var(--grad-soft);color:var(--purple-d)}
.cli-row.cli-new{background:#fdf6ff}
.cli-row.cli-new b{color:var(--purple-d)}
.cli-chosen{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;
  background:var(--grad-soft);border-radius:12px;margin:8px 0;font-size:14.5px}

/* ---------- Formular GDPR ---------- */
.gdpr-check{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-top:1px solid var(--line);font-size:13.5px;line-height:1.5;cursor:pointer}
.gdpr-check input{width:auto;margin-top:3px;flex:none;transform:scale(1.2)}
.gdpr-check i{color:var(--muted);font-size:12px}
.sign-wrap{position:relative;margin-top:6px}
.sign-wrap canvas{width:100%;height:160px;border:1.5px dashed var(--line);border-radius:12px;background:#fff;touch-action:none;display:block}
.sign-wrap .btn{position:absolute;top:8px;right:8px}
