/* ============================ West Coast Arcades — design system (base Navilio) ============================ */
:root{
  --navy:#0e2a52; --navy2:#143462; --navy-deep:#0a2247;
  --teal:#14a4b4; --teal-d:#0e8a99; --teal-l:#e3f5f7;
  --magenta:#e91e63; --magenta-l:#fde7ef;
  --ink:#0e2a52; --muted:#6b7a90; --faint:#93a1b3;
  --bg:#eef2f8; --card:#ffffff; --line:#e7edf5; --line2:#eef2f7;
  --green:#2e9e5b; --green-l:#e6f5ec;
  --blue:#1f6fd0; --blue-l:#e7f1fc;
  --purple:#6a3fb5; --purple-l:#efe9fb;
  --amber:#c9820f; --amber-l:#fbefd9;
  --pink:#d23c7d; --pink-l:#fce8f1;
  --radius:16px;
  --shadow:0 2px 10px rgba(16,42,82,.06);
  --shadow-lg:0 8px 30px rgba(16,42,82,.12);
  --sidebar-w:250px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--ink); font-size:15px;
}
a{color:inherit;text-decoration:none}
svg.ic{width:20px;height:20px;flex-shrink:0}

/* ============================== LAYOUT ============================== */
.app{display:flex; min-height:100vh}
.main{flex:1; min-width:0; display:flex; flex-direction:column}
.view{padding:22px 26px 60px; max-width:1180px; width:100%}

/* ============================== SIDEBAR ============================== */
.sidebar{
  width:var(--sidebar-w); flex-shrink:0; background:var(--navy);
  color:#fff; display:flex; flex-direction:column; position:sticky; top:0; height:100vh;
}
.brand{display:flex; align-items:center; gap:11px; padding:20px 18px 16px}
.brand-logo{width:42px;height:42px;object-fit:contain}
.brand-name{font-size:21px; font-weight:800; letter-spacing:.3px; line-height:1}
.brand-sub{font-size:11px; color:#9db4d4; margin-top:3px; letter-spacing:.2px}

.nav{flex:1; padding:8px 12px; overflow-y:auto}
.nav a{
  display:flex; align-items:center; gap:13px; padding:11px 14px; border-radius:12px;
  color:#c4d3e8; font-weight:600; font-size:14.5px; margin-bottom:3px; cursor:pointer; position:relative;
}
.nav a:hover{background:rgba(255,255,255,.06); color:#fff}
.nav a.active{
  background:linear-gradient(135deg, var(--teal), #1f7bb8); color:#fff;
  box-shadow:0 6px 16px rgba(20,164,180,.35);
}
.nav a .ic{opacity:.95}
.nav a .nav-badge{
  margin-left:auto; background:var(--magenta); color:#fff; font-size:11px; font-weight:700;
  min-width:18px; height:18px; border-radius:999px; display:flex; align-items:center; justify-content:center; padding:0 5px;
}
.nav a.active .nav-badge{background:#fff; color:var(--magenta)}

.userbox{
  display:flex; align-items:center; gap:11px; margin:12px; padding:11px;
  background:rgba(255,255,255,.06); border-radius:14px; border:1px solid rgba(255,255,255,.08);
}
.userbox .u-name{font-size:13.5px; font-weight:700}
.userbox .u-role{font-size:11.5px; color:#9db4d4}

/* ============================== TOPBAR ============================== */
.topbar{
  position:sticky; top:0; z-index:20; background:rgba(255,255,255,.92); backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line); padding:14px 26px;
  display:flex; align-items:center; gap:14px;
}
.topbar h1{font-size:21px; font-weight:800; margin:0; color:var(--navy)}
.topbar-right{margin-left:auto; display:flex; align-items:center; gap:14px}
.topbar-actions{display:flex; gap:10px; align-items:center}
.bell{
  position:relative; width:42px; height:42px; border-radius:50%; border:1px solid var(--line);
  background:#fff; color:var(--navy); cursor:pointer; display:flex; align-items:center; justify-content:center;
}
.bell .ic{width:20px;height:20px}
.bell-badge{
  position:absolute; top:-3px; right:-3px; background:var(--magenta); color:#fff;
  font-size:11px; font-weight:700; min-width:18px; height:18px; border-radius:999px;
  display:flex; align-items:center; justify-content:center; border:2px solid #fff;
}
.burger{display:none; width:40px;height:40px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer}

/* ============================== BOUTONS ============================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background:var(--teal); color:#fff; border:none; border-radius:12px;
  padding:11px 18px; font-weight:700; font-size:14.5px; cursor:pointer; white-space:nowrap;
  box-shadow:0 4px 12px rgba(20,164,180,.25);
}
.btn:hover{background:var(--teal-d)}
.btn .ic{width:18px;height:18px}
.btn.navy{background:var(--navy); box-shadow:none}
.btn.navy:hover{background:var(--navy2)}
.btn.green{background:var(--green); box-shadow:none}
.btn.grey{background:#eef2f7; color:var(--navy); box-shadow:none}
.btn.grey:hover{background:#e3e9f1}
.btn.red{background:#fdecec; color:#d23c3c; box-shadow:none}
.btn.red:hover{background:#fbdada}
.btn.light{background:var(--teal-l); color:var(--teal-d); box-shadow:none}
.btn.outline{background:#fff; color:var(--navy); border:1px solid var(--line); box-shadow:none}
.btn.full{width:100%}
.btn.small{padding:8px 13px; font-size:13px; border-radius:10px}
.iconbtn{
  width:40px;height:40px;border-radius:50%; border:none; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; background:var(--teal); color:#fff;
}
.iconbtn .ic{width:18px;height:18px}
.iconbtn.tealsoft{background:var(--teal-l); color:var(--teal-d)}
.iconbtn.ghost{background:#f1f5fa; color:var(--muted)}

/* ============================== CARTES GÉNÉRIQUES ============================== */
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:18px}
.section-title{font-size:13px;font-weight:700;color:var(--teal-d);text-transform:uppercase;letter-spacing:.05em;margin:18px 0 8px}

/* ============================== CARTES MÉTRIQUES ============================== */
.metrics{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin-bottom:18px}
.metric{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px 18px; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:2px;
}
.metric .m-val{font-size:26px; font-weight:800; color:var(--navy); line-height:1.1}
.metric .m-val small{font-size:14px; font-weight:700; color:var(--muted)}
.metric .m-lbl{font-size:13px; color:var(--muted); font-weight:600}
.metric.accent .m-val{color:var(--teal-d)}

/* ============================== TIMELINE TOURNÉE ============================== */
.tl{position:relative; margin-top:4px}
.tl-item{display:flex; gap:14px; position:relative; padding-bottom:14px}
.tl-rail{display:flex; flex-direction:column; align-items:center; flex-shrink:0}
.tl-num{
  width:30px;height:30px;border-radius:50%; background:var(--teal); color:#fff;
  font-weight:700; font-size:14px; display:flex; align-items:center; justify-content:center; z-index:1;
}
.tl-item.done .tl-num{background:var(--green)}
.tl-line{flex:1; width:2px; background:var(--line); margin:4px 0}
.tl-item:last-child .tl-line{display:none}
.tl-card{
  flex:1; background:var(--card); border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); padding:14px 16px; display:flex; align-items:center; gap:14px;
}
.tl-item.done .tl-card{opacity:.62}
.tl-main{flex:1; min-width:0}
.tl-time{font-weight:800; color:var(--navy); font-size:15px}
.tl-name{font-weight:700; margin:1px 0}
.tl-addr{color:var(--muted); font-size:13px}
.tl-actions{display:flex; align-items:center; gap:8px; flex-shrink:0}
.tl-check{width:22px;height:22px;cursor:pointer; accent-color:var(--teal)}

/* tags de soins (pastilles colorées) */
.tags{display:flex; flex-wrap:wrap; gap:6px; margin-top:6px}
.tag{font-size:12px; font-weight:700; padding:3px 10px; border-radius:999px; background:var(--teal-l); color:var(--teal-d)}
.tag.pink{background:var(--pink-l); color:var(--pink)}
.tag.blue{background:var(--blue-l); color:var(--blue)}
.tag.green{background:var(--green-l); color:var(--green)}
.tag.purple{background:var(--purple-l); color:var(--purple)}
.tag.amber{background:var(--amber-l); color:var(--amber)}
.tag.gray{background:#eef1f5; color:#5a6b80}

/* ============================== TABLEAU PATIENTS ============================== */
.toolbar{display:flex; gap:12px; align-items:center; margin-bottom:16px; flex-wrap:wrap}
.search{position:relative; flex:1; min-width:200px}
.search .ic{position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--faint); width:18px;height:18px}
.search input{padding-left:40px}
.tablecard{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden}
table.grid{width:100%; border-collapse:collapse}
table.grid th{
  text-align:left; font-size:12.5px; font-weight:700; color:var(--muted); text-transform:uppercase;
  letter-spacing:.03em; padding:14px 16px; background:#f7f9fc; border-bottom:1px solid var(--line);
}
table.grid td{padding:13px 16px; border-bottom:1px solid var(--line2); font-size:14px; vertical-align:middle}
table.grid tr:last-child td{border-bottom:none}
table.grid tr:hover td{background:#fafcff}
.pcell{display:flex; align-items:center; gap:11px}
.pcell .sub{color:var(--muted); font-size:12.5px}
.row-actions{display:flex; gap:7px; justify-content:flex-end}
.row-actions .iconbtn{width:34px;height:34px}
.row-actions .iconbtn .ic{width:16px;height:16px}

/* ============================== GRILLE SOINS ============================== */
.tabs-row{display:flex; gap:24px; border-bottom:1px solid var(--line); margin-bottom:18px}
.tabs-row button{
  background:none; border:none; padding:10px 2px; font-size:14.5px; font-weight:600; color:var(--muted);
  cursor:pointer; border-bottom:3px solid transparent; margin-bottom:-1px;
}
.tabs-row button.active{color:var(--teal-d); border-bottom-color:var(--teal)}
.soingrid{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px}
.soincard{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:16px; display:flex; flex-direction:column; gap:8px; position:relative;
}
.soincard .s-ico{width:46px;height:46px;border-radius:13px; display:flex; align-items:center; justify-content:center; background:var(--teal-l); color:var(--teal-d)}
.soincard .s-ico .ic{width:24px;height:24px}
.soincard h4{margin:2px 0 0; font-size:15.5px; font-weight:700}
.soincard p{margin:0; color:var(--muted); font-size:13px; line-height:1.45; flex:1}
.soincard .s-tools{position:absolute; top:12px; right:12px; display:flex; gap:5px; opacity:0; transition:.15s}
.soincard:hover .s-tools{opacity:1}

/* ============================== CALENDRIER ============================== */
.seg{display:inline-flex; background:#eef2f7; border-radius:11px; padding:3px}
.seg button{border:none; background:none; padding:7px 16px; font-weight:700; font-size:13.5px; color:var(--muted); border-radius:9px; cursor:pointer}
.seg button.active{background:#fff; color:var(--navy); box-shadow:var(--shadow)}
.week{display:grid; grid-template-columns:56px repeat(7,1fr); background:var(--card); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow)}
.week .wh{padding:10px 6px; text-align:center; font-size:12px; font-weight:700; color:var(--muted); border-bottom:1px solid var(--line); border-left:1px solid var(--line2)}
.week .wh.today{color:var(--teal-d)}
.week .wc{border-left:1px solid var(--line2); border-bottom:1px solid var(--line2); min-height:46px; padding:3px; position:relative}
.week .wtime{font-size:11px; color:var(--faint); text-align:right; padding:3px 6px; border-bottom:1px solid var(--line2)}
.ev{font-size:11px; font-weight:600; padding:3px 6px; border-radius:7px; margin-bottom:3px; background:var(--teal-l); color:var(--teal-d); cursor:pointer; overflow:hidden; white-space:nowrap; text-overflow:ellipsis}
.cal-month{display:grid; grid-template-columns:repeat(7,1fr); gap:7px}
.cal-month .dow{text-align:center;font-size:12px;color:var(--muted);font-weight:700;padding:4px 0}
.cal-cell{aspect-ratio:1;border-radius:11px;border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative}
.cal-cell.empty{border:none;background:transparent;cursor:default}
.cal-cell.today{border-color:var(--teal);font-weight:800;color:var(--teal-d)}
.cal-cell.has::after{content:'';position:absolute;bottom:7px;width:6px;height:6px;border-radius:50%;background:var(--teal)}

/* ============================== ACCUEIL ============================== */
.hero{
  background:linear-gradient(120deg,#173a6b,#0e2a52); color:#fff; border-radius:20px;
  padding:28px 30px; margin-bottom:20px; box-shadow:var(--shadow-lg);
}
.hero h2{margin:0 0 6px; font-size:26px; font-weight:800}
.hero p{margin:0; color:#bcd0ec; font-size:15px}
.hero .accent{color:#7fe3ec; font-weight:700}
/* Bandeau de bienvenue (style maquette) */
.welcome{display:flex;align-items:center;gap:18px;background:linear-gradient(120deg,#e9f3fc,#f4f8fc);border:1px solid #dce8f5;border-radius:20px;padding:22px 26px;margin-bottom:20px;overflow:hidden}
.welcome-txt{flex:1;min-width:0}
.welcome-txt h2{margin:0 0 6px;font-size:26px;color:var(--navy);font-weight:800}
.welcome-txt p{margin:0;color:var(--muted);font-size:15px}
.welcome-txt .accent{color:var(--magenta);font-weight:700}
.welcome-img{max-height:170px;max-width:46%;border-radius:14px;object-fit:cover;flex-shrink:0}
@media(max-width:760px){.welcome-img{display:none}}

/* cartes pilules */
.home-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:14px}
.home-card{
  display:flex; gap:14px; align-items:center; background:var(--card); border:1px solid var(--line);
  border-radius:999px; padding:13px 18px; box-shadow:var(--shadow); cursor:pointer;
}
.home-card:hover{box-shadow:var(--shadow-lg); transform:translateY(-1px)}
.home-card .h-ico{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.home-card .h-ico .ic{width:24px;height:24px}
.home-card .h-txt{flex:1;min-width:0}
.home-card h4{margin:0 0 1px; font-size:16px; font-weight:800}
.home-card p{margin:0; font-size:12.5px; color:var(--muted)}
.home-card .h-chev{color:var(--faint);width:18px;height:18px;flex-shrink:0}

/* bas de page accueil */
.home-foot{margin-top:18px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:18px 22px; box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.home-foot .hf-main{display:flex;align-items:center;gap:12px}
.home-foot .hf-heart{font-size:22px}
.home-foot strong{color:var(--navy);font-size:15px}
.home-foot .hf-sub{color:var(--muted);font-size:13.5px;margin-top:2px}
.home-foot .hf-thanks{color:var(--magenta);font-weight:700;font-style:italic}
.topbar-date{display:inline-flex;align-items:center;gap:7px;color:var(--navy);font-weight:700;font-size:13.5px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:7px 12px}
.topbar-date svg{width:16px;height:16px;color:var(--teal-d)}

/* couleurs d'icônes (accueil + soins) */
.ic-teal{background:var(--teal-l); color:var(--teal-d)}
.ic-pink{background:var(--pink-l); color:var(--pink)}
.ic-blue{background:var(--blue-l); color:var(--blue)}
.ic-purple{background:var(--purple-l); color:var(--purple)}
.ic-amber{background:var(--amber-l); color:var(--amber)}
.ic-green{background:var(--green-l); color:var(--green)}
.ic-navy{background:#e6ebf3; color:var(--navy)}

/* ============================== AVATARS ============================== */
.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.avatar-sm{width:34px;height:34px}
.avatar-ph{display:inline-flex;align-items:center;justify-content:center;background:#cfe6ea;color:var(--teal-d);font-weight:700;font-size:13px;text-transform:uppercase}
.userbox .avatar-ph{background:rgba(255,255,255,.16);color:#fff}
.avatar-lg{width:74px;height:74px;font-size:26px}

/* ============================== FORMULAIRES / MODALE ============================== */
label.field{display:block;margin:12px 0}
label.field span{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:5px}
input,select,textarea{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:11px;font-size:14.5px;
  font-family:inherit;background:#fff;color:var(--ink);
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(20,164,180,.15)}
textarea{min-height:68px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-overlay{position:fixed;inset:0;background:rgba(14,42,82,.45);z-index:60;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow:auto}
.modal{background:#fff;border-radius:20px;padding:22px;max-width:580px;width:100%;margin-top:24px;box-shadow:var(--shadow-lg)}
.modal h3{margin:0 0 14px;font-size:19px;color:var(--navy)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:var(--teal-l);color:var(--teal-d);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.chip button{background:none;border:none;color:var(--teal-d);cursor:pointer;font-size:15px;line-height:1;padding:0}
.combo{position:relative}
.combo-list{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:5;background:#fff;border:1px solid var(--line);border-radius:11px;max-height:240px;overflow:auto;box-shadow:var(--shadow-lg)}
.combo-item{padding:10px 12px;cursor:pointer;font-size:14.5px;border-bottom:1px solid var(--line2)}
.combo-item:last-child{border-bottom:none}
.combo-item:hover{background:#f3f7fb}
.combo-item .sub{color:var(--muted);font-size:12px;margin-left:6px}
.combo-item.muted{color:var(--muted);cursor:default}
.cat-picker{border:1px solid var(--line);border-radius:11px;max-height:200px;overflow:auto;margin-bottom:10px}
.cat-opt{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:14.5px;border-bottom:1px solid var(--line2);cursor:pointer}
.cat-opt:last-child{border-bottom:none}
.cat-opt:hover{background:#f7f9fc}
.cat-opt input{width:auto;transform:scale(1.25)}
.heure-row{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.heure-row input[type=time]{flex:1}
.serie-banner{background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;border-radius:12px;padding:12px 14px;margin-bottom:14px;font-size:14px}
.serie-banner .help{color:#4f46e5}
.recap{background:var(--teal-l);border:1px solid #b6e3e8;color:var(--teal-d);border-radius:11px;padding:10px 12px;font-size:14px;margin:4px 0 12px}
.badge-serie{background:#e0e7ff;color:#3730a3;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:700}

/* ============================== CONNEXION ============================== */
.login-wrap{min-height:100vh;display:flex}
.login-hero{flex:1;background:linear-gradient(135deg,#0e2a52,#0e7490);color:#fff;padding:48px 52px;display:flex;flex-direction:column;justify-content:center}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:30px}
.login-brand .lb-name{font-size:24px;font-weight:800;line-height:1}
.login-brand .lb-sub{font-size:12px;color:#9db4d4;margin-top:2px}
.login-hero h2{font-size:34px;margin:0 0 12px;font-weight:800;line-height:1.15}
.login-hero h2 span{color:#7fe3ec}
.login-hero>p{color:#cfe0f2;font-size:16px;max-width:430px;margin:0}
.login-points{list-style:none;padding:0;margin:28px 0 0;display:flex;flex-direction:column;gap:13px}
.login-points li{display:flex;align-items:center;gap:11px;color:#e6eefb;font-weight:600}
.login-points li svg{width:20px;height:20px;color:#7fe3ec;flex-shrink:0}
.login-card{width:430px;max-width:100%;background:#fff;display:flex;flex-direction:column;justify-content:center;padding:48px 44px}
.login-card h3{font-size:23px;margin:0 0 18px;color:var(--navy)}
.login-err{background:#fdecec;color:#b3261e;border:1px solid #f6caca;border-radius:10px;padding:10px 12px;font-size:13.5px;margin-bottom:12px}
.ub-logout{background:none;border:none;color:#9db4d4;cursor:pointer;padding:6px;border-radius:8px;flex-shrink:0}
.ub-logout:hover{color:#fff;background:rgba(255,255,255,.12)}
@media (max-width:820px){
  .login-wrap{flex-direction:column}
  .login-hero{padding:34px 26px}
  .login-hero h2{font-size:27px}
  .login-card{width:100%;padding:32px 26px}
}

/* divers */
.list-item{background:#fff;border:1px solid var(--line);border-radius:13px;padding:13px 15px;margin-bottom:10px;box-shadow:var(--shadow);display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.list-item:hover{background:#fafcff}
.list-item .sub{color:var(--muted);font-size:13px;margin-top:3px}
.empty-state{text-align:center;color:var(--muted);padding:50px 20px;background:#fff;border:1px dashed var(--line);border-radius:var(--radius)}
.help{font-size:13px;color:var(--muted);margin:6px 0 0}
.hidden{display:none !important}
.details{background:#f7f9fc;border-radius:12px;padding:10px 14px;margin-top:6px}
.details p{margin:6px 0;font-size:13.5px}
.details .key{color:var(--muted)}
.buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px;margin:10px 0}
.buttons a{display:flex;align-items:center;justify-content:center;gap:6px;padding:11px;border-radius:11px;background:var(--teal);color:#fff;font-weight:700;font-size:14px}
.buttons a.maps{background:#eef2f7;color:var(--navy)}
.buttons a.call{background:var(--green)}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:13px 20px;border-radius:12px;z-index:80;font-weight:600;box-shadow:var(--shadow-lg);opacity:0;transition:opacity .25s;pointer-events:none}
.toast.show{opacity:1}
.scrim{position:fixed;inset:0;background:rgba(14,42,82,.45);z-index:45;opacity:0;pointer-events:none;transition:opacity .2s}
.scrim.show{opacity:1;pointer-events:auto}

/* barre de navigation jour (Tournée) */
.daybar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.daybar input[type=date]{flex:1;text-align:center;font-weight:700}

/* cartes étape de tournée */
.stop{margin-bottom:14px;padding:16px}
.stop.done{opacity:.6}
.stop.done .stop-name{text-decoration:line-through}
.stop-head{display:flex;gap:12px;align-items:flex-start}
.stop-num{width:30px;height:30px;border-radius:50%;background:var(--teal);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stop.done .stop-num{background:var(--green)}
.stop-time{font-weight:700;color:var(--muted);font-size:13px}
.stop-name{font-weight:800;font-size:17px;color:var(--navy)}
.stop-addr{color:var(--muted);font-size:14px}
.stop-fait{display:flex;align-items:center;gap:7px;font-weight:700;font-size:14px;flex-shrink:0;cursor:pointer}
.stop-fait input{width:20px;height:20px;accent-color:var(--teal)}
.navrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;margin:12px 0 4px}
.navbtn{display:flex;align-items:center;justify-content:center;gap:6px;padding:11px;border-radius:11px;font-weight:700;font-size:14px;text-decoration:none;cursor:pointer;border:none}
.navbtn.apple{background:var(--navy);color:#fff}
.navbtn.gmaps{background:#eaf1fb;color:var(--blue)}
.navbtn.call{background:var(--green);color:#fff}
.navbtn.js-edit,.pcard .js-edit{background:#eef2f7;color:var(--navy)}
.navbtn.disabled{background:#eef1f5;color:var(--muted)}
.stop-tools{margin-top:10px;display:flex;justify-content:flex-end}

/* cartes patients (responsive) */
.pcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.pcard{padding:15px;cursor:pointer}
.pcard-top{display:flex;gap:11px;align-items:center;margin-bottom:10px}
.pcard-name{font-weight:800;color:var(--navy)}
.pcard-addr{color:var(--muted);font-size:13px}
.pcard-info{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:13.5px;color:var(--muted);margin-bottom:12px}
.pcard-info span{display:inline-flex;align-items:center;gap:6px}
.pcard-info svg{width:15px;height:15px}
.pcard-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* ============================== RESPONSIVE ============================== */
@media (max-width:860px){
  .sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:transform .25s;box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .burger{display:inline-flex;align-items:center;justify-content:center}
  .view{padding:16px 14px 70px}
  .topbar{padding:11px 14px;flex-wrap:wrap}
  .topbar h1{font-size:19px}
  .topbar-right{gap:8px}
  .topbar-actions{flex-wrap:wrap}
  .topbar-actions .btn{padding:9px 12px;font-size:13px}
  .row2{grid-template-columns:1fr}
  .metrics{grid-template-columns:1fr 1fr;gap:10px}
  .metric .m-val{font-size:22px}
  .modal{padding:18px;margin-top:10px;border-radius:16px}
  .pcard-actions{grid-template-columns:1fr 1fr}
  .week{font-size:11px}
}
@media (max-width:420px){
  .metrics{grid-template-columns:1fr 1fr}
  .navrow{grid-template-columns:1fr 1fr}
}

/* étape « Fait » : on réduit au minimum pour clarifier la suite de la tournée */
.stop.done .stop-body{display:none}
.stop.done{padding:12px 16px}
.navbtn.consigne{background:#fff4e0;color:#b9770f}

/* calendrier semaine — version soignée */
.weektitle{font-weight:800;color:var(--navy);margin-bottom:10px;font-size:16px}
.week .wh{display:flex;flex-direction:column;gap:1px;padding:8px 4px;justify-content:center}
.wh-day{font-weight:700;color:var(--navy);font-size:12.5px}
.wh.today .wh-day{color:var(--teal-d)}
.wh-mon{font-size:11px;color:var(--faint)}
.week .wcorner{background:#f7f9fc}
.week .wc{min-height:54px}
.wc-empty{background:repeating-linear-gradient(45deg,#f6f8fc,#f6f8fc 6px,#fff 6px,#fff 12px)}
.noday{display:block;color:var(--faint);font-size:11px;text-align:center;margin-top:6px;font-weight:600}
.ev{display:flex;flex-direction:column;line-height:1.25;padding:5px 7px;border-radius:8px}
.ev b{font-weight:700}

/* ============================ West Coast Arcades — compléments ============================ */
/* Bascule OUI / NON (état fonctionnel cliquable) */
.toggle-oui-non{display:inline-flex;border-radius:999px;overflow:hidden;border:1px solid var(--line);cursor:pointer;font-weight:800;font-size:12.5px;user-select:none}
.toggle-oui-non span{padding:5px 13px;display:inline-flex;align-items:center;gap:5px;transition:.12s;color:var(--muted);background:#fff}
.toggle-oui-non .t-oui{}
.toggle-oui-non .t-non{}
.toggle-oui-non.on .t-oui{background:var(--green);color:#fff}
.toggle-oui-non.off .t-non{background:#e23b3b;color:#fff}
.toggle-oui-non.on .t-non{color:#b9b9b9}
.toggle-oui-non.off .t-oui{color:#b9b9b9}

/* Badges de statut matériel */
.statut{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:4px 11px;border-radius:999px}
.statut::before{content:'';width:8px;height:8px;border-radius:50%;background:currentColor}
.statut.dispo{background:var(--green-l);color:var(--green)}
.statut.bloque{background:var(--amber-l);color:var(--amber)}
.statut.hs{background:#fdecec;color:#d23c3c}
.statut.vendu{background:#eef1f5;color:#5a6b80}

/* Lignes de devis */
.ligne{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;margin-bottom:8px;background:#fff}
.ligne .l-name{flex:1;font-weight:600}
.ligne .l-prix{width:120px}
.ligne .l-qte{width:70px}
.ligne .l-warn{font-size:12px;color:#c9820f;font-weight:700}
.devis-total{display:flex;justify-content:space-between;align-items:center;background:var(--teal-l);border:1px solid #b6e3e8;border-radius:12px;padding:14px 16px;margin-top:8px}
.devis-total .dt-val{font-size:22px;font-weight:800;color:var(--teal-d)}

/* Grille de disponibilité (événement) */
.dispo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.dispo-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow);border-left:5px solid var(--green)}
.dispo-card.ko{border-left-color:#e23b3b}
.dispo-card .dc-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.dispo-card h4{margin:0;font-size:15px;color:var(--navy)}
.dispo-card .dc-cat{color:var(--muted);font-size:12.5px}
.dispo-card .dc-raison{margin-top:8px;font-size:12.5px;color:#c0392b;font-weight:600}
.dispo-card.ok .dc-raison{color:var(--green)}

/* statut pills réparation / prêt / devis */
.pill-st{font-size:11.5px;font-weight:800;padding:3px 10px;border-radius:999px}
.pill-st.a_faire{background:var(--amber-l);color:var(--amber)}
.pill-st.en_cours{background:var(--blue-l);color:var(--blue)}
.pill-st.termine{background:var(--green-l);color:var(--green)}
.pill-st.rendu{background:#eef1f5;color:#5a6b80}
.pill-st.brouillon{background:#eef1f5;color:#5a6b80}
.pill-st.envoye{background:var(--blue-l);color:var(--blue)}
.pill-st.accepte{background:var(--green-l);color:var(--green)}
.pill-st.refuse{background:#fdecec;color:#d23c3c}

.mini{font-size:12.5px;color:var(--muted)}
.blocks-list{display:flex;flex-wrap:wrap;gap:5px}
