:root{
  --bg:#0b0f14;
  --card:#0f1722;
  --card2:#121d2c;
  --text:#e9eef7;
  --muted:#a9b4c4;
  --line:#243247;
  --accent:#ff7a2f;
  --ok:#32d583;
  --warn:#fdb022;
  --bad:#ff4d4d;
  --radius:16px;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background: radial-gradient(1000px 600px at 10% 0%, rgba(255,122,47,.12), transparent 60%),
              radial-gradient(900px 650px at 90% 10%, rgba(50,213,131,.10), transparent 55%),
              var(--bg);
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1100px;margin:0 auto;padding:18px}
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(11,15,20,.8);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(36,50,71,.6);
}
.topbar-inner{display:flex;align-items:center;gap:14px;justify-content:space-between}
.brand{font-weight:900;letter-spacing:.4px}
.brand span{color:var(--accent)}
.nav{display:flex;gap:12px;flex-wrap:wrap}
.nav a{padding:8px 10px;border-radius:10px;color:var(--muted)}
.nav a:hover{background:rgba(255,255,255,.06);color:var(--text)}
.userbox{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pill{padding:7px 10px;border-radius:999px;background:rgba(255,122,47,.14);border:1px solid rgba(255,122,47,.30);color:var(--text);font-weight:700;font-size:.9rem}

h1,h2{margin:0 0 10px}
h1{font-size:1.6rem}
h2{font-size:1.2rem;color:var(--text)}
p{color:var(--muted);margin:8px 0 0}

.grid{
  display:grid;
  gap:14px;
}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:900px){ .grid.cols-3{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ .grid.cols-3,.grid.cols-2{grid-template-columns:1fr} }

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
  border:1px solid rgba(36,50,71,.85);
  border-radius:var(--radius);
  padding:14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.24);
}
.card.soft{background:rgba(15,23,34,.65)}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:space-between}

.btn{
  border:none;cursor:pointer;
  background:linear-gradient(180deg, rgba(255,122,47,.95), rgba(255,122,47,.80));
  color:#151515;font-weight:900;
  padding:10px 14px;border-radius:12px;
  display:inline-flex;align-items:center;gap:8px;
}
.btn:hover{filter:brightness(1.02)}
.btn:active{transform:translateY(1px)}
.btn.ghost{
  background:transparent;
  border:1px solid rgba(36,50,71,.9);
  color:var(--text);
}
.btn.small{padding:8px 10px;border-radius:11px;font-size:.92rem;font-weight:800}

.input, select, textarea{
  width:100%;
  background:rgba(18,29,44,.7);
  color:var(--text);
  border:1px solid rgba(36,50,71,.9);
  border-radius:12px;
  padding:10px 12px;
  outline:none;
}
textarea{min-height:110px;resize:vertical}
.form{display:grid;gap:12px}
.form .two{display:grid;gap:12px;grid-template-columns:1fr 1fr}
@media(max-width:700px){ .form .two{grid-template-columns:1fr} }

.tag{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(50,213,131,.12);
  border:1px solid rgba(50,213,131,.25);
  color:var(--text);font-weight:800;font-size:.85rem
}
.tag.warn{background:rgba(253,176,34,.12);border-color:rgba(253,176,34,.25)}
.tag.bad{background:rgba(255,77,77,.12);border-color:rgba(255,77,77,.25)}

.theme-card{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:12px;
  align-items:stretch;
}
@media(max-width:640px){ .theme-card{grid-template-columns:1fr} }

.imgbox{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(36,50,71,.8);
  background:rgba(255,255,255,.02);
  aspect-ratio: 4 / 3; /* même taille */
  position:relative;
}
.imgbox img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.imgbox .zoom{
  position:absolute;right:8px;bottom:8px;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  padding:6px 8px;
  border-radius:10px;
  font-weight:800;
}

.meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:.92rem}
.meta b{color:var(--text)}

.entries-grid{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:900px){ .entries-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:640px){ .entries-grid{grid-template-columns:1fr} }

.entry-card .who{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-top:10px}
.entry-card .who a{color:var(--text);font-weight:900}
.count{color:var(--muted);font-weight:900}

hr.sep{border:none;border-top:1px solid rgba(36,50,71,.7);margin:14px 0}

/* Lightbox */
#lightbox{
  position:fixed;inset:0;
  background:rgba(0,0,0,.86);
  display:none;
  align-items:center;justify-content:center;
  padding:18px;
  z-index:999;
}
#lightbox img{
  max-width:min(1100px, 95vw);
  max-height:90vh;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:#111;
}

/* Toast points */
.toast{
  position:fixed;right:18px;top:86px;
  background:rgba(15,23,34,.88);
  border:1px solid rgba(255,122,47,.35);
  box-shadow:0 16px 40px rgba(0,0,0,.4);
  border-radius:16px;
  padding:12px 14px;
  min-width:240px;
  animation:pop .22s ease-out;
}
@keyframes pop{from{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}
.toast .big{font-size:1.1rem;font-weight:950}
.toast .small{color:var(--muted);margin-top:4px;font-weight:800}
/* CTA cards (index) */
.cta-grid{ align-items:start; }
.cta{
  display:block;
  transition: transform .12s ease, filter .12s ease;
  cursor:pointer;
}
.cta:hover{ transform: translateY(-2px); filter: brightness(1.03); }

.cta-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:6px;
}

.pill.mini{
  padding:6px 10px;
  font-size:.82rem;
  font-weight:900;
  opacity:.95;
}

.cta-action{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:12px;
}

.muted{ color: var(--muted); font-weight:800; font-size:.92rem; }
/* =========================
   MOBILE TWEAKS (clean)
   ========================= */

@media (max-width: 640px){

  .wrap{ padding:12px; }

  /* topbar: éviter débordements */
  .topbar-inner{
    flex-wrap:wrap;
    gap:10px;
  }
  .nav{
    width:100%;
    justify-content:flex-start;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;
  }
  .nav a{ white-space:nowrap; }

  /* CTA: plus "touch-friendly" */
  .cta-grid{ gap:12px; }
  .cta{ padding:14px; }
  .cta h2{ font-size:1.05rem; }
  .cta p{ font-size:.95rem; line-height:1.25rem; }

  /* Liste thèmes: cards plus compactes */
  .card{ padding:12px; border-radius:14px; }
  h1{ font-size:1.25rem; }
  h2{ font-size:1.05rem; }

  /* Form recherche: full width + bouton large */
  .form .two{ grid-template-columns:1fr; }
  .btn.small{ width:100%; justify-content:center; }

  /* theme-card: image au-dessus, texte dessous */
  .theme-card{
    grid-template-columns:1fr;
    gap:10px;
  }

  /* image ratio plus "feed" */
  .imgbox{
    aspect-ratio: 16 / 10;
    border-radius:14px;
  }

  /* meta: éviter ligne infinie */
  .meta{
    gap:8px;
    font-size:.9rem;
  }

  /* bouton ouvrir: plein largeur sur mobile */
  .row{
    align-items:flex-start;
  }
  .row .btn.small{
    width:100%;
  }

  /* zoom label: plus discret */
  .imgbox .zoom{
    right:10px; bottom:10px;
    padding:7px 10px;
    border-radius:12px;
  }

  /* Lightbox: confort mobile */
  #lightbox{
    padding:10px;
  }
  #lightbox img{
    max-height:85vh;
    border-radius:14px;
  }
}


/* Très petits écrans (iPhone SE) */
@media (max-width: 380px){
  .pill{ padding:6px 8px; font-size:.82rem; }
  .brand{ font-size:1rem; }
  h1{ font-size:1.18rem; }
  .imgbox{ aspect-ratio: 4 / 3; }
}
/* =========================
   TOPBAR MOBILE FIX
   ========================= */
@media (max-width: 640px){

  /* header plus clair */
  .topbar{
    background:rgba(18,29,44,.96);
    border-bottom:1px solid rgba(255,255,255,.08);
  }

  /* structure centrée */
  .topbar-inner{
    flex-direction:column;
    align-items:center;
    gap:10px;
  }

  /* logo bien visible */
  .brand{
    font-size:1.15rem;
    text-align:center;
  }

  /* nav plus lisible */
  .nav{
    width:100%;
    justify-content:center;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    border-radius:14px;
    padding:6px;
    gap:6px;
  }

  .nav a{
    color:#e9eef7;
    font-weight:800;
    padding:8px 10px;
    border-radius:10px;
  }

  .nav a:hover{
    background:rgba(255,255,255,.12);
  }

  /* userbox centré */
  .userbox{
    width:100%;
    justify-content:center;
    gap:8px;
  }

  .userbox .btn,
  .userbox .pill{
    flex:1;
    justify-content:center;
    text-align:center;
  }

  .userbox .pill{
    background:rgba(255,122,47,.22);
    border:1px solid rgba(255,122,47,.45);
    color:#fff;
  }
}

/* iPhone SE / très petits écrans */
@media (max-width: 380px){
  .nav{
    flex-wrap:wrap;
  }
  .nav a{
    font-size:.9rem;
    padding:7px 9px;
  }
}

/* =========================
   PROFILE WINS (no crush)
   ========================= */
.wins-list{ display:grid; gap:14px; }

.win-item{
  display:grid;
  grid-template-columns: 180px 1fr;
  gap:14px;
  align-items:stretch;
}

.win-thumb{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(36,50,71,.8);
  background:rgba(255,255,255,.02);
  aspect-ratio: 4 / 3;
  position:relative;
  display:block;
}

.win-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.win-thumb .zoom{
  position:absolute;right:8px;bottom:8px;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  padding:6px 8px;
  border-radius:10px;
  font-weight:800;
}

.win-main{ min-width:0; } /* IMPORTANT anti-écrasement */
.win-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.win-title{
  margin-top:10px;
  margin-bottom:0;
  word-break:break-word;
}

/* mobile */
@media (max-width: 640px){
  .win-item{ grid-template-columns: 1fr; }
  .win-thumb{ aspect-ratio: 16 / 10; }
  .win-top{ flex-direction:column; align-items:stretch; }
  .win-top .btn.small{ width:100%; justify-content:center; }
}
