/* ============================================================
   WOUGGO V2 — parcours.css
   ============================================================ */
body { background:#FFF7ED; overflow-x:hidden; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar { position:fixed;top:0;left:0;width:60px;height:100vh;background:#fff;border-right:1px solid #E5E7EB;display:flex;flex-direction:column;align-items:center;padding:1rem 0;z-index:200; }
.sidebar__logo { margin-bottom:1.25rem; }
.sidebar__links { flex:1;display:flex;flex-direction:column;align-items:center;gap:4px; }
.sidebar__bottom { margin-top:auto; }
.sidebar__item { width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;text-decoration:none;cursor:pointer;color:#9CA3AF;transition:background .15s,color .15s; }
.sidebar__item:hover,.sidebar__item.active { background:#FFF7ED;color:#F97316; }
.sidebar__item svg { width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round; }
@media(max-width:768px){.sidebar{display:none;}}

/* ── Page ────────────────────────────────────────────────── */
.page-wrap { margin-left:60px;min-height:100vh;background:#FFF7ED;max-width:800px; }
@media(max-width:768px){.page-wrap{margin-left:0;padding-bottom:64px;}}

/* ── Vues ────────────────────────────────────────────────── */
.pview { display:flex;flex-direction:column;min-height:100vh; }
.pview.hidden { display:none; }

/* ── Header parcours ─────────────────────────────────────── */
.parc-header {
  display:flex;align-items:center;gap:.75rem;
  padding:.875rem 1.25rem;
  background:#fff;border-bottom:1px solid #E5E7EB;
  position:sticky;top:0;z-index:100;flex-shrink:0;
}
.parc-header__title { font-size:1.125rem;font-weight:700;color:#532822;flex:1; }
.parc-header__center { flex:1;min-width:0; }
.parc-back { width:36px;height:36px;border:none;background:#FFF7ED;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#532822;flex-shrink:0;transition:background .15s; }
.parc-back:hover { background:#F0E8DF; }
.parc-share-btn { width:36px;height:36px;border:none;background:#FFF7ED;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#532822;flex-shrink:0; }
.parc-share-btn:hover { background:#F0E8DF; }

.parc-detail-titre { font-size:1rem;font-weight:700;color:#532822;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.parc-code { font-size:.75rem;color:#9CA3AF;font-weight:500; }

/* ── Join bar ────────────────────────────────────────────── */
.join-bar {
  display:flex;gap:.5rem;padding:.875rem 1.25rem;
  background:#fff;border-bottom:1px solid #E5E7EB;
}
.join-input {
  flex:1;height:40px;padding:0 1rem;
  border:1.5px solid #E0D8D0;border-radius:10px;
  font-size:.9375rem;font-family:inherit;color:#532822;
  letter-spacing:.1em;font-weight:600;outline:none;
  transition:border-color .15s;
}
.join-input:focus { border-color:#F97316; }
.join-input::placeholder { letter-spacing:0;font-weight:400;color:#9CA3AF; }

/* ── Liste parcours ──────────────────────────────────────── */
.parcours-list { padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.625rem; }
.parc-item {
  display:flex;align-items:center;gap:.875rem;
  background:#fff;border-radius:12px;border:1px solid #EDE8E2;
  padding:1rem 1.25rem;cursor:pointer;
  transition:transform .15s,box-shadow .15s;
}
.parc-item:hover { transform:translateY(-1px);box-shadow:0 4px 16px rgba(83,40,34,.08); }
.parc-item__body { flex:1;min-width:0; }
.parc-item__titre { font-size:.9375rem;font-weight:700;color:#532822;margin-bottom:.25rem; }
.parc-item__meta { font-size:.8125rem;color:#7A5C58; }

/* ── Empty states ────────────────────────────────────────── */
.parc-empty-list { display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:3rem 1.25rem; }
.parc-empty-list__icon { font-size:56px; }
.parc-empty-list__title { font-size:1.125rem;font-weight:700;color:#532822; }
.parc-empty-list__sub { font-size:.875rem;color:#7A5C58;line-height:1.5; }
.parc-empty { text-align:center;padding:2rem;color:#7A5C58;font-size:.875rem; }

/* ── Formulaire création ─────────────────────────────────── */
.create-form { padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:1rem; }

/* ── Membres bar ─────────────────────────────────────────── */
.membres-bar {
  display:flex;align-items:center;gap:.375rem;
  padding:.625rem 1.25rem;
  background:#fff;border-bottom:1px solid #E5E7EB;
  flex-wrap:wrap;
}
.membre-avatar {
  width:32px;height:32px;border-radius:50%;
  background:#F97316;color:#fff;
  font-size:.875rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:2px solid #fff;box-shadow:0 0 0 1.5px #F97316;
}

/* ── Onglets parcours ────────────────────────────────────── */
.parc-tabs { display:flex;background:#fff;border-bottom:1px solid #E5E7EB; }
.parc-tab { flex:1;padding:.75rem;border:none;background:transparent;font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;color:#7A5C58;transition:all .15s;border-bottom:2px solid transparent; }
.parc-tab.active { color:#F97316;border-bottom-color:#F97316;font-weight:700; }
.parc-tab-content { display:none;flex:1; }
.parc-tab-content.active { display:block; }

/* ── Liste lieux dans parcours ───────────────────────────── */
.parc-lieux { padding:.875rem 1.25rem;display:flex;flex-direction:column;gap:.625rem; }
.parc-lieu {
  display:flex;align-items:center;gap:.75rem;
  background:#fff;border-radius:12px;border:1px solid #EDE8E2;
  padding:.75rem;position:relative;
}
.parc-lieu__num {
  width:28px;height:28px;border-radius:50%;
  background:#F97316;color:#fff;
  font-size:.875rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.parc-lieu__img { width:56px;height:56px;border-radius:8px;overflow:hidden;background:#F0EDE8;flex-shrink:0; }
.parc-lieu__img img { width:100%;height:100%;object-fit:cover; }
.parc-lieu__ph { width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:22px; }
.parc-lieu__body { flex:1;min-width:0; }
.parc-lieu__nom { font-size:.875rem;font-weight:700;color:#532822;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.parc-lieu__meta { font-size:.75rem;color:#7A5C58; }
.parc-lieu__prix { font-size:.75rem;color:#F97316;font-weight:600; }
.parc-lieu__remove { width:28px;height:28px;border-radius:50%;background:#FEF2F2;border:none;cursor:pointer;color:#EF4444;font-size:.8125rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s; }
.parc-lieu__remove:hover { background:#EF4444;color:#fff; }

.parc-maps-btn { padding:.875rem 1.25rem; }

/* ── Chat ────────────────────────────────────────────────── */
#ptab-chat { display:none;flex-direction:column;height:calc(100vh - 220px); }
#ptab-chat.active { display:flex; }
.chat-messages { flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem; }
.chat-empty { text-align:center;color:#9CA3AF;font-size:.875rem;padding:2rem; }
.chat-bubble { max-width:80%;padding:.625rem .875rem;border-radius:14px;font-size:.875rem;line-height:1.5; }
.chat-bubble--user { background:#F97316;color:#fff;align-self:flex-end;border-bottom-right-radius:4px; }
.chat-bubble--ia { background:#fff;color:#532822;align-self:flex-start;border-bottom-left-radius:4px;border:1px solid #EDE8E2; }
.chat-msg-author { font-size:.6875rem;font-weight:700;opacity:.8;margin-bottom:.125rem; }
.chat-msg-time { font-size:.625rem;opacity:.6;margin-top:.25rem;text-align:right; }
.chat-input-bar { display:flex;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border-top:1px solid #E5E7EB;flex-shrink:0; }
.chat-input { flex:1;height:44px;padding:0 1rem;border:1.5px solid #E0D8D0;border-radius:22px;font-size:.9375rem;font-family:inherit;color:#532822;outline:none;background:#FFF7ED;transition:border-color .15s; }
.chat-input:focus { border-color:#F97316;background:#fff; }
.chat-send-btn { width:44px;height:44px;background:#F97316;color:#fff;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s; }
.chat-send-btn:hover { background:#EA6A00; }

/* ── Boutons & forms ─────────────────────────────────────── */
.btn { display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:.625rem 1.5rem;border-radius:10px;font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all .15s;text-decoration:none;white-space:nowrap; }
.btn-primary { background:#F97316;color:#fff; }
.btn-primary:hover { background:#EA6A00; }
.btn-secondary { background:transparent;color:#F97316;border:1.5px solid #F97316; }
.btn-secondary:hover { background:#FFF7ED; }
.btn-dark { background:#1A1A2E;color:#fff; }
.btn-dark:hover { background:#3B3B5C; }
.btn-full { width:100%; }
.btn-lg { min-height:52px;font-size:1rem; }
.btn-sm { min-height:36px;padding:.375rem .875rem;font-size:.8125rem; }
.form-group { display:flex;flex-direction:column;gap:.375rem; }
.form-label { font-size:.875rem;font-weight:600;color:#532822; }
.req { color:#F97316; }
.form-input { width:100%;height:48px;padding:0 1rem;border:1.5px solid #E0D8D0;border-radius:10px;font-size:.9375rem;font-family:inherit;color:#532822;background:#fff;outline:none;transition:border-color .15s; }
.form-input:focus { border-color:#F97316; }
.pro-alert { padding:.75rem 1rem;border-radius:10px;font-size:.875rem; }
.pro-alert.hidden { display:none; }
.pro-alert--error { background:#FEF2F2;color:#DC2626;border:1px solid #FECACA; }

/* ── Bottom nav ──────────────────────────────────────────── */
.bottom-nav { display:none; }
@media(max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:#fff;border-top:1px solid #E5E7EB;align-items:center;justify-content:space-around;z-index:200;padding-bottom:env(safe-area-inset-bottom);}}
.bottom-nav__item { flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:44px;color:#9CA3AF;text-decoration:none;cursor:pointer;transition:color .15s; }
.bottom-nav__item.active { color:#F97316; }
.bottom-nav__label { font-size:10px;font-weight:500; }
.bnav-icon { width:24px;height:24px;display:flex;align-items:center;justify-content:center; }
.bnav-icon svg { width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round; }
.bottom-nav__item.active .bnav-icon svg { stroke:#F97316; }
.bnav-center { position:relative; }
.bnav-fab { width:52px;height:52px;background:#F97316;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:-16px;box-shadow:0 4px 16px rgba(249,115,22,.4); }
.bnav-fab svg { width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round; }
