:root{
  --ink:#16140f; --ink-2:#1f1c15; --ink-3:#2a261d;
  --cream:#f3ece0; --cream-dim:#bdb4a3; --line:#3a352a;
  --flame:#e8743b; --flame-2:#f2954f; --moss:#86946a; --maxw:1180px;
  color-scheme: dark; /* widgets natifs (calendrier datetime-local, etc.) en mode sombre — rend l'icône du calendrier visible */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--ink); color:var(--cream); font-family:"Newsreader",Georgia,serif; font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden;}
.topo{position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.16}
.grain{position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05; mix-blend-mode:overlay}
.wrap{position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:0 22px}

header.site{padding:26px 0 0}
.bar{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
.brand{display:flex; align-items:baseline; gap:12px; cursor:pointer}
.brand .glyph{font-family:"Anton",sans-serif; font-size:34px; letter-spacing:.5px; line-height:.8; color:var(--cream); text-transform:uppercase;}
.brand .glyph b{color:var(--flame)}
.brand small{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:3px; color:var(--cream-dim); text-transform:uppercase}
.actions{display:flex; gap:10px; align-items:center}
.btn{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:1.5px; text-transform:uppercase; background:var(--flame); color:#1a0f06; border:none; padding:13px 20px; border-radius:2px; cursor:pointer; font-weight:600; transition:transform .15s ease, background .2s ease;}
.btn:hover{background:var(--flame-2); transform:translateY(-2px)}
.btn.ghost{background:transparent; color:var(--cream); border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--flame); color:var(--flame); background:transparent}
.btn.ghost .mini-av{width:20px;height:20px;border-radius:50%;object-fit:cover;margin-right:-4px;vertical-align:middle}
.btn.link{background:transparent;border:none;color:var(--cream-dim);padding:13px 6px}
.btn.link:hover{color:var(--flame);transform:none;background:transparent}

.hero{padding:64px 0 38px; max-width:880px}
.hero h1{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:clamp(52px,9vw,116px); line-height:.86; letter-spacing:.5px; margin:0 0 22px;}
.hero h1 .out{color:transparent; -webkit-text-stroke:1.5px var(--cream-dim)}
.hero h1 em{font-style:normal; color:var(--flame)}
.hero p{font-size:clamp(18px,2.2vw,23px); color:var(--cream-dim); max-width:660px; margin:0 0 30px}
.hero p .em{color:var(--cream); font-style:italic}
.manifest{display:flex; gap:26px; flex-wrap:wrap; font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:1px; color:var(--cream-dim); text-transform:uppercase}
.manifest span{display:flex; align-items:center; gap:8px}
.manifest .dot{width:6px; height:6px; background:var(--flame); border-radius:50%}
.hero .signature{font-family:"JetBrains Mono",monospace; font-size:13px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); margin:0 0 18px}
.hero .signature .out{color:transparent; -webkit-text-stroke:1px var(--moss)}
.hero .signature em{font-style:normal; color:var(--flame)}

/* ---------- Bandeau « 3 piliers » ---------- */
.pillars{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; padding:8px 0 12px}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}
.pillar{background:var(--ink-2); border:1px solid var(--line); border-radius:6px; padding:22px 20px; cursor:pointer; transition:transform .18s ease, border-color .18s ease; display:flex; flex-direction:column; gap:8px}
.pillar:hover{transform:translateY(-3px); border-color:var(--flame)}
.pillar:focus-visible{outline:2px solid var(--flame-2); outline-offset:2px}
.pillar-ic{font-size:26px}
.pillar h3{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:20px; line-height:1.05; letter-spacing:.4px; margin:0}
.pillar p{color:var(--cream-dim); font-size:14.5px; line-height:1.5; margin:0; flex:1}
.pillar-cta{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--flame-2)}

/* ---------- Section « Sorties à venir » (accueil) ---------- */
.home-events{border-top:1px solid var(--line); margin-top:30px; padding:26px 0 4px}
.home-events .evt-list{margin-top:4px}

.toolbar{display:flex; align-items:center; gap:16px; flex-wrap:wrap; border-top:1px solid var(--line); padding:22px 0 14px; margin-top:30px}
.search{flex:1; min-width:220px; background:var(--ink-2); border:1px solid var(--line); color:var(--cream); border-radius:3px; padding:12px 14px; font-family:"Newsreader",serif; font-size:16px; outline:none}
.search:focus{border-color:var(--flame)}
.fsel{background:var(--ink-2); border:1px solid var(--line); color:var(--cream); border-radius:3px; padding:12px 14px; font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.5px; outline:none; cursor:pointer; max-width:250px}
.fsel:focus{border-color:var(--flame)}
.count{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--cream-dim); letter-spacing:1px; white-space:nowrap; margin-left:auto}
.filterbar{display:flex; gap:34px; flex-wrap:wrap; padding-bottom:8px}
.fgroup{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
.flabel{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--moss)}
.chips{display:flex; gap:8px; flex-wrap:wrap}
.chip{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:1px; text-transform:uppercase; padding:7px 13px; border:1px solid var(--line); border-radius:100px; background:transparent; color:var(--cream-dim); cursor:pointer; transition:all .18s ease;}
.chip:hover{color:var(--cream); border-color:var(--cream-dim)}
.chip.on{background:var(--cream); color:var(--ink); border-color:var(--cream)}

.feed{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:26px 0 90px}
@media(max-width:880px){.feed{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.feed{grid-template-columns:1fr}}
.card{background:var(--ink-2); border:1px solid var(--line); border-radius:4px; overflow:hidden; cursor:pointer; display:flex; flex-direction:column; transition:transform .2s ease, border-color .2s ease; opacity:0; transform:translateY(14px); animation:rise .55s ease forwards;}
@keyframes rise{to{opacity:1; transform:none}}
.card:hover{transform:translateY(-4px); border-color:var(--flame)}
.thumb{aspect-ratio:4/3; position:relative; overflow:hidden; background:var(--ink-3)}
.thumb img{width:100%; height:100%; object-fit:cover; display:block}
.thumb .ph{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:"Anton",sans-serif; font-size:64px; color:#473f30;}
.tag{position:absolute; top:12px; left:12px; font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; background:rgba(22,20,15,.82); color:var(--flame-2); padding:6px 10px; border-radius:2px; backdrop-filter:blur(3px)}
.tag.region{top:auto; bottom:12px; left:12px; color:var(--cream);}
.card .body{padding:16px 17px 18px; display:flex; flex-direction:column; gap:9px; flex:1}
.card h3{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:21px; line-height:1.02; letter-spacing:.4px; margin:2px 0 0}
.byline{font-family:"JetBrains Mono",monospace; font-size:10.5px; letter-spacing:.5px; color:var(--cream-dim); text-transform:uppercase; display:flex; align-items:center; gap:7px; flex-wrap:wrap}
.byline .who{color:var(--flame-2); cursor:pointer}
.byline .who:hover{text-decoration:underline}
.av{width:22px; height:22px; border-radius:50%; object-fit:cover; background:var(--ink-3); display:inline-flex; align-items:center; justify-content:center; font-family:"Anton",sans-serif; font-size:11px; color:var(--moss); flex:0 0 auto}
.metrics{display:flex; gap:9px; font-family:"JetBrains Mono",monospace; font-size:12px; color:var(--moss); flex-wrap:wrap; align-items:center}
.metrics b{color:var(--cream); font-weight:600}
.metrics .sep{color:var(--line)}
.excerpt{color:var(--cream-dim); font-size:15px; line-height:1.5; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden}
.foot{margin-top:auto; padding-top:10px; display:flex; gap:16px; font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--cream-dim); letter-spacing:.5px}
.foot span{display:flex; align-items:center; gap:5px}

.scrim{position:fixed; inset:0; z-index:50; background:rgba(8,7,4,.74); backdrop-filter:blur(4px); display:none; align-items:flex-start; justify-content:center; padding:36px 18px; overflow:auto}
.scrim.open{display:flex}
.modal{background:var(--ink-2); border:1px solid var(--line); border-radius:6px; width:100%; max-width:760px; position:relative; animation:rise .4s ease forwards}
.modal .x{position:absolute; top:14px; right:14px; z-index:3; background:rgba(22,20,15,.7); border:1px solid var(--line); color:var(--cream); width:38px; height:38px; border-radius:50%; cursor:pointer; font-size:18px; line-height:1}
.modal .x:hover{border-color:var(--flame); color:var(--flame)}
.hero-img{width:100%; aspect-ratio:16/9; object-fit:cover; display:block; border-radius:6px 6px 0 0; background:var(--ink-3)}
.hero-img.ph{display:flex; align-items:center; justify-content:center; font-family:"Anton",sans-serif; font-size:96px; color:#473f30}
.mbody{padding:30px 34px 34px}
.mbody .tag{position:static; display:inline-block; margin-bottom:14px}
.mbody h2{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:clamp(30px,5vw,46px); line-height:.94; margin:0 0 10px}
.mbody .byline{margin-bottom:14px; font-size:12px}
.attrs{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:20px}
.attr{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; border:1px solid var(--line); color:var(--cream-dim); padding:6px 11px; border-radius:100px}
.attr b{color:var(--flame-2); font-weight:600}
.mmetrics{display:flex; gap:28px; flex-wrap:wrap; padding:16px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:22px}
.mmetrics div{display:flex; flex-direction:column; gap:3px}
.mmetrics .k{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--cream-dim)}
.mmetrics .v{font-family:"JetBrains Mono",monospace; font-size:20px; color:var(--flame)}
.map{width:100%; height:280px; border-radius:5px; margin-bottom:22px; border:1px solid var(--line); background:var(--ink-3); z-index:0}
.narrative{font-size:18px; line-height:1.75; white-space:pre-wrap; color:#e7e0d2}
.inspire-row{display:flex; align-items:center; gap:14px; margin:18px 0 8px; flex-wrap:wrap}
.inspire{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:1px; text-transform:uppercase; background:transparent; border:1px solid var(--flame); color:var(--flame); padding:11px 18px; border-radius:100px; cursor:pointer; transition:all .18s; display:inline-block}
.inspire:hover{background:var(--flame); color:#1a0f06}
.inspire.done{background:var(--flame); color:#1a0f06}

.comments{margin-top:30px; border-top:1px solid var(--line); padding-top:24px}
.comments h4{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--cream-dim); margin:0 0 18px}
.cmt{padding:14px 0; border-bottom:1px solid var(--line)}
.cmt .who{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px; color:var(--flame-2); text-transform:uppercase; margin-bottom:4px}
.cmt .who time{color:var(--cream-dim); margin-left:8px}
.cmt p{margin:0; color:#ddd5c6; font-size:16px; line-height:1.55}
.cmt-empty{color:var(--cream-dim); font-style:italic; font-size:15px}
.cmt-form{margin-top:20px; display:flex; flex-direction:column; gap:10px}

label.f{display:block; font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--cream-dim); margin:0 0 6px}
input,select,textarea{width:100%; background:var(--ink); border:1px solid var(--line); color:var(--cream); border-radius:3px; padding:11px 13px; font-family:"Newsreader",serif; font-size:16px; outline:none; transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--flame)}
textarea{resize:vertical; min-height:80px; line-height:1.55}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}
.field{margin-bottom:16px}
.fiche{border:1px solid var(--line); border-radius:5px; padding:18px 18px 2px; margin-bottom:20px; background:var(--ink-3)}
.fiche-head{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); margin-bottom:3px}
.fiche-sub{font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--cream-dim); margin-bottom:16px; letter-spacing:.3px}
.drop{border:1.5px dashed var(--line); border-radius:4px; padding:22px; text-align:center; cursor:pointer; transition:border-color .15s; color:var(--cream-dim); font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.5px}
.drop:hover{border-color:var(--flame); color:var(--cream)}
.drop img{max-height:160px; border-radius:3px; margin-top:6px}
.err{color:var(--flame); font-family:"JetBrains Mono",monospace; font-size:12px; margin-top:6px}

.avatar-lg{width:96px; height:96px; border-radius:50%; object-fit:cover; background:var(--ink-3); display:flex; align-items:center; justify-content:center; font-family:"Anton",sans-serif; font-size:42px; color:var(--moss); flex:0 0 auto; border:2px solid var(--line)}
.prof-head{display:flex; gap:24px; align-items:flex-start; flex-wrap:wrap}
.prof-head h2{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:40px; margin:0 0 8px; line-height:.95}
.prof-head .bio{color:var(--cream-dim); margin:0 0 16px; max-width:460px}
.prof-stats{display:flex; gap:30px; margin-bottom:6px}
.prof-stats div{display:flex; flex-direction:column}
.prof-stats .v{font-family:"JetBrains Mono",monospace; font-size:24px; color:var(--flame)}
.prof-stats .k{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--cream-dim)}
.prof-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; border-top:1px solid var(--line); padding-top:24px}
@media(max-width:560px){.prof-grid{grid-template-columns:1fr}}
.mini{display:flex; gap:12px; background:var(--ink); border:1px solid var(--line); border-radius:4px; overflow:hidden; cursor:pointer; transition:border-color .18s}
.mini:hover{border-color:var(--flame)}
.mini .mt{width:78px; height:78px; object-fit:cover; background:var(--ink-3); flex:0 0 auto; display:flex; align-items:center; justify-content:center; font-family:"Anton",sans-serif; font-size:28px; color:#473f30}
.mini .mc{padding:10px 12px; display:flex; flex-direction:column; gap:4px; justify-content:center}
.mini h5{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:15px; margin:0; line-height:1.05}
.mini small{font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--moss); letter-spacing:.5px}

.empty{grid-column:1/-1; text-align:center; padding:80px 20px; color:var(--cream-dim)}
.empty p{font-size:18px}
.loading{grid-column:1/-1; text-align:center; padding:80px; color:var(--cream-dim); font-family:"JetBrains Mono",monospace; letter-spacing:2px; text-transform:uppercase; font-size:12px}
footer.site{border-top:1px solid var(--line); padding:34px 0 60px; color:var(--cream-dim); font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px}
footer.site b{color:var(--flame)}

/* ---------- Infolettre (emplacement A : pied de page ; C : fin de récit) ---------- */
.nl{border-top:1px solid var(--line); margin-top:30px; padding:30px 0 6px}
.nl-title{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:clamp(24px,4vw,34px); line-height:.96; margin:0 0 8px}
.nl-sub{color:var(--cream-dim); font-size:15.5px; line-height:1.5; margin:0 0 14px; max-width:620px}
.nl-form{display:flex; gap:10px; flex-wrap:wrap; align-items:center; max-width:520px}
.nl-input{flex:1; min-width:200px; background:var(--ink-2); border:1px solid var(--line); color:var(--cream); border-radius:3px; padding:12px 14px; font-family:"Newsreader",serif; font-size:16px; outline:none}
.nl-input:focus{border-color:var(--flame)}
.nl-msg{min-height:18px; margin:8px 0 0; font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.3px}
.nl-fine{color:var(--cream-dim); font-family:"JetBrains Mono",monospace; font-size:10.5px; letter-spacing:.4px; margin:12px 0 0}
.nl-fine .nl-link{color:var(--cream-dim); text-decoration:underline}
.nl-fine .nl-link:hover{color:var(--flame)}
.nl-done{color:var(--moss); font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.5px; margin:0}
/* Bloc C — inséré en fin de récit (dans la modale détail) */
.nl-recit{position:relative; border:1px solid var(--line); border-radius:6px; background:var(--ink-3); padding:20px 22px; margin:22px 0}
.nl-recit-title{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:22px; line-height:1; margin:0 0 8px}
.nl-x{position:absolute; top:10px; right:12px; background:transparent; border:none; color:var(--cream-dim); font-size:16px; cursor:pointer; line-height:1; padding:4px}
.nl-x:hover{color:var(--flame)}

/* ---------- Chantiers 4–6 ---------- */
/* Bouton carte dans la barre d'outils */
.mapbtn{padding:11px 16px}

/* Onglets Récits / Défis à refaire (chantier 4) */
.tabs{display:flex; gap:8px; padding:4px 0 14px}
.tab{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; padding:9px 16px; border:1px solid var(--line); border-radius:100px; background:transparent; color:var(--cream-dim); cursor:pointer; transition:all .18s ease}
.tab:hover{color:var(--cream); border-color:var(--cream-dim)}
.tab.on{background:var(--flame); color:#1a0f06; border-color:var(--flame)}
.tab .tab-n{opacity:.8; margin-left:4px}

/* Carte « défi à refaire » dans le fil */
.defi-card .defi-badge{position:absolute; top:12px; right:12px; font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; background:var(--flame); color:#1a0f06; padding:6px 10px; border-radius:2px; font-weight:600}
.defi-card .foot span:first-child{color:var(--flame-2)}

/* Lien vers le défi depuis le détail d'un récit */
.defi-link{display:inline-block; margin:0 0 20px; font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--flame-2); background:rgba(232,116,59,.10); border:1px solid var(--flame); border-radius:100px; padding:10px 16px; cursor:pointer; transition:all .18s}
.defi-link:hover{background:var(--flame); color:#1a0f06}

/* Carte d'ensemble (chantier 5) */
.map-full{width:100%; height:min(62vh,560px); border-radius:5px; border:1px solid var(--line); background:var(--ink-3); z-index:0}

/* Case à cocher notifications (chantier 6) — neutralise input{width:100%} */
.check{display:flex; align-items:flex-start; gap:10px; cursor:pointer; font-family:"Newsreader",serif; font-size:15px; color:var(--cream-dim); margin:4px 0 18px; line-height:1.4}
.check input[type=checkbox]{width:18px; height:18px; flex:0 0 auto; margin-top:2px; accent-color:var(--flame); cursor:pointer; padding:0}

/* ---------- Itération 2 : URL/partage, à-faire, signalement, traces, a11y ---------- */

/* Bouton « à tenter » : variante verte (mousse) du bouton inspire */
.inspire.todo{border-color:var(--moss); color:var(--moss)}
.inspire.todo:hover{background:var(--moss); color:#10130b}
.inspire.todo.done{background:var(--moss); color:#10130b}

/* Lien « Signaler » sous un récit */
.report-link{display:inline-block; margin-top:22px; background:none; border:none; cursor:pointer; font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px; color:var(--cream-dim); padding:6px 0}
.report-link:hover{color:var(--flame)}
/* Drapeau de signalement à côté d'un commentaire */
.report-mini{background:none; border:none; cursor:pointer; color:var(--line); font-size:12px; margin-left:8px; padding:0; vertical-align:baseline}
.report-mini:hover{color:var(--flame)}

/* Sous-titres de section dans la fiche profil */
.prof-section{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); margin:28px 0 14px; border-top:1px solid var(--line); padding-top:22px}

/* Bascule de couches sur la carte */
.maptabs{display:flex; gap:8px; margin-bottom:12px}

/* Accessibilité : focus visible au clavier */
:focus-visible{outline:2px solid var(--flame-2); outline-offset:2px}
.card:focus-visible, .mini:focus-visible{outline:2px solid var(--flame-2); outline-offset:2px; border-color:var(--flame)}

/* ---------- Répertoire de défis (section vitrine en haut) ---------- */
.catalogue{border-top:1px solid var(--line); margin-top:30px; padding:26px 0 4px}
.cat-head{display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:18px}
.cat-head h2{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:clamp(28px,4vw,40px); line-height:.9; margin:0; color:var(--cream)}
.cat-sub{font-family:"Newsreader",serif; color:var(--cream-dim); margin:8px 0 0; max-width:560px}
.cat-filters{display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:18px}
.cat-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
@media(max-width:880px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cat-grid{grid-template-columns:1fr}}
.cat-card{background:var(--ink-2); border:1px solid var(--line); border-radius:4px; overflow:hidden; cursor:pointer; display:flex; flex-direction:column; transition:transform .2s ease, border-color .2s ease; opacity:0; transform:translateY(14px); animation:rise .55s ease forwards}
.cat-card:hover{transform:translateY(-4px); border-color:var(--moss)}
.cat-card:focus-visible{outline:2px solid var(--flame-2); outline-offset:2px; border-color:var(--moss)}
.cat-thumb{aspect-ratio:16/10; position:relative; overflow:hidden; background:var(--ink-3)}
.cat-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.cat-thumb .ph{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:"Anton",sans-serif; font-size:52px; color:#473f30}
.cat-thumb .tag{position:absolute; top:12px; left:12px; background:rgba(22,20,15,.82); color:var(--moss)}
/* Centre d'activité — « depuis ta dernière visite » */
.digest{max-width:var(--maxw); margin:0 auto 18px; padding:0 24px}
.digest-inner{display:flex; align-items:center; gap:14px; background:var(--ink-2); border:1px solid var(--line); border-left:3px solid var(--flame); border-radius:6px; padding:12px 16px}
.digest-k{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--moss); margin-right:10px; white-space:nowrap}
.digest-body{color:var(--cream-dim); font-size:14.5px}
.digest-x{margin-left:auto; background:transparent; border:none; color:var(--cream-dim); cursor:pointer; font-size:16px; line-height:1; padding:4px 6px}
.digest-x:hover{color:var(--cream)}

/* Placeholder « image à venir » pour un défi sans photo */
.ph.ph-todo{flex-direction:column; gap:10px; text-align:center; padding:14px}
.ph-todo .ph-type{font-family:"Anton",sans-serif; line-height:.95; letter-spacing:2px; color:#5b513e}
.ph-todo .ph-soon{font-family:"JetBrains Mono",ui-monospace,monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); opacity:.85}
.hero-img.ph-todo .ph-soon{font-size:13px}
.cat-body{padding:15px 16px 17px; display:flex; flex-direction:column; gap:8px; flex:1}
.cat-body h3{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:20px; line-height:1.02; letter-spacing:.4px; margin:0}

/* ---------- Bouton partager ---------- */
.inspire.share{border-color:var(--cream-dim); color:var(--cream-dim)}
.inspire.share:hover{background:var(--cream); color:var(--ink); border-color:var(--cream)}

/* ---------- Tableau de bord admin ---------- */
.dash-top{display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-bottom:18px}
.nl-actions{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:18px}
.nl-preview{background:#fff; border:1px solid var(--line); border-radius:6px; padding:18px; max-height:52vh; overflow:auto}
.stat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:26px}
@media(max-width:680px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--ink-3); border:1px solid var(--line); border-radius:5px; padding:14px 16px; display:flex; flex-direction:column; gap:3px}
.stat-v{font-family:"JetBrains Mono",monospace; font-size:30px; color:var(--flame); line-height:1}
.stat-k{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--cream-dim)}
.stat-x{font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--moss); margin-top:2px}
.dash-acq{background:var(--ink-2); border:1px solid var(--line); border-radius:5px; padding:16px 18px; margin-bottom:26px}
.dash-acq h4{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); margin:0 0 10px}
.dash-acq-lead{margin:0 0 12px; font-size:15px}
.dash-acq-t{width:100%; border-collapse:collapse; font-family:"JetBrains Mono",monospace; font-size:13px}
.dash-acq-t th{text-align:left; color:var(--cream-dim); font-weight:400; font-size:10px; letter-spacing:1px; text-transform:uppercase; padding:6px 10px; border-bottom:1px solid var(--line)}
.dash-acq-t td{padding:7px 10px; border-bottom:1px solid var(--ink-3)}
.dash-acq-t td:first-child{color:var(--flame)}
.dash-acq-note{margin:12px 0 0; font-size:11px; color:var(--cream-dim)}
.dash-cols{display:grid; grid-template-columns:1fr 1fr; gap:22px}
@media(max-width:680px){.dash-cols{grid-template-columns:1fr}}
.dash-col h4{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); margin:0 0 12px; border-top:1px solid var(--line); padding-top:14px}
.dash-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px}
.dash-list li{display:flex; flex-direction:column; gap:2px; font-size:14px; color:#ddd5c6}
.dash-list li a{color:var(--flame-2); text-decoration:none}
.dash-list li a:hover{text-decoration:underline}
.dash-list small{font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--cream-dim)}
.rep-li{gap:6px}
.rep-acts{display:flex; flex-wrap:wrap; gap:6px; margin-top:4px}
.rep-act{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:.5px; text-transform:uppercase; padding:4px 9px; border:1px solid var(--line); border-radius:100px; background:transparent; color:var(--cream-dim); cursor:pointer}
.rep-act:hover{color:var(--cream); border-color:var(--cream-dim)}
.rep-act.danger{color:var(--flame); border-color:var(--line)}
.rep-act.danger:hover{background:var(--flame); color:#1a0f06; border-color:var(--flame)}

/* ---------- Titre de la section des récits ---------- */
.feed-head{border-top:1px solid var(--line); margin-top:34px; padding-top:26px}
.feed-head h2{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:clamp(28px,4vw,40px); line-height:.9; margin:0; color:var(--cream)}

/* ---------- Actions de l'auteur (modifier / supprimer) ---------- */
.owner-actions{display:flex; gap:10px; flex-wrap:wrap; margin:18px 0 4px; padding-top:18px; border-top:1px solid var(--line)}
.btn.ghost.danger{color:var(--flame); border-color:var(--line)}
.btn.ghost.danger:hover{border-color:var(--flame); background:var(--flame); color:#1a0f06}

/* ---------- Événements ---------- */
.evt-list{display:flex; flex-direction:column; gap:14px}
.evt-card{display:flex; gap:0; background:var(--ink-3); border:1px solid var(--line); border-radius:5px; overflow:hidden; cursor:pointer; transition:border-color .18s}
.evt-card:hover{border-color:var(--flame)}
.evt-card.clos{opacity:.55}
.evt-card:focus-visible{outline:2px solid var(--flame-2); outline-offset:2px}
.evt-date{flex:0 0 120px; background:var(--ink-2); border-right:1px solid var(--line); padding:14px 12px; font-family:"JetBrains Mono",monospace; font-size:11px; line-height:1.4; color:var(--flame-2); display:flex; align-items:center; text-transform:capitalize}
.evt-body{padding:13px 16px; display:flex; flex-direction:column; gap:6px; flex:1}
.evt-body h3{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:19px; line-height:1.02; margin:0}
.evt-parts{display:flex; flex-wrap:wrap; gap:10px}
.evt-part{display:inline-flex; align-items:center; gap:7px; font-family:"JetBrains Mono",monospace; font-size:12px; color:var(--cream-dim); background:var(--ink); border:1px solid var(--line); border-radius:100px; padding:5px 12px 5px 5px}
.evt-part-x{background:none; border:none; color:var(--cream-dim); cursor:pointer; font-size:11px; padding:0 0 0 2px}
.evt-part-x:hover{color:var(--flame)}
.evt-invite{margin-top:14px}
/* sondage de dates */
.poll-row{display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--line); flex-wrap:wrap}
.poll-row.lead .poll-when{color:var(--flame-2)}
.poll-vote{flex:0 0 auto; width:30px; height:30px; border-radius:50%; border:1px solid var(--line); background:transparent; color:var(--cream-dim); cursor:pointer; font-size:13px}
.poll-vote.on{background:var(--moss); color:#10130b; border-color:var(--moss)}
.poll-when{font-family:"JetBrains Mono",monospace; font-size:13px; color:var(--cream); text-transform:capitalize}
.poll-count{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--cream-dim); margin-left:auto}
.invite-res{display:flex; align-items:center; gap:8px; width:100%; text-align:left; background:var(--ink); border:1px solid var(--line); border-radius:4px; padding:7px 10px; margin-top:6px; cursor:pointer; color:var(--cream); font-family:"JetBrains Mono",monospace; font-size:13px}
.invite-res:hover{border-color:var(--flame)}
.invite-res span{margin-left:auto; color:var(--flame-2); font-size:11px}
/* calendrier */
.cal-head{display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:12px}
.cal-title{font-family:"Anton",sans-serif; text-transform:uppercase; font-size:22px; letter-spacing:.5px; min-width:200px; text-align:center}
.cal-grid{display:grid; grid-template-columns:repeat(7,1fr); gap:6px}
.cal-wd{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--moss); text-align:center; padding:4px 0}
.cal-cell{min-height:74px; background:var(--ink-3); border:1px solid var(--line); border-radius:4px; padding:5px; display:flex; flex-direction:column; gap:3px}
.cal-cell.empty{background:transparent; border-color:transparent}
.cal-cell.today{border-color:var(--flame)}
.cal-day{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--cream-dim)}
.cal-evt{font-family:"JetBrains Mono",monospace; font-size:10px; text-align:left; background:var(--flame); color:#1a0f06; border:none; border-radius:2px; padding:3px 5px; cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%}
.cal-evt:hover{background:var(--flame-2)}
@media(max-width:600px){.cal-cell{min-height:54px} .cal-evt{font-size:0; padding:6px; border-radius:50%; width:8px; height:8px}}

/* ---------- Pages légales (confidentialité, charte) ---------- */
.legal h4{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:var(--moss); margin:22px 0 6px}
.legal p{color:#ddd5c6; font-size:15px; line-height:1.6; margin:0 0 10px}
.legal a{color:var(--flame-2)}
.legal-date{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--cream-dim); margin-bottom:8px}
.legal-note{font-style:italic; color:var(--cream-dim); font-size:13px; border-top:1px solid var(--line); padding-top:14px; margin-top:18px}
footer.site a{color:var(--cream-dim); text-decoration:underline}
footer.site a:hover{color:var(--flame)}

/* ---------- Bandeau bêta ---------- */
.beta{position:relative; z-index:3; display:flex; align-items:center; justify-content:center; gap:14px; background:var(--flame); color:#1a0f06; font-family:"JetBrains Mono",monospace; font-size:12px; line-height:1.45; letter-spacing:.3px; padding:9px 42px 9px 16px; text-align:center}
.beta a{color:#1a0f06; text-decoration:underline; font-weight:600}
.beta-x{position:absolute; right:10px; top:50%; transform:translateY(-50%); background:transparent; border:none; color:#1a0f06; cursor:pointer; font-size:14px; line-height:1; opacity:.7; padding:4px}
.beta-x:hover{opacity:1}

/* ---------- Connexion : bouton Google + séparateur ---------- */
.btn.google{display:inline-flex; align-items:center; justify-content:center; gap:10px; background:#fff; color:#1f1f1f}
.btn.google:hover{background:#f1f1f1; transform:translateY(-2px)}
.btn.google svg{flex:0 0 auto}
.auth-or{display:flex; align-items:center; gap:12px; margin:18px 0; color:var(--cream-dim); font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase}
.auth-or::before, .auth-or::after{content:""; flex:1; height:1px; background:var(--line)}

/* ---------- Défi collectif « Run the World Cup » ---------- */
.evt-card.defi-collectif{border-color:var(--flame)}
.evt-card.defi-collectif .evt-date{background:var(--flame); color:#1a0f06; font-weight:700}
/* Bloc cible (buts → km) */
.rtwc-cible{display:flex; align-items:center; gap:16px; background:var(--ink-2); border:1px solid var(--line); border-left:3px solid var(--flame); border-radius:6px; padding:16px 18px; margin:16px 0}
.rtwc-cible .rtwc-goals{font-family:"Anton",sans-serif; font-size:44px; line-height:1; color:var(--flame); flex:0 0 auto}
.rtwc-cible small{color:var(--cream-dim); font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px}
/* Tableau de bord personnel */
.rtwc-prog{margin:6px 0 16px}
.rtwc-prog-top{display:flex; justify-content:space-between; font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.5px; color:var(--cream-dim); margin-bottom:6px}
.rtwc-prog-top b{color:var(--cream); font-size:16px}
.rtwc-bar{height:12px; background:var(--ink-3); border-radius:100px; overflow:hidden}
.rtwc-bar span{display:block; height:100%; background:linear-gradient(90deg,var(--moss),var(--flame)); border-radius:100px; transition:width .4s ease}
.rtwc-msg{font-size:14px; color:var(--cream-dim); margin:8px 0 0}
.rtwc-msg b{color:var(--flame)}
/* Formulaire de journalisation des km */
.rtwc-form{display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin:8px 0 12px}
.rtwc-form .search{flex:0 1 110px; min-width:90px}
.rtwc-form #km-note{flex:1 1 160px}
.rtwc-entries{margin:0 0 14px}
/* Classement individuel */
.rtwc-class{border-top:1px solid var(--line); margin-top:12px; padding-top:12px}
.rtwc-class h5{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--moss); margin:0 0 10px}
.rtwc-rank{display:flex; align-items:center; gap:10px; padding:7px 8px; border-radius:4px}
.rtwc-rank.me{background:var(--ink-2)}
.rtwc-pos{font-family:"JetBrains Mono",monospace; font-size:13px; color:var(--cream-dim); width:22px; text-align:right; flex:0 0 auto}
.rtwc-name{flex:1; color:var(--cream)}
.rtwc-km{font-family:"JetBrains Mono",monospace; font-size:13px; color:var(--flame); white-space:nowrap}

/* ---------- Carrousel de photos (détail) ---------- */
.carousel{position:relative; border-radius:6px 6px 0 0; overflow:hidden; background:var(--ink-3)}
.carousel-track{display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-img{flex:0 0 100%; width:100%; aspect-ratio:16/9; object-fit:cover; scroll-snap-align:center; display:block; background:var(--ink-3)}
.car-btn{position:absolute; top:50%; transform:translateY(-50%); background:rgba(22,20,15,.7); color:var(--cream); border:1px solid var(--line); width:40px; height:40px; border-radius:50%; cursor:pointer; font-size:22px; line-height:1; z-index:2; backdrop-filter:blur(3px)}
.car-btn:hover{border-color:var(--flame); color:var(--flame)}
.car-btn.prev{left:10px} .car-btn.next{right:10px}
.car-count{position:absolute; bottom:10px; right:12px; background:rgba(22,20,15,.72); color:var(--cream); font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px; padding:4px 9px; border-radius:100px; z-index:2}

/* ---------- Assistant d'écriture (formulaire) ---------- */
.assist{display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin:-6px 0 14px}
.assist-label{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--moss)}
.assist-btn{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px; text-transform:uppercase; padding:7px 12px; border:1px solid var(--line); border-radius:100px; background:transparent; color:var(--cream-dim); cursor:pointer; transition:all .18s}
.assist-btn:hover{color:var(--cream); border-color:var(--moss)}
.assist-btn:disabled{opacity:.5; cursor:default}
.assist-btn.undo{color:var(--flame-2); border-color:var(--flame)}
.assist-msg{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--cream-dim); margin-left:4px}

/* ---------- Preuve sociale du désir (tuiles + modale de défi) ---------- */
.metrics.proof{color:var(--flame-2)}
.attr.proof{border-color:var(--flame); color:var(--flame-2); text-transform:none; letter-spacing:.5px}

/* ---------- Modales en plein écran sur mobile ----------
   Sur petit écran, les fenêtres (récit, défi, formulaires…) occupent tout
   l'écran au lieu de flotter, et le bouton ✕ reste visible pendant le
   défilement (position fixe). Aucun impact au-dessus de 640 px. */
@media(max-width:640px){
  .scrim{padding:0}
  .modal{max-width:none; min-height:100vh; min-height:100dvh; border-radius:0; border-left:none; border-right:none; border-top:none}
  .modal .x{position:fixed; top:10px; right:10px}
  .mbody{padding:22px 16px 30px}
  .hero-img{border-radius:0}
  .hero-img.ph{font-size:64px}
}

/* ---------- Nouveautés (journal des nouveautés — chantier A) ---------- */
/* Pastille de notification (compteur). Conservée : utilisée par la pastille des Messages. */
.nouv-badge{display:inline-flex; align-items:center; justify-content:center; min-width:16px; height:16px; padding:0 4px; margin-left:6px; border-radius:100px; background:var(--flame); color:#1a0f06; font-family:"JetBrains Mono",monospace; font-size:10px; font-weight:700; line-height:1}

/* ---------- Tâches d'événement (chantier B) ---------- */
.tache-form{display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.tache-form .search{flex:1; min-width:170px}
.tache-assign{max-width:180px}
.tache-done b{text-decoration:line-through}
.tache-done{opacity:.7}

/* ---------- Messagerie privée 1-à-1 (Jalon M1) ---------- */
.conv-list{display:flex; flex-direction:column}
.conv-row{display:flex; align-items:center; gap:12px; padding:14px 4px; border-bottom:1px solid var(--line); cursor:pointer; transition:background .15s}
.conv-row:hover{background:var(--ink-3)}
.conv-row:focus-visible{outline:2px solid var(--flame-2); outline-offset:-2px}
.conv-av{width:44px; height:44px; border-radius:50%; object-fit:cover; flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center; background:var(--ink-3); color:var(--cream); font-family:"Anton",sans-serif; font-size:18px}
.conv-main{flex:1; min-width:0; display:flex; flex-direction:column; gap:3px}
.conv-top{display:flex; justify-content:space-between; align-items:baseline; gap:10px}
.conv-name{color:var(--cream); font-size:15px}
.conv-time{flex:0 0 auto; font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--cream-dim)}
.conv-prev{color:var(--cream-dim); font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.conv-row.unread .conv-name{font-weight:bold}
.conv-row.unread .conv-prev{color:var(--cream)}
.conv-dot{flex:0 0 auto; color:var(--flame); font-size:12px}
.conv-head{display:flex; align-items:center; gap:14px; margin-bottom:16px; flex-wrap:wrap}
.conv-with{display:flex; align-items:center; gap:9px; color:var(--cream); font-size:17px}
.conv-actions{display:flex; gap:8px; margin-left:auto}
/* La modale de signalement surcouvre toujours les autres (ex. depuis une conversation). */
#reportScrim{z-index:60}
/* Le hub Communauté est une couche de fond : les détails/formulaires (annonce, offre,
   mentor, messagerie…) s'ouvrent PAR-DESSUS. z-index plus bas que .scrim (50). */
#communauteScrim{z-index:45}

/* ---------- Hôtes (accueil entre membres) ---------- */
.acc-filters{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:16px}
.acc-list{display:flex; flex-direction:column; gap:14px}
.acc-card{background:var(--ink); border:1px solid var(--line); border-radius:6px; padding:16px}
.acc-head{display:flex; align-items:center; gap:12px}
.acc-head h3{font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; font-size:19px; margin:0; line-height:1.05; color:var(--cream)}
.acc-meta{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--moss); letter-spacing:.5px; margin-top:3px}
.acc-badges{display:flex; flex-wrap:wrap; gap:6px; margin-top:12px}
.acc-badge{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:.5px; text-transform:uppercase; padding:4px 9px; border:1px solid var(--flame); color:var(--flame-2); border-radius:100px}
.prof-badges{display:inline-flex; gap:6px; vertical-align:middle}
.prof-badge{font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.5px; text-transform:uppercase; padding:4px 10px; border:1px solid var(--moss); color:var(--moss); background:transparent; border-radius:100px; cursor:pointer; transition:color .2s ease, border-color .2s ease}
.prof-badge:hover{border-color:var(--flame); color:var(--flame)}
.acc-desc{font-size:15px; line-height:1.6; color:#e7e0d2; white-space:pre-wrap; margin:12px 0 0}
.acc-line{font-size:13px; color:var(--cream-dim); margin-top:8px}
.acc-foot{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:.5px; text-transform:uppercase; color:var(--cream-dim); margin-top:12px; border-top:1px solid var(--line); padding-top:10px}
.acc-checks{display:flex; flex-wrap:wrap; gap:10px}
.acc-check{display:flex; align-items:center; gap:6px; font-size:14px; color:var(--cream); background:var(--ink); border:1px solid var(--line); border-radius:100px; padding:6px 12px; cursor:pointer}
.acc-check input{accent-color:var(--flame)}
.thread{display:flex; flex-direction:column; gap:10px; max-height:52vh; overflow-y:auto; padding:14px; background:var(--ink); border:1px solid var(--line); border-radius:6px}
.bubble-row{display:flex; flex-direction:column; max-width:80%}
.bubble-row.me{align-self:flex-end; align-items:flex-end}
.bubble-row.them{align-self:flex-start; align-items:flex-start}
.bubble{padding:9px 13px; border-radius:14px; font-size:15px; line-height:1.5; white-space:pre-wrap; word-wrap:break-word}
.bubble-row.them .bubble{background:var(--ink-3); color:var(--cream); border-bottom-left-radius:4px}
.bubble-row.me .bubble{background:var(--flame); color:var(--ink); border-bottom-right-radius:4px}
.bubble-t{font-family:"JetBrains Mono",monospace; font-size:9.5px; color:var(--cream-dim); margin-top:3px}
.composer{display:flex; gap:10px; margin-top:14px; align-items:flex-end}
.composer textarea{flex:1; resize:vertical; min-height:44px}
.composer .btn{flex:0 0 auto}
