/* ============================================================================
 * indexHome.css — TripCooking · Console membre (entête + carte + frise)
 * ----------------------------------------------------------------------------
 * Chargé UNIQUEMENT pour la vue membre (branche $isMember d'index.php).
 * Markup de l'entête : haut/entete.php  → classes .tcHeader* (PAS .top).
 *
 * Nettoyage / corrections de cette version :
 *   • L'entête .tcHeader est désormais ENTIÈREMENT responsive (burger réel
 *     .tcHeader__burger, wordmark/horloge/Créer/profil qui s'adaptent).
 *   • L'ancien bloc topbar .top (mort, non présent dans le markup) est retiré ;
 *     on conserve seulement .live / .pulse / @keyframes ping (utilisés par le dock).
 *   • La colonne Activité, masquée en intermédiaire, redevient empilée et
 *     utilisable sous 820px.
 *   • --rail-w aligné sur --rail (plus de décalage de largeur de rail).
 * ========================================================================== */

:root{
  /* chrome (sombre) */
  --chrome:#16171B; --chrome-2:#1C1E23; --chrome-3:#23262C;
  --line:#2A2D34; --line-2:#34373F;
  --on:#ECEDE9; --soft:#9A9E98; --muted:#6C7069;

  /* carte (clair) */
  --map-bg:#E7E6DF;

  /* accents */
  --accent:#CA4A82; --accent-deep:#B6306B; --accent-2:#E14B7A;
  --accent-soft:rgba(202,74,130,.16);
  --live:#34D27B; --gold:#E8A93C; --steel:#7FB0D9;

  --ui:"Plus Jakarta Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;

  --rail:266px; --dock:252px;
  --rail-w:var(--rail);   /* largeur du rail en mode 3 colonnes (= --rail) */
  --ca-w:360px;           /* largeur de la colonne Activité */
  --r:14px;
  --sh:0 1px 0 rgba(255,255,255,.03),0 16px 34px -22px rgba(0,0,0,.7);
}
body{margin:0;padding-top:60px;background:var(--chrome);color:var(--on);font-family:var(--ui);line-height:1.45;-webkit-font-smoothing:antialiased}  /* padding = hauteur de l'entête fixe */
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0}
img{display:block;max-width:100%}
::selection{background:var(--accent-soft);color:#fff}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
*::-webkit-scrollbar{width:8px;height:8px}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
*::-webkit-scrollbar-track{background:transparent}
.mono{font-family:var(--mono);font-feature-settings:"tnum"}


/* ============================================================================
 * ENTÊTE — .tcHeader (markup : haut/entete.php, form de recherche intact)
 * ========================================================================== */
.tcHeader{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;
  --tch-h:60px;
  height:var(--tch-h);
  gap:16px;
  padding:0 16px;

  background:var(--chrome,#16171B);
  background:color-mix(in srgb,var(--chrome,#16171B) 84%,transparent);
  -webkit-backdrop-filter:blur(14px) saturate(1.25);
  backdrop-filter:blur(14px) saturate(1.25);
  border-bottom:1px solid var(--line,#2A2D34);
  box-shadow:0 10px 30px -22px rgba(0,0,0,.85);
}
.tcHeader *{box-sizing:border-box}
.tcHeader a{color:inherit;text-decoration:none}
.tcHeader button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.tcHeader :focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}

/* --- GAUCHE : burger (mobile) + logo --- */
.tcHeader__left{display:flex;align-items:center;flex-shrink:0;gap:8px}
.tcHeader .tcHeader__burger{display:none}             /* visible en responsive */
.tcHeader__brand{display:inline-flex;align-items:center;gap:11px;padding:4px 8px 4px 4px;border-radius:12px;transition:background .15s}
.tcHeader__brand:hover{background:var(--chrome-2)}
.tcHeader__logo{
  display:grid;place-items:center;
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));
  box-shadow:0 8px 20px -7px rgba(182,48,107,.75),inset 0 1px 0 rgba(255,255,255,.25);
  color:#fff;font-size:13px;font-weight:800;letter-spacing:.02em;
}
.tcHeader__brandText{font-size:17px;font-weight:800;letter-spacing:-.02em;color:var(--on)}
.tcHeader__brandText span{color:var(--accent-2)}      /* « Cooking » en framboise */

/* --- CENTRE : recherche (form intact) + Créer --- */
.tcHeader__center{flex:1;display:flex;align-items:center;justify-content:center;gap:12px;min-width:0}
.tcHeaderSearch{
  position:relative;flex:1;display:flex;align-items:center;
  max-width:560px;height:42px;gap:10px;padding:0 12px 0 14px;
  background:var(--chrome-2);border:1px solid var(--line);border-radius:13px;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.tcHeaderSearch:hover{border-color:var(--line-2)}
.tcHeaderSearch:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--chrome)}
.tcHeaderSearch__icon{flex-shrink:0;font-size:14px;line-height:1;opacity:.85;color:var(--muted)}
#rechercheEntete{flex:1;min-width:0;height:100%;border:none;outline:none;background:none;color:var(--on);font:inherit;font-size:13.5px}
#rechercheEntete::placeholder{color:var(--muted)}
#rechercheEntete::-webkit-search-cancel-button{-webkit-appearance:none;appearance:none}
/* indice clavier ⌘K (purement CSS, n'altère pas le moteur) */
.tcHeaderSearch::after{
  content:"⌘K";margin-left:auto;flex-shrink:0;
  font-family:var(--mono);font-size:11px;color:var(--muted);
  border:1px solid var(--line-2);border-radius:6px;padding:2px 7px;line-height:1;pointer-events:none;
}
.tcHeaderSearch:focus-within::after{opacity:0}
/* dropdown résultats */
#resultEntete.search-dropdown{
  position:absolute;top:calc(100% + 9px);left:0;right:0;z-index:50;
  max-height:60vh;overflow-y:auto;
  background:var(--chrome-2);border:1px solid var(--line-2);border-radius:14px;
  box-shadow:var(--sh);padding:6px;
}
#resultEntete.search-dropdown ul{list-style:none;margin:0;padding:0}
#resultEntete.search-dropdown li{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;font-size:13px;color:var(--soft);cursor:pointer;transition:background .12s,color .12s}
#resultEntete.search-dropdown li:hover,
#resultEntete.search-dropdown li.is-active{background:var(--chrome-3);color:var(--on)}
#resultEntete.search-dropdown:empty{display:none}
/* bouton Créer */
.tcCreateBtn{
  flex-shrink:0;display:inline-flex;align-items:center;
  height:42px;padding:0 18px;gap:7px;border-radius:13px;
  font-weight:700;font-size:13.5px;color:#fff;
  background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));
  box-shadow:0 10px 22px -9px rgba(182,48,107,.85);
  transition:transform .14s,filter .14s,box-shadow .14s;
}
.tcCreateBtn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.tcCreateBtn:active{transform:translateY(0)}
.tcCreateBtn__plus{font-size:17px;font-weight:800;line-height:1;margin-top:-1px}

/* --- DROITE : horloge LIVE · notifs · messages · profil --- */
.tcHeader__right{display:flex;align-items:center;flex-shrink:0;gap:10px}
.tcClock{
  display:inline-flex;align-items:center;gap:9px;height:38px;padding:0 14px;border-radius:999px;
  background:var(--chrome-2);border:1px solid var(--line);
}
.tcClock__live{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--accent-2)}
.tcClock__pulse{width:7px;height:7px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 0 0 rgba(225,75,122,.55);animation:tcEntetePing 1.8s infinite}
@keyframes tcEntetePing{70%{box-shadow:0 0 0 7px rgba(225,75,122,0)}100%{box-shadow:0 0 0 0 rgba(225,75,122,0)}}
.tcClock__time{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--on)}

.tcIconBtn{position:relative;display:grid;place-items:center;width:38px;height:38px;border-radius:11px;border:1px solid transparent;color:var(--soft);font-size:16px;line-height:1;transition:background .15s,border-color .15s,color .15s}
.tcIconBtn:hover{background:var(--chrome-2);border-color:var(--line);color:var(--on)}
/* pastille par défaut (notif sans compteur) */
.tcIconBtn.js-open-notif::after{
  content:"";position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:50%;
  background:var(--accent-2);border:2px solid var(--chrome);animation:tcEntetePing 2.2s infinite;
}
.tcIconBtn.js-open-notif.is-empty::after{display:none;animation:none}
/* badge chiffré (cloche + messages) dès que data-count > 0 */
.tcIconBtn[data-count]:not([data-count="0"]):not([data-count=""])::after{
  content:attr(data-count);position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;
  display:grid;place-items:center;font-family:var(--ui);font-size:10.5px;font-weight:800;line-height:1;
  color:#fff;background:var(--accent-2);border:2px solid var(--chrome);border-radius:999px;animation:none;
}
/* profil (photo OU initiales) */
.tcProfile{display:flex;align-items:center;gap:10px;padding:4px 12px 4px 4px;border-radius:999px;border:1px solid var(--line);background:var(--chrome-2);transition:border-color .15s,background .15s}
.tcProfile:hover{border-color:var(--line-2);background:var(--chrome-3)}
.tcProfile>div{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.tcProfile__photo{width:34px;height:34px;border-radius:10px;object-fit:cover;flex-shrink:0;background:linear-gradient(135deg,var(--accent-deep),var(--gold))}
.tcProfile__avatar{width:34px;height:34px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px;font-family:var(--ui);background:linear-gradient(135deg,#8b5cf6,#6d28d9)}
.tcProfile__name{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.tcProfile__handle{font-size:10px;white-space:nowrap}
/* visiteur */
.tcHeader__btnLogin,
.tcHeader__btnRegister{display:inline-flex;align-items:center;height:40px;padding:0 16px;border-radius:12px;font-weight:700;font-size:13px;white-space:nowrap;transition:transform .14s,filter .14s,background .15s,border-color .15s,color .15s}
.tcHeader__btnLogin{color:var(--soft);border:1px solid var(--line-2);background:transparent}
.tcHeader__btnLogin:hover{color:var(--on);border-color:var(--soft);background:var(--chrome-2)}
.tcHeader__btnRegister{color:#fff;background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));box-shadow:0 8px 18px -8px rgba(182,48,107,.85)}
.tcHeader__btnRegister:hover{transform:translateY(-1px);filter:brightness(1.05)}

/* ============================================================
 * ENTÊTE — Responsive (hauteur fixée à 60px à tous les paliers)
 * ============================================================ */
@media (max-width:1100px){
  .tcHeader{gap:12px;padding:0 12px}
  .tcHeader__brandText{display:none}            /* logo seul */
  .tcHeaderSearch{max-width:none}
  .tcHeaderSearch::after{display:none}          /* on cache ⌘K */
}
@media (max-width:900px){
  .tcClock{display:none}                         /* horloge non essentielle */
  .tcCreateBtn{width:42px;padding:0;justify-content:center;gap:0}
  .tcCreateBtn__label{display:none}
  .tcCreateBtn__plus{font-size:22px;margin:0}
  .tcProfile{padding:0;border:none;background:none}
  .tcProfile>div{display:none}                   /* avatar seul */
  .tcProfile__photo,.tcProfile__avatar{width:36px;height:36px}
}
@media (max-width:820px){
  .tcHeader{gap:10px}
  .tcHeader .tcHeader__burger{display:grid}                /* burger réel → ouvre #rail */
  .tcHeader__center{gap:8px}
}
@media (max-width:560px){
  .tcHeader{gap:8px;padding:0 10px}
  .tcIconBtn[aria-label="Messages"]{display:none}
  .tcHeaderSearch{height:40px}
  #rechercheEntete{font-size:13px}
  #rechercheEntete::placeholder{font-size:12.5px}
}
@media (max-width:400px){
  .tcHeader__brand{padding:4px}
  .tcCreateBtn{display:none}                      /* création via la tabbar */
}


/* ============================================================================
 * OVERLAY + MODALE DE CAPTURE
 * ========================================================================== */
#overlayCapture{
  position:fixed;inset:0;z-index:2000;
  background:rgba(10,11,13,.62);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s ease,visibility .22s ease;
}
#overlayCapture.is-open{opacity:1;visibility:visible;pointer-events:auto;display:block !important}

.indexCapture{
  --m-bg:var(--chrome-2,#1C1E23);
  --m-bg-2:var(--chrome-3,#23262C);
  --m-bg-field:var(--chrome,#16171B);
  --m-line:var(--line,#2A2D34);
  --m-line-2:var(--line-2,#34373F);
  --m-on:var(--on,#ECEDE9);
  --m-soft:var(--soft,#9A9E98);
  --m-muted:var(--muted,#6C7069);
  --m-accent:var(--accent,#CA4A82);
  --m-accent-deep:var(--accent-deep,#B6306B);
  --m-accent-soft:var(--accent-soft,rgba(202,74,130,.16));
  --m-ui:var(--ui,"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,sans-serif);
  --m-r:14px;

  position:fixed;z-index:2001;top:50%;left:50%;
  width:min(560px,94vw);max-height:90vh;
  display:flex;flex-direction:column;
  background:var(--m-bg);color:var(--m-on);
  border:1px solid var(--m-line-2);border-radius:18px;
  box-shadow:0 30px 70px -25px rgba(0,0,0,.8),0 1px 0 rgba(255,255,255,.04) inset;
  font-family:var(--m-ui);

  /* ⭐ La modale scrolle elle-même si le contenu dépasse 90vh
        (fonctionne même sans conteneur .modal-body) */
  overflow-y:auto;
  overflow-x:hidden;
  overscroll-behavior:contain;        /* le scroll ne fuit pas vers la page */
  scroll-behavior:smooth;
  scrollbar-width:thin;               /* Firefox */
  scrollbar-color:var(--m-accent) transparent;

  opacity:0;visibility:hidden;pointer-events:none;
  transform:translate(-50%,-46%) scale(.97);
  transition:opacity .22s ease,transform .22s ease,visibility .22s ease;
}
.indexCapture.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,-50%) scale(1);display:flex !important}
.indexCapture *{box-sizing:border-box}
.indexCapture :focus-visible{outline:2px solid var(--m-accent);outline-offset:2px}

/* Scrollbar « joli » sur la modale (WebKit : Chrome / Edge / Safari) */
.indexCapture::-webkit-scrollbar{width:10px}
.indexCapture::-webkit-scrollbar-track{background:transparent;margin:8px 0}
.indexCapture::-webkit-scrollbar-thumb{
  background:linear-gradient(var(--m-accent),var(--m-accent-deep));
  border:2px solid transparent;            /* liseré transparent → thumb « flottant » plus fin */
  border-radius:999px;
  background-clip:padding-box;
}
.indexCapture::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(var(--m-accent-deep),var(--m-accent));
  background-clip:padding-box;
}

/* En-tête épinglé en haut pendant le scroll */
.indexCapture .modalHeader{
  position:sticky;top:0;z-index:3;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 18px;border-bottom:1px solid var(--m-line);
  background:var(--m-bg);          /* masque le contenu qui défile dessous */
  flex-shrink:0;
}
.indexCapture .modalHeader h2{margin:0;font-size:16px;font-weight:800;letter-spacing:-.01em}
.indexCapture #closeCapture{width:34px;height:34px;display:grid;place-items:center;border:none;border-radius:9px;background:var(--m-bg-2);color:var(--m-soft);font-size:20px;line-height:1;cursor:pointer;transition:background .15s,color .15s}
.indexCapture #closeCapture:hover{background:var(--m-accent-soft);color:#fff}

/* Corps : padding + scrollbar assorti SI un conteneur .modal-body existe.
   Sans .modal-body dans ton HTML, c'est la modale qui scrolle (voir plus haut). */
.indexCapture .modal-body{
  flex:1 1 auto;
  min-height:0;                 /* clé : autorise le rétrécissement → active le scroll */
  overflow-y:auto;
  overflow-x:hidden;
  overscroll-behavior:contain;
  scroll-behavior:smooth;
  padding:18px;
  display:flex;flex-direction:column;gap:16px;
  scrollbar-width:thin;
  scrollbar-color:var(--m-accent) transparent;
}
.indexCapture .modal-body::-webkit-scrollbar{width:10px}
.indexCapture .modal-body::-webkit-scrollbar-track{background:transparent;margin:8px 0}
.indexCapture .modal-body::-webkit-scrollbar-thumb{
  background:linear-gradient(var(--m-accent),var(--m-accent-deep));
  border:2px solid transparent;border-radius:999px;background-clip:padding-box;
}
.indexCapture .modal-body::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(var(--m-accent-deep),var(--m-accent));background-clip:padding-box;
}

.indexCapture label{display:block;margin-bottom:7px;font-size:12.5px;font-weight:600;color:var(--m-soft)}

.indexCapture .form-control{width:100%;padding:11px 13px;background:var(--m-bg-field);border:1px solid var(--m-line);border-radius:10px;color:var(--m-on);font:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}
.indexCapture .form-control::placeholder{color:var(--m-muted)}
.indexCapture .form-control:focus{outline:none;border-color:var(--m-accent);box-shadow:0 0 0 3px var(--m-accent-soft)}
.indexCapture textarea.form-control{resize:vertical;min-height:96px;line-height:1.5}

.indexCapture select.form-control{
  -webkit-appearance:none;appearance:none;padding-right:38px;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239A9E98' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right 13px center;
}
.indexCapture select.form-control option{background:var(--m-bg-field);color:var(--m-on)}

.indexCapture .choisirPays{position:relative}
.indexCapture #resultatPaysModale{margin-top:8px}
.indexCapture #resultatPaysModale ul{list-style:none;margin:0;padding:6px;max-height:200px;overflow-y:auto;background:var(--m-bg-field);border:1px solid var(--m-line-2);border-radius:11px;box-shadow:0 16px 30px -20px rgba(0,0,0,.7)}
.indexCapture #resultatPaysModale ul:empty{display:none}
/* scrollbar assorti pour la liste de pays */
.indexCapture #resultatPaysModale ul{scrollbar-width:thin;scrollbar-color:var(--m-accent) transparent}
.indexCapture #resultatPaysModale ul::-webkit-scrollbar{width:10px}
.indexCapture #resultatPaysModale ul::-webkit-scrollbar-track{background:transparent;margin:6px 0}
.indexCapture #resultatPaysModale ul::-webkit-scrollbar-thumb{background:linear-gradient(var(--m-accent),var(--m-accent-deep));border:2px solid transparent;border-radius:999px;background-clip:padding-box}
.indexCapture #resultatPaysModale ul::-webkit-scrollbar-thumb:hover{background:linear-gradient(var(--m-accent-deep),var(--m-accent));background-clip:padding-box}
.indexCapture #resultatPaysModale li{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;font-size:13px;color:var(--m-soft);cursor:pointer;transition:background .12s,color .12s}
.indexCapture #resultatPaysModale li:hover,
.indexCapture #resultatPaysModale li.is-active{background:var(--m-bg-2);color:var(--m-on)}

.indexCapture .tcMediaPick{display:flex;gap:4px;padding:4px;background:var(--m-bg-field);border:1px solid var(--m-line);border-radius:11px}
.indexCapture .tcMediaPick__btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 10px;border:none;border-radius:8px;background:none;color:var(--m-soft);font:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,color .15s}
.indexCapture .tcMediaPick__btn:hover{color:var(--m-on)}
.indexCapture .tcMediaPick__btn.is-active{background:linear-gradient(135deg,var(--m-accent),var(--m-accent-deep));color:#fff;box-shadow:0 6px 14px -7px rgba(182,48,107,.85)}
.indexCapture .tcMediaPick__icon{font-size:15px;line-height:1}

.indexCapture .custom-file-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;margin-top:12px;padding:22px 16px;text-align:center;background:var(--m-bg-field);border:1.5px dashed var(--m-line-2);border-radius:12px;color:var(--m-soft);cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.indexCapture .custom-file-upload:hover{border-color:var(--m-accent);background:var(--m-accent-soft);color:var(--m-on)}
.indexCapture .custom-file-upload svg{width:20px;height:20px;color:var(--m-accent)}
.indexCapture #tcUploadLabel{font-size:13.5px;font-weight:700;color:var(--m-on)}
.indexCapture .tcMediaHint{font-size:11px;color:var(--m-muted)}
.indexCapture .custom-file-upload input[type="file"],
.indexCapture #file{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

.indexCapture .image-preview{margin-top:12px}
.indexCapture .image-preview img{width:100%;max-height:280px;object-fit:cover;border-radius:12px;border:1px solid var(--m-line);background:var(--m-bg-field)}

/* Pied épinglé en bas pendant le scroll (le bouton Publier reste visible) */
.indexCapture .modalFooter{
  position:sticky;bottom:0;z-index:3;
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-top:1px solid var(--m-line);
  background:var(--m-bg);          /* masque le contenu qui défile dessous */
  flex-shrink:0;
}
.indexCapture #messageCapture{flex:1;min-width:0;font-size:12.5px;color:var(--m-soft)}
.indexCapture #messageCapture.is-error{color:#ff6b6b}
.indexCapture #messageCapture.is-success{color:var(--live,#34D27B)}
.indexCapture .loaderCapture{display:flex;align-items:center}
.indexCapture .loaderCapture img{width:26px;height:26px;animation:tcSpin .9s linear infinite}
@keyframes tcSpin{to{transform:rotate(360deg)}}
.indexCapture .post-button{margin-left:auto;padding:11px 20px;border:none;border-radius:11px;background:linear-gradient(135deg,var(--m-accent),var(--m-accent-deep));color:#fff;font:inherit;font-size:13.5px;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:0 10px 22px -10px rgba(182,48,107,.9);transition:transform .14s,filter .14s}
.indexCapture .post-button:hover{transform:translateY(-1px);filter:brightness(1.05)}
.indexCapture .post-button:active{transform:translateY(0)}
.indexCapture .post-button:disabled{opacity:.6;cursor:not-allowed;transform:none}
/* ===== vignettes-plats (motif de marque conservé) ===== */
.tile{position:relative;overflow:hidden;background:#cdbbaa}
.t-1{background:linear-gradient(135deg,#ff9a62,#e8541f)}
.t-2{background:linear-gradient(135deg,#7fc7a6,#1f8a5e)}
.t-3{background:linear-gradient(135deg,#f0b65a,#c8761a)}
.t-4{background:linear-gradient(135deg,#7eb6e0,#2f6aa8)}
.t-5{background:linear-gradient(135deg,#e887ab,#b23a68)}
.t-6{background:linear-gradient(135deg,#c9d36a,#7e9a2a)}
.tile::after{content:"";position:absolute;left:50%;top:54%;width:58%;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle at 38% 32%,rgba(255,255,255,.32),rgba(255,255,255,.05) 46%,transparent 62%),conic-gradient(from 200deg,rgba(0,0,0,.1),rgba(255,255,255,.12),rgba(0,0,0,.12),rgba(255,255,255,.08),rgba(0,0,0,.1));box-shadow:inset 0 2px 10px rgba(255,255,255,.25),inset 0 -8px 16px rgba(0,0,0,.22)}

/* ===== Indicateur LIVE (utilisé par le dock & le repère « maintenant ») ===== */
.live{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;letter-spacing:.08em;color:var(--live)}
.live .pulse{width:7px;height:7px;border-radius:50%;background:var(--live);box-shadow:0 0 0 0 rgba(52,210,123,.6);animation:ping 1.8s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(52,210,123,.55)}70%{box-shadow:0 0 0 7px rgba(52,210,123,0)}100%{box-shadow:0 0 0 0 rgba(52,210,123,0)}}


/* ============================================================================
 * APP SHELL (sous l'entête fixe de 60px)
 * ========================================================================== */
.app{
  display:grid;height:calc(100vh - 60px);height:calc(100dvh - 60px);
  grid-template-columns:var(--rail) 1fr;
  grid-template-rows:1fr var(--dock);
  grid-template-areas:"rail map" "rail dock";
}

/* ===== RAIL (gauche) ===== */
.rail{grid-area:rail;background:var(--chrome);border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0;overflow:hidden;z-index:30}
.rail .scroll{flex:1;overflow-y:auto;padding:12px 12px 8px;display:flex;flex-direction:column;gap:4px}
.nav-lbl{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 10px 6px}
.nav-lbl:first-child{padding-top:2px}
.nav a{display:flex;align-items:center;gap:12px;padding:9px 11px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--soft)}
.nav a .gi{width:18px;text-align:center;font-size:15px;filter:grayscale(.2)}
.nav a:hover{background:var(--chrome-2);color:var(--on)}
.nav a.on{background:var(--accent-soft);color:#fff}
.nav a.on .gi{filter:none}
.nav a .lab{white-space:nowrap;overflow:hidden}
.nav a .cnt{margin-left:auto;font-family:var(--mono);font-size:10.5px;color:var(--muted)}

.subtabs{display:flex;gap:2px;background:var(--chrome-2);border:1px solid var(--line);border-radius:10px;padding:3px;margin:6px 2px 8px}
.subtabs button{flex:1;font-size:11.5px;font-weight:700;color:var(--soft);padding:6px 4px;border-radius:7px;white-space:nowrap}
.subtabs button.on{background:var(--chrome-3);color:#fff}
.pane{display:none;flex-direction:column;gap:1px}
.pane.on{display:flex}
.row{display:flex;align-items:center;gap:10px;padding:8px 8px;border-radius:9px}
.row:hover{background:var(--chrome-2)}
.row .fl{font-size:17px;width:22px;text-align:center}
.row .av{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-weight:800;font-size:11px;color:#fff;flex-shrink:0}
.row .ci{flex:1;min-width:0}
.row .n{font-weight:700;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .h{font-family:var(--mono);font-size:10px;color:var(--muted)}
.row .go{font-size:11px;font-weight:700;color:#fff;background:var(--accent-deep);padding:5px 10px;border-radius:7px}
.row .go.out{background:none;color:var(--soft);border:1px solid var(--line-2)}
.row .go:hover{background:var(--accent)}

/* session card (bas du rail) */
.session{border-top:1px solid var(--line);padding:12px;background:var(--chrome)}
.session .u{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.session .u .av{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#B6306B,#E8A93C);display:grid;place-items:center;color:#fff;font-weight:800;font-size:12px}
.session .u .n{font-weight:700;font-size:13px}
.session .u .s{font-family:var(--mono);font-size:10px;color:var(--muted)}
.session .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.session .st{background:var(--chrome-2);border:1px solid var(--line);border-radius:9px;padding:8px 6px;text-align:center}
.session .st b{display:block;font-family:var(--mono);font-size:15px;font-weight:600;line-height:1}
.session .st.fire b{color:var(--accent-2)}
.session .st span{font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

/* ===== MAP (centre) ===== */
.map-area{grid-area:map;position:relative;min-height:0;background:var(--map-bg)}
#map{position:absolute;inset:0}
.leaflet-container{background:var(--map-bg);font-family:var(--ui)}
.leaflet-control-zoom{border:none!important;box-shadow:var(--sh)!important}
.leaflet-control-zoom a{background:var(--chrome-2)!important;color:var(--on)!important;border-color:var(--line)!important}
.leaflet-control-zoom a:hover{background:var(--chrome-3)!important}
.leaflet-control-attribution{background:rgba(22,23,27,.78)!important;color:var(--muted)!important}
.leaflet-control-attribution a{color:var(--soft)!important}
.leaflet-div-icon{background:none;border:none}

/* pins */
.pin{position:relative;display:flex;align-items:center;gap:5px;background:var(--chrome-2);border:1.5px solid var(--accent);border-radius:999px;padding:3px 9px 3px 5px;box-shadow:0 8px 18px -7px rgba(0,0,0,.7);font-family:var(--mono);font-size:11px;font-weight:600;color:var(--on);white-space:nowrap;transform:translateY(-4px);transition:transform .14s,border-color .14s}
.pin:hover,.pin.hot{transform:translateY(-7px);border-color:var(--gold)}
.pin .fl{font-size:13px}.pin .c{color:var(--accent-2)}
.pin::after{content:"";position:absolute;bottom:-6px;left:15px;width:9px;height:9px;background:var(--chrome-2);border-right:1.5px solid var(--accent);border-bottom:1.5px solid var(--accent);transform:rotate(45deg)}

/* overlays carte */
.map-overlay{position:absolute;z-index:500;pointer-events:none}
.map-overlay > *{pointer-events:auto}
.filters{top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;max-width:70%}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--on);background:var(--chrome-2);border:1px solid var(--line);border-radius:999px;padding:6px 11px;box-shadow:var(--sh)}
.chip:hover{border-color:var(--line-2)}
.chip.on{background:var(--accent-deep);border-color:var(--accent);color:#fff}
.chip .d{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.legend{bottom:14px;left:12px;background:var(--chrome-2);border:1px solid var(--line);border-radius:11px;padding:10px 12px;box-shadow:var(--sh);font-size:11px;color:var(--soft)}
.legend .lt{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.legend .lr{display:flex;align-items:center;gap:8px;margin-top:5px}
.legend .sw{width:10px;height:10px;border-radius:3px}
.statbox{top:12px;right:12px;background:var(--chrome-2);border:1px solid var(--line);border-radius:11px;padding:9px 13px;box-shadow:var(--sh);text-align:right}
.statbox .v{font-family:var(--mono);font-size:18px;font-weight:600;line-height:1}
.statbox .k{font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* ===== DOCK (frise temps réel) ===== */
.dock{grid-area:dock;background:var(--chrome);border-top:1px solid var(--line);display:flex;flex-direction:column;min-height:0;z-index:30}
.dock-head{display:flex;align-items:center;gap:12px;padding:11px 16px 9px;flex-shrink:0}
.dock-head h2{font-size:13.5px;font-weight:800;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.dock-head .live{font-size:9.5px}
.dock-head .meta{font-family:var(--mono);font-size:10.5px;color:var(--muted)}
.dock-head .seg{margin-left:auto;display:flex;gap:2px;background:var(--chrome-2);border:1px solid var(--line);border-radius:9px;padding:3px}
.dock-head .seg button{font-size:11.5px;font-weight:700;color:var(--soft);padding:5px 11px;border-radius:6px}
.dock-head .seg button.on{background:var(--chrome-3);color:#fff}

.track-wrap{flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;padding:0 16px 14px}
.track{display:flex;align-items:stretch;gap:0;height:100%;min-width:min-content}

/* repère MAINTENANT */
.nowhead{flex-shrink:0;width:78px;position:relative;display:flex;flex-direction:column;justify-content:center;padding-right:14px;margin-right:6px}
.nowhead::after{content:"";position:absolute;right:0;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--live),transparent);border-radius:2px}
.nowhead .lab{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--live);font-weight:600}
.nowhead .clk{font-family:var(--mono);font-size:13px;color:var(--on);margin-top:3px}
.nowhead .pulse{width:8px;height:8px;border-radius:50%;background:var(--live);margin-top:9px;box-shadow:0 0 0 0 rgba(52,210,123,.6);animation:ping 1.8s infinite}

/* ticks de temps entre buckets */
.tick{flex-shrink:0;width:64px;position:relative;display:flex;align-items:center;justify-content:center}
.tick::before{content:"";position:absolute;top:14px;bottom:18px;left:50%;width:1px;background:repeating-linear-gradient(180deg,var(--line-2) 0 4px,transparent 4px 9px)}
.tick span{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:var(--chrome);padding:3px 0;writing-mode:horizontal-tb;transform:rotate(0);position:relative;z-index:1}

/* cartes de la frise */
.tcard{flex-shrink:0;width:236px;height:100%;display:flex;flex-direction:column;background:var(--chrome-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-right:12px;box-shadow:var(--sh);transition:transform .15s,border-color .15s}
.tcard:hover{transform:translateY(-3px);border-color:var(--line-2)}
.tcard.focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(232,169,60,.35),var(--sh)}
.tcard .thumb{position:relative;height:84px;flex-shrink:0}
.tcard .thumb .tile{position:absolute;inset:0}
.tcard .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}        /* couvertures réelles */
.tcard .geo{position:absolute;top:7px;left:7px;display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;color:#1A1B18;background:rgba(255,255,255,.92);border-radius:999px;padding:3px 8px 3px 6px;max-width:calc(100% - 14px);z-index:2}
.tcard .geo .fl{font-size:11px}.tcard .geo .v{color:#6A6E66;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tcard .kind{position:absolute;top:7px;right:7px;font-size:9.5px;font-weight:800;letter-spacing:.03em;color:#fff;background:var(--accent-deep);border-radius:999px;padding:3px 8px;z-index:2}
.tcard .kind.explo{background:var(--gold);color:#3a2a06}
.tcard .bd{flex:1;min-height:0;display:flex;flex-direction:column;padding:9px 11px 8px}
.tcard h3{font-size:13.5px;font-weight:800;line-height:1.2;letter-spacing:-.01em;color:var(--on);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tcard h3 a{color:inherit;text-decoration:none}                                            /* titre cliquable */
.tcard .au{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:11px;color:var(--soft)}
.tcard .au .ca{width:17px;height:17px;border-radius:5px;display:grid;place-items:center;font-size:8px;font-weight:800;color:#fff;flex-shrink:0}
.tcard .au b{color:var(--on);font-weight:700}
.tcard .ago{font-family:var(--mono);font-size:9.5px;color:var(--muted);margin-left:auto;white-space:nowrap}
.tcard .foot{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:8px;font-family:var(--mono);font-size:10.5px;color:var(--muted)}
.tcard .foot .it{display:inline-flex;align-items:center;gap:5px}
.tcard .foot svg{width:13px;height:13px}
.tcard .foot .it.like{cursor:pointer}
.tcard .foot .it.like.on{color:var(--accent-2)}
.tcard .foot .it.like.on svg{fill:var(--accent-2)}
.tcard.live-card{border-color:var(--accent)}
.tcard.live-card::before{content:"";position:absolute}

/* tabbar mobile (affichée en responsive) */
.tabbar{display:none}


/* ============================================================================
 * COLONNE ACTIVITÉ (3e colonne de .app)
 * ========================================================================== */
@media (min-width:1080px){
  .app{
    grid-template-columns:var(--rail-w) minmax(0,1fr) var(--ca-w) !important;
    grid-template-rows:minmax(0,1fr) auto !important;
    grid-template-areas:"rail map act" "rail dock act" !important;
  }
  .app > .rail{grid-area:rail}
  .app > .map-area{grid-area:map}
  .app > .dock{grid-area:dock}
  .app > .console-activity{grid-area:act}
}
/* en dessous de 1080 : masquée ici, réaffichée empilée à ≤820 (plus bas) */
@media (max-width:1079px){
  .console-activity{display:none}
}

.console-activity{
  --ca-rose:var(--accent,#f5407a);
  --ca-gold:var(--gold,#f6a80c);
  --ca-green:var(--live,#2fe3a0);
  --ca-blue:#62a9ff;
  --ca-panel:#16131f;--ca-panel2:#1d1828;--ca-panel3:#241f32;
  --ca-line:rgba(255,255,255,.08);--ca-line2:rgba(255,255,255,.05);
  --ca-txt:#f4f2f8;--ca-txt2:#a8a3b6;--ca-txt3:#6e6980;
  --ca-bg:#0f0d15;

  display:flex;flex-direction:column;min-height:0;overflow:hidden;
  border-left:1px solid var(--ca-line);
  background:linear-gradient(180deg,rgba(255,255,255,.012),transparent 200px),var(--ca-bg);
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--ca-txt);
}
.ca-head{padding:18px 18px 0;display:flex;flex-direction:column;gap:14px}
.ca-title{display:flex;align-items:center;gap:10px}
.ca-title h2{font-size:18px;font-weight:700;letter-spacing:-.01em;margin:0}
.ca-live{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--ca-green);background:rgba(47,227,160,.1);padding:3px 8px;border-radius:7px}
.ca-live .pulse{width:6px;height:6px;border-radius:50%;background:var(--ca-green);box-shadow:0 0 0 0 rgba(47,227,160,.5);animation:caPulse 2s infinite}
@keyframes caPulse{100%{box-shadow:0 0 0 7px rgba(47,227,160,0)}}
.ca-gear{margin-left:auto;width:32px;height:32px;border-radius:9px;border:1px solid var(--ca-line2);display:grid;place-items:center;color:var(--ca-txt3);background:transparent;cursor:pointer}
.ca-gear svg{width:16px;height:16px}

.ca-tabs{display:flex;gap:4px;padding:4px;background:var(--ca-panel);border:1px solid var(--ca-line);border-radius:11px}
.ca-tabs button{flex:1;height:32px;border:0;border-radius:8px;cursor:pointer;font:600 12.5px/1 'Plus Jakarta Sans',sans-serif;color:var(--ca-txt3);background:transparent}
.ca-tabs button.on{background:var(--ca-panel3);color:var(--ca-txt)}
.ca-tabs button .n{font-size:10px;color:var(--ca-rose);font-weight:700;margin-left:4px}

.ca-feature{margin:14px 18px 2px;padding:12px;border-radius:14px;border:1px solid rgba(245,64,122,.22);background:linear-gradient(135deg,rgba(245,64,122,.10),rgba(245,64,122,.02))}
.ca-feature .lab{display:flex;align-items:center;gap:7px;margin-bottom:9px;font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--ca-rose)}
.ca-feature .lab svg{width:13px;height:13px}
.ca-feature .item{display:flex;align-items:center;gap:11px;text-decoration:none;color:inherit}
.ca-feature .th{width:46px;height:46px;border-radius:11px;flex:none;object-fit:cover;background:var(--ca-panel2)}
.ca-feature .nm{font-weight:600;font-size:13.5px}
.ca-feature .mt{display:flex;align-items:center;gap:6px;margin-top:3px;font-size:11.5px;color:var(--ca-txt2)}
.ca-feature .mt .fl{font-size:12px}

.ca-feed{flex:1;overflow-y:auto;padding:6px 14px 18px;display:flex;flex-direction:column;gap:2px}
.ca-feed::-webkit-scrollbar{width:8px}
.ca-feed::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:8px}
.ca-day{font-size:10px;font-weight:700;letter-spacing:.13em;color:var(--ca-txt3);padding:14px 6px 8px}
.ca-item{display:grid;grid-template-columns:38px 1fr;gap:12px;padding:11px 8px;border-radius:13px;text-decoration:none;color:inherit}
.ca-item:hover{background:var(--ca-panel)}
.ca-item.is-hidden{display:none}
.ca-ic{position:relative;width:38px;height:38px;flex:none}
.ca-ic .uav{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;font-family:'IBM Plex Mono','Plus Jakarta Sans',monospace}
.ca-ic .typ{position:absolute;right:-3px;bottom:-3px;width:18px;height:18px;border-radius:7px;display:grid;place-items:center;border:2.5px solid var(--ca-bg)}
.ca-ic .typ svg{width:10px;height:10px;color:#fff}
.ca-item[data-type="recette"] .typ{background:var(--ca-rose)}
.ca-item[data-type="commentaire"] .typ{background:var(--ca-green)}
.ca-item[data-type="like"] .typ{background:var(--ca-rose)}
.ca-item[data-type="exploration"] .typ{background:var(--ca-gold)}
.ca-item[data-type="live"] .typ{background:var(--ca-green)}
.ca-item[data-type="save"] .typ{background:var(--ca-blue)}
.ca-tx .l1{font-size:13px;line-height:1.4;color:var(--ca-txt)}
.ca-tx .l1 b{font-weight:600}
.ca-tx .l1 .rec{font-weight:600;color:var(--ca-rose)}
.ca-tx .quote{font-size:12.5px;color:var(--ca-txt2);font-style:italic;line-height:1.4;margin-top:5px;padding-left:10px;border-left:2px solid var(--ca-line)}
.ca-tx .thumb{margin-top:8px;width:100%;height:72px;border-radius:11px;object-fit:cover;display:block;background:var(--ca-panel2)}
.ca-tx .l2{display:flex;align-items:center;gap:9px;margin-top:6px;font-size:11.5px;color:var(--ca-txt3)}
.ca-tx .l2 .ctx{display:flex;align-items:center;gap:5px}
.ca-tx .l2 .ctx .fl{font-size:12px}
.ca-tx .l2 .time{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:11px}
.ca-empty{padding:40px 18px;text-align:center;color:var(--ca-txt3);font-size:13px}


/* ============================================================================
 * FOOTER (.siteFooter) — visiteur
 * ========================================================================== */
.siteFooter{
  --f-chrome:var(--chrome,#16171B);
  --f-chrome-2:var(--chrome-2,#1C1E23);
  --f-line:var(--line,#2A2D34);
  --f-line-2:var(--line-2,#34373F);
  --f-on:var(--on,#ECEDE9);
  --f-soft:var(--soft,#9A9E98);
  --f-muted:var(--muted,#6C7069);
  --f-accent:var(--accent,#CA4A82);
  --f-accent-2:var(--accent-2,#E14B7A);
  --f-accent-deep:var(--accent-deep,#B6306B);
  --f-gold:var(--gold,#E8A93C);
  --f-ui:var(--ui,"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",sans-serif);
  --f-mono:var(--mono,"IBM Plex Mono",ui-monospace,monospace);
  background:radial-gradient(120% 150% at 0% 0%,rgba(202,74,130,.08),transparent 55%),var(--f-chrome);
  border-top:1px solid var(--f-line);color:var(--f-soft);font-family:var(--f-ui);line-height:1.5;-webkit-font-smoothing:antialiased;
}
.siteFooter *,.siteFooter *::before,.siteFooter *::after{box-sizing:border-box}
.siteFooter a{color:inherit;text-decoration:none}
.siteFooter h4{margin:0}
.siteFooter ul{list-style:none;margin:0;padding:0}
.siteFooter__top{max-width:1200px;margin:0 auto;padding:54px 24px 38px;display:grid;grid-template-columns:1.5fr 2.4fr;gap:48px}
.siteFooter__brand{max-width:360px}
.siteFooter__logo{display:inline-flex;align-items:center;gap:10px;margin-bottom:14px}
.siteFooter__logoMark{width:34px;height:34px;display:grid;place-items:center;border-radius:9px;background:linear-gradient(135deg,var(--f-accent-deep),var(--f-gold));color:#fff;font-weight:800;font-size:13px;letter-spacing:.02em;box-shadow:0 8px 18px -6px rgba(182,48,107,.7)}
.siteFooter__logoText{font-size:18px;font-weight:800;color:var(--f-on);letter-spacing:-.02em}
.siteFooter__tagline{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.04em;color:var(--f-gold);margin:0 0 12px}
.siteFooter__desc{font-size:13.5px;line-height:1.65;color:var(--f-soft);margin:0 0 20px}
.siteFooter__socials{display:flex;flex-wrap:wrap;gap:10px}
.siteFooter__social{display:inline-flex;align-items:center;gap:8px;padding:7px 13px 7px 7px;border-radius:999px;border:1px solid var(--f-line);background:var(--f-chrome-2);font-size:12.5px;font-weight:700;color:var(--f-soft);transition:color .15s,border-color .15s,transform .15s,background .15s}
.siteFooter__social svg{width:20px;height:20px;flex-shrink:0}
.siteFooter__social:hover{color:var(--f-on);border-color:var(--f-line-2);background:var(--f-chrome);transform:translateY(-1px)}
.siteFooter__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.siteFooter__title{font-size:13px;font-weight:800;color:var(--f-on);letter-spacing:-.01em;margin:0 0 16px;padding-bottom:10px;position:relative}
.siteFooter__title::after{content:"";position:absolute;left:0;bottom:0;width:24px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--f-accent),var(--f-gold))}
.siteFooter__col ul{display:flex;flex-direction:column;gap:11px}
.siteFooter__col a{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--f-soft);transition:color .15s,transform .15s}
.siteFooter__col a:hover{color:var(--f-on);transform:translateX(2px)}
.siteFooter__count{font-family:var(--f-mono);font-size:10.5px;color:var(--f-muted);background:var(--f-chrome-2);border:1px solid var(--f-line);border-radius:999px;padding:1px 8px;transition:color .15s,border-color .15s}
.siteFooter__col a:hover .siteFooter__count{color:var(--f-on);border-color:var(--f-line-2)}
.siteFooter__bar{border-top:1px solid var(--f-line);max-width:1200px;margin:0 auto;padding:18px 24px 28px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.siteFooter__copy{font-size:12px;color:var(--f-muted);margin:0}
.siteFooter__barLinks{display:flex;gap:18px;font-size:12px}
.siteFooter__barLinks a{color:var(--f-soft)}
.siteFooter__barLinks a:hover{color:var(--f-on)}


/* ============================================================================
 * RESPONSIVE — console (rail, carte, dock, activité, tabbar)
 * ========================================================================== */

/* ≤1079 : rail en icônes (la colonne Activité est déjà masquée plus haut) */
@media (max-width:1079px){
  :root{--rail:64px}
  .nav a .lab,.nav a .cnt,.nav-lbl,.subtabs,.pane,.session .grid,.session .u .ci{display:none}
  .nav a{justify-content:center;padding:11px 0}
  .session{padding:10px;display:flex;justify-content:center}
  .session .u{margin:0}
  .session .u .av{margin:0}
}

/* ≤820 : pile verticale + rail en tiroir + tabbar + Activité empilée */
@media (max-width:820px){
  .app{display:flex;flex-direction:column;height:auto;min-height:calc(100vh - 60px);min-height:calc(100dvh - 60px)}

  .rail{position:fixed;top:60px;left:0;bottom:0;width:280px;transform:translateX(-100%);transition:transform .25s;border-right:1px solid var(--line);z-index:990}
  .rail.open{transform:none;box-shadow:0 0 0 100vmax rgba(0,0,0,.5)}
  .rail .scroll{padding:14px}
  .nav a .lab,.nav a .cnt,.nav-lbl,.subtabs,.pane,.session .grid,.session .u .ci{display:revert}
  .nav a{justify-content:flex-start;padding:9px 11px}
  .session{display:block}

  .map-area{height:46vh;min-height:300px;flex-shrink:0}
  .dock{height:auto}
  .track-wrap{padding-bottom:18px}

  /* colonne Activité : empilée sous le dock, scroll interne */
  .console-activity{display:flex !important;max-height:72vh;border-left:none;border-top:1px solid var(--ca-line,rgba(255,255,255,.08))}
  .ca-head{position:sticky;top:0;z-index:2;background:var(--ca-bg,#0f0d15);padding-bottom:12px}

  /* tabbar mobile */
  .tabbar{display:flex;position:sticky;bottom:0;z-index:35;background:var(--chrome);border-top:1px solid var(--line);padding:6px 4px;justify-content:space-around}
  .tabbar a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:9.5px;font-weight:700;color:var(--muted);padding:5px 10px;border-radius:9px}
  .tabbar a .gi{font-size:18px}
  .tabbar a.on{color:#fff;background:var(--accent-soft)}

  .filters{max-width:calc(100% - 24px)}
  .statbox{display:none}
}

/* ≤520 : allègements carte/dock */
@media (max-width:520px){
  .dock-head .meta{display:none}
  .legend{display:none}
}


/* ============================================================================
 * FOOTER — responsive
 * ========================================================================== */
@media (max-width:880px){
  .siteFooter__top{grid-template-columns:1fr;gap:38px}
  .siteFooter__brand{max-width:none}
}
@media (max-width:560px){
  .siteFooter__top{padding:42px 18px 30px}
  .siteFooter__nav{grid-template-columns:1fr 1fr;gap:26px}
  .siteFooter__bar{flex-direction:column;align-items:flex-start;padding:16px 18px 26px}
}
@media (max-width:380px){
  .siteFooter__nav{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
/* ============================================================================
 * ⭐ MES FILS — chips d'abonnements dans la frise + section dépliée
 * Ajout vue membre. Réutilise les variables :root existantes.
 * N'affecte ni le header/recherche, ni la modale, ni la carte.
 * ========================================================================== */
@keyframes tcmPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* --- Rangée de chips dans la frise (.dock) --- */
.subrail{display:flex;align-items:center;gap:7px;padding:2px 16px 10px;overflow-x:auto;flex-shrink:0;scrollbar-width:thin}
.subrail::-webkit-scrollbar{height:6px}
.subrail .lbl{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);white-space:nowrap;margin-right:2px}
.subrail .fchip{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;font-size:12px;font-weight:700;color:var(--on);background:var(--chrome-2);border:1px solid var(--line);border-radius:999px;padding:5px 11px;cursor:pointer}
.subrail .fchip .n{font-family:var(--mono);font-size:9.5px;color:var(--muted);font-weight:600}
.subrail .fchip .fl{font-size:13px}
.subrail .fchip:hover{border-color:var(--line-2)}
.subrail .fchip.on{background:var(--accent-deep);border-color:var(--accent);color:#fff}
.subrail .fchip.on .n{color:rgba(255,255,255,.8)}
.subrail .fchip.sub{color:var(--gold);border-color:rgba(232,169,60,.35);background:rgba(232,169,60,.1)}
.subrail .fchip.ghost{color:var(--soft);background:none;border-style:dashed}
.subrail .sep{width:1px;height:18px;background:var(--line-2);flex:none;margin:0 1px}

/* --- Section « Mes fils » (sous la console) --- */
.tcm-feeds{position:relative;background:var(--chrome);padding:0 0 56px}
.tcm-feeds::before{content:"";display:block;height:1px;max-width:1320px;margin:0 auto;background:linear-gradient(90deg,transparent,var(--line-2),transparent)}
.tcm-wrap{max-width:1320px;margin:0 auto;padding:0 22px}
.tcm-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin:26px 0 14px}
.tcm-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:9px}
.tcm-eyebrow::before{content:"";width:24px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.tcm-h2{font-family:var(--ui);font-size:26px;font-weight:800;letter-spacing:-.02em;margin-top:8px;color:var(--on)}
.tcm-sub{color:var(--soft);font-size:13.5px;margin-top:6px;max-width:60ch;line-height:1.5}
.tcm-livepill{display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border-radius:999px;background:rgba(52,210,123,.12);border:1px solid rgba(52,210,123,.3);color:var(--live);font-weight:800;font-size:11.5px;font-family:var(--mono);letter-spacing:.1em;height:fit-content}
.tcm-dot{width:8px;height:8px;border-radius:50%;background:var(--live);box-shadow:0 0 0 4px rgba(52,210,123,.18),0 0 12px 1px var(--live);animation:tcmPulse 1.6s infinite}
.tcm-rowhead{display:flex;align-items:center;gap:12px;margin:22px 0 12px}
.tcm-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:17px;background:var(--accent-soft);border:1px solid var(--line-2);flex:0 0 auto}
.tcm-ic--theme{background:rgba(232,169,60,.15)}
.tcm-ic--sub{background:rgba(232,169,60,.12);color:var(--gold);font-size:14px}
.tcm-rowhead h3{font-family:var(--ui);font-size:18px;font-weight:800;letter-spacing:-.01em;color:var(--on)}
.tcm-tag{color:var(--gold);font-size:12.5px;font-weight:700}
.tcm-k{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.04em;margin-top:1px}
.tcm-more{margin-left:auto;font-weight:700;font-size:12.5px;color:var(--accent-2)}
.tcm-rlive{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9.5px;color:var(--live);letter-spacing:.08em;text-transform:uppercase}
.tcm-rlive i,.tcm-cfeed__live i{width:6px;height:6px;border-radius:50%;background:var(--live);box-shadow:0 0 8px 1px var(--live);animation:tcmPulse 1.6s infinite}
.tcm-countries{display:flex;gap:13px;overflow-x:auto;scroll-snap-type:x proximity;padding-bottom:8px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.tcm-countries::-webkit-scrollbar{height:7px}.tcm-countries::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}.tcm-countries::-webkit-scrollbar-track{background:transparent}
.tcm-cfeed{background:var(--chrome-2);border:1px solid var(--line);border-radius:15px;overflow:hidden;display:flex;flex-direction:column;flex:0 0 300px;scroll-snap-align:start;align-self:flex-start}
.tcm-cfeed__top{display:flex;align-items:center;gap:9px;padding:11px 13px;border-bottom:1px solid var(--line)}
.tcm-flag{font-size:20px;line-height:1;flex:0 0 auto}
.tcm-cfeed__id{flex:1;min-width:0}
.tcm-cfeed__name{font-weight:800;font-size:14px;color:var(--on);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tcm-cfeed__sub{font-family:var(--mono);font-size:9.5px;color:var(--muted)}
.tcm-cfeed__live{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:8.5px;color:var(--live);text-transform:uppercase}
.tcm-cfeed__item{display:flex;align-items:center;gap:9px;padding:9px 13px;border-top:1px solid rgba(255,255,255,.05)}
.tcm-cfeed__item:hover{background:var(--chrome-3)}
.tcm-thumb{width:38px;height:38px;border-radius:9px;flex:0 0 auto;object-fit:cover;background:var(--chrome-3)}
.tcm-cfeed__meta{min-width:0}
.tcm-cfeed__t{font-weight:600;font-size:12px;color:var(--on);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tcm-cfeed__d{font-family:var(--mono);font-size:9.5px;color:var(--muted);margin-top:2px}
.tcm-cfeed__empty{padding:13px;font-size:11.5px;color:var(--muted);text-align:center}
.tcm-cfeed--add{flex:0 0 220px;align-self:stretch;align-items:center;justify-content:center;text-align:center;gap:7px;border-style:dashed;background:rgba(255,255,255,.02);color:var(--soft);padding:16px;text-decoration:none}
.tcm-plus{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:20px;background:var(--accent-soft);color:var(--accent-2)}
.tcm-cfeed--add b{font-size:13px;color:var(--on)}
.tcm-addsub{font-size:10.5px;color:var(--muted)}
.tcm-feedrow{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x proximity;padding-bottom:8px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.tcm-feedrow::-webkit-scrollbar{height:7px}.tcm-feedrow::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}.tcm-feedrow::-webkit-scrollbar-track{background:transparent}
.tcm-card{flex:0 0 252px;scroll-snap-align:start;background:var(--chrome-2);border:1px solid var(--line);border-radius:15px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
.tcm-card:hover{transform:translateY(-3px);border-color:var(--line-2)}
.tcm-card__cover{position:relative;height:120px;background:var(--chrome-3)}
.tcm-card__cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tcm-card__cover::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,8,11,.5),transparent 55%)}
.tcm-chip{position:absolute;z-index:2;font-family:var(--mono);font-size:10px;font-weight:700;border-radius:999px;padding:3px 8px;background:rgba(12,13,17,.72);border:1px solid var(--line-2);color:var(--on)}
.tcm-chip--flag{left:8px;top:8px}
.tcm-chip--time{right:8px;top:8px;color:var(--gold)}
.tcm-card__body{padding:10px 12px 11px;display:flex;flex-direction:column;gap:7px;flex:1}
.tcm-card__title{font-weight:800;font-size:14px;line-height:1.2;color:var(--on);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tcm-card__author{display:flex;align-items:center;gap:6px;color:var(--soft);font-size:11.5px}
.tcm-av{width:20px;height:20px;border-radius:6px;display:grid;place-items:center;font-weight:800;font-size:8px;color:#fff;flex:0 0 auto}
.tcm-card__foot{margin-top:auto;padding-top:8px;border-top:1px solid rgba(255,255,255,.06);font-family:var(--mono);font-size:10.5px;color:var(--muted)}
.tcm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-top:24px}
.tcm-stat{background:var(--chrome-2);border:1px solid var(--line);border-radius:13px;padding:16px;text-align:center}
.tcm-stat .v{font-family:var(--mono);font-size:23px;color:var(--on);line-height:1}
.tcm-stat .l{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:5px}
@media (max-width:1000px){.tcm-stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.tcm-cfeed{flex:0 0 84vw}.tcm-card{flex:0 0 70vw}.tcm-stats{grid-template-columns:repeat(2,1fr)}.tcm-h2{font-size:22px}}

/* ============================================================================
 * ⭐ MISE EN PAGE MEMBRE v2 — colonnes figées + centre scrollable
 * Rail (gauche) & Activité (droite) en sticky pleine hauteur ; la colonne
 * centrale #stream défile : menu+options → carte → frise → « Mes fils ».
 * Override des règles grid précédentes. N'affecte ni header/recherche,
 * ni modale, ni vue visiteur.
 * ========================================================================== */
.app{display:flex;align-items:flex-start;height:auto;min-height:calc(100vh - 60px);min-height:calc(100dvh - 60px)}
.center{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;background:var(--chrome)}

/* Barre horizontale : menu + options, au-dessus de la carte (collante) */
.tcbar{display:flex;align-items:center;gap:14px;padding:9px 16px;background:var(--chrome)}
.tcbar__menu{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none}
.tcbar__menu::-webkit-scrollbar{display:none}
.tcbar__menu a{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;padding:8px 13px;border-radius:10px;font-weight:700;font-size:13px;color:var(--soft);border:1px solid transparent;transition:background .14s,color .14s,border-color .14s}
.tcbar__menu a .gi{font-size:15px}
.tcbar__menu a:hover{background:var(--chrome-2);color:var(--on)}
.tcbar__menu a.on{background:var(--accent-soft);border-color:rgba(202,74,130,.4);color:#fff}
.tcbar__opts{margin-left:auto;display:flex;align-items:center;gap:14px;flex-shrink:0}
.tcbar__stat{font-family:var(--mono);font-size:11px;color:var(--muted);white-space:nowrap}
.tcbar__stat b{color:var(--on);font-size:13px;font-weight:600}
.tcbar__cta{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:8px 14px;border-radius:10px;font-weight:700;font-size:12.5px;color:#fff;background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));box-shadow:0 8px 18px -10px rgba(182,48,107,.9)}
.tcbar__cta:hover{filter:brightness(1.06)}

@media (min-width:1080px){
  .app{flex-direction:row}
  .app > .rail{position:sticky;top:var(--tc-head,60px);height:calc(100vh - var(--tc-head,60px));height:calc(100dvh - var(--tc-head,60px));flex:0 0 var(--rail);overflow-y:auto;overflow-x:hidden}
  .app > .console-activity{position:sticky;top:var(--tc-head,60px);height:calc(100vh - var(--tc-head,60px));height:calc(100dvh - var(--tc-head,60px));flex:0 0 var(--ca-w);overflow-y:auto;display:flex !important;border-left:1px solid var(--line)}
  .center > .map-area{height:clamp(440px,66vh,720px);flex:0 0 auto}
  .center > .dock{height:300px;flex:0 0 auto}
  .center > .tcm-feeds{flex:0 0 auto}
}
@media (max-width:1079px){
  .center{width:100%}
  .tcbar{position:static}
}
@media (max-width:560px){
  .tcbar{flex-wrap:wrap;gap:8px}
  .tcbar__opts{width:100%;justify-content:space-between}
}

/* alignement entête + barre « Mes fils » au-dessus de la carte */
body{padding-top:var(--tc-head,60px)}
.center > .subrail{padding:10px 16px;background:var(--chrome);border-bottom:1px solid var(--line);flex:0 0 auto}
.center > .subrail .lbl{margin-right:4px}