:root{
  --brand:#B026E0; --brand-dark:#1A0626; --bg:#f5f3f7; --card:#fff;
  --line:#e7e0ee; --text:#1A0626; --muted:#7a6a85; --ok:#1f9d55; --warn:#b8860b;
  --radius:14px; --shadow:0 6px 24px rgba(26,6,38,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:15px;line-height:1.45}
a{color:var(--brand);text-decoration:none}
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 16px;background:linear-gradient(135deg,#1A0626,#B026E0);color:#fff;box-shadow:var(--shadow)}
.topbar a{color:#fff}
.topbar .brand{font-weight:800;font-size:18px;letter-spacing:.2px}
.topbar nav{display:flex;gap:14px;align-items:center;font-size:14px}
.wrap{max-width:980px;margin:0 auto;padding:18px 16px 60px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px;margin-bottom:16px}
.card h2{margin:0 0 12px;font-size:17px}
.card h3{margin:18px 0 8px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
h1{font-size:22px;margin:6px 0 18px}
label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}
input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;
  font:inherit;background:#fff;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(176,38,224,.12)}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:140px}
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;cursor:pointer;border:none;
  background:var(--brand);color:#fff;font-weight:700;padding:12px 18px;border-radius:100px;font-size:15px;
  box-shadow:0 8px 20px rgba(176,38,224,.3)}
.btn:hover{filter:brightness(1.05)}
.btn.secondary{background:#fff;color:var(--brand);border:1px solid var(--brand);box-shadow:none}
.btn.ghost{background:transparent;color:var(--muted);box-shadow:none;border:1px solid var(--line)}
.btn.sm{padding:8px 14px;font-size:13px}
.btn.block{width:100%}
.muted{color:var(--muted)}
.pill{display:inline-block;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:700}
.pill.nouveau{background:#fdeaff;color:#B026E0}
.pill.confirme{background:#e7f6ee;color:var(--ok)}
.pill.realise{background:#eef0ff;color:#3b46c4}
.pill.annule{background:#fde8e8;color:#c0392b}
.pill.web{background:#eef7ff;color:#1a73e8}.pill.tel{background:#fff3e0;color:#b8860b}
.flash{background:#e7f6ee;color:#1f7a45;border:1px solid #b9e3c9;padding:10px 14px;border-radius:10px;margin-bottom:14px}
.banner{background:#fff3cd;color:#856404;border:1px solid #ffe69c;padding:10px 14px;border-radius:10px;margin-bottom:14px;font-size:13px}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.day-head{margin:18px 0 6px;font-weight:800;color:var(--brand-dark);text-transform:capitalize}
.rdv-line{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:12px;
  background:#fff;margin-bottom:8px}
.rdv-line:hover{border-color:var(--brand)}
.rdv-line .time{font-weight:800;color:var(--brand);min-width:54px}
.rdv-line .who{flex:1}
.rdv-line .who small{color:var(--muted)}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.file-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;
  border:1px solid var(--line);border-radius:10px;margin-bottom:8px}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,#1A0626,#B026E0)}
.login-card{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:30px;width:100%;max-width:380px}
canvas#pad{width:100%;height:220px;border:2px dashed var(--brand);border-radius:14px;background:#fff;touch-action:none}
.doc-preview{background:#faf6fc;border:1px solid var(--line);border-radius:12px;padding:16px;font-size:14px;line-height:1.6}
@media(max-width:560px){.topbar .brand{font-size:16px}.wrap{padding:14px 12px 60px}.row{gap:8px}}
