/* ==================== Thème / base ==================== */
:root{
  --bg:#0b0f1a;
  --panel:#0f1424;
  --muted:#a6b0cf;
  --text:#e6e9f5;
  --accent:#7c3aed;
  --accent2:#06b6d4;
  --ring: 0 0 0 2px color-mix(in oklab, var(--accent) 60%, transparent);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Inter,system-ui,Segoe UI,Roboto,Arial;
  background:
    radial-gradient(1100px 700px at 6% -10%, rgba(124,58,237,.12), transparent 60%),
    radial-gradient(900px 600px at 110% 8%, rgba(6,182,212,.10), transparent 60%),
    var(--bg);
  color:var(--text); line-height:1.55;
}

/* ==================== Nav ==================== */
.t-nav{
  position:sticky;top:0;z-index:20;
  background:color-mix(in oklab,var(--bg) 85%, transparent);
  border-bottom:1px solid rgba(255,255,255,.06);
  backdrop-filter:saturate(140%) blur(10px)
}
.t-container{width:min(1200px,94%);margin-inline:auto;padding-inline:clamp(6px,1.6vw,14px)}
.t-nav .t-container{display:flex;align-items:center;justify-content:space-between;height:58px}
.brand{display:flex;gap:.6rem;align-items:center;color:inherit;text-decoration:none;font-weight:700}
.brand img{border-radius:8px;box-shadow:0 6px 18px rgba(124,58,237,.35), inset 0 0 18px rgba(255,255,255,.1)}
.links a{margin-left:1rem;color:var(--muted);text-decoration:none;white-space:nowrap}
.links a.active,.links a:hover{color:var(--text)}

/* ==================== Hero ==================== */
.hero{padding:clamp(1.2rem,3vw,2rem) 0 .6rem}
.kicker{text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;color:var(--accent2);font-weight:700;margin:0}
.title{font-size:clamp(1.6rem,3.6vw,2.4rem);margin:.2rem 0}
.sub{color:var(--muted)}
.code{font-family:ui-monospace,Consolas,Menlo,monospace;border:1px solid rgba(255,255,255,.15);padding:.1rem .35rem;border-radius:6px;background:rgba(255,255,255,.04)}

/* ==================== Grids & Cards ==================== */
.grid{
  display:grid; gap:1rem;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  padding-bottom:2rem
}
.card,.tpl-card{
  background:color-mix(in oklab,var(--panel) 92%, transparent);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px; display:flex; flex-direction:column; overflow:hidden
}
.card{padding:1rem;margin-bottom:1rem}
.card-body{padding:1rem}
.card-title{margin:.2rem 0 .3rem}
.mini{display:flex;gap:1rem;color:var(--muted);font-size:.9rem;margin-top:.5rem}
.chips{display:flex;gap:.4rem;flex-wrap:wrap;margin:.25rem 0}
.tag{display:inline-block;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:.18rem .5rem;color:var(--muted);font-size:.75rem}

/* Cartes du catalogue */
.tpl-card{padding:1rem}
.tpl-card .c-head{display:flex;gap:.6rem;align-items:center;justify-content:space-between;min-height:32px}
.tpl-card h3{margin:.2rem 0 .3rem;font-size:1.05rem}
.tpl-card .c-desc{color:var(--muted);margin:.25rem 0 .4rem;font-size:.95rem;min-height:1.2em}
.metrics{display:flex;gap:1rem;color:var(--muted);font-size:.92rem;margin:.5rem 0}
.actions{display:flex;gap:.6rem;margin-top:.5rem}

/* ==================== Boutons ==================== */
.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  color:var(--text);border-radius:12px;padding:.6rem .9rem;font-weight:600;cursor:pointer
}
.btn.primary{border-color:transparent;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 12px 30px rgba(124,58,237,.35)}
.btn:hover{transform:translateY(-1px)}

/* ==================== Modale ==================== */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:grid;place-items:center;padding:1rem;z-index:1000}
.modal.open{display:grid}
.modal:not(.open){display:none}
.modal-box{
  width:min(980px,100%);
  background:color-mix(in oklab,var(--panel) 92%, transparent);
  border:1px solid rgba(255,255,255,.1); border-radius:16px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  padding:1rem 1rem 1.2rem; position:relative;
  max-height:90dvh; overflow:auto
}
.modal .close{position:absolute;top:10px;right:10px;border:0;background:transparent;color:var(--muted);font-size:20px;cursor:pointer}
.pv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem;gap:.6rem}
.pv-title{margin:.3rem 0}
.pv-meta{color:var(--muted);margin-bottom:.6rem}
.pv-tools{display:flex;gap:1rem;flex-wrap:wrap;margin:.2rem 0 .8rem}
.pv-tools label{display:inline-flex;gap:.4rem;align-items:center;color:var(--muted)}
.pv-columns{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media (max-width:900px){.pv-columns{grid-template-columns:1fr}}

/* ==================== Aperçu lisible ==================== */
.roles{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(180px,1fr));
  gap:.35rem .6rem; align-items:start;
}
.role{
  display:flex; align-items:center; gap:.5rem;
  padding:.28rem .45rem;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.02);
  min-width:0;
}
.role .sw{ width:.85rem; height:.85rem; border-radius:999px; flex:none }

.chans{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
  gap:.6rem; align-items:start;
}
.catbox{
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px; background:rgba(255,255,255,.02);
  padding:.55rem .65rem .5rem;
}
.cat{ font-weight:700; margin-bottom:.35rem }
.ch-list{ display:flex; gap:.35rem; flex-wrap:wrap }
.ch{
  padding:.22rem .4rem;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px; background:rgba(255,255,255,.02);
  font-size:.95rem;
}
.muted{color:var(--muted)}
.warn{color:#ffd166}

/* ==================== Commande ==================== */
.cmd{margin:1rem 0}
.cmd-row{display:flex;gap:.5rem}
.cmd-row input{
  flex:1;min-width:140px;
  padding:.6rem .7rem;border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);color:inherit
}
.options{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:.4rem;margin-top:.5rem}
.options label{display:flex;gap:.5rem;align-items:center}

/* ==================== Uploader ==================== */
.uploader{margin:1rem 0 1.2rem}
.drop{display:grid;place-items:center;border:1.5px dashed rgba(255,255,255,.18);border-radius:14px;min-height:160px;color:var(--muted);background:rgba(255,255,255,.02)}
.drop.hover{outline:var(--ring)}
.row{display:flex;gap:.6rem;align-items:center;margin-top:.6rem}

/* ==================== Admin / Listes / Espace auteur ==================== */
.login{display:flex;gap:.6rem;flex-wrap:wrap}
.login input{padding:.6rem .7rem;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:inherit}

/* Les lignes s’enroulent, ne débordent plus */
.list .row{
  display:flex;
  flex-wrap:wrap;               /* <— corrige le débordement */
  gap:.8rem 1rem;
  align-items:center;
  justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.06);
  padding:.8rem 0
}
.list .row:first-child{border-top:none}

.bold{font-weight:700}
.grow{flex:1 1 320px}           /* prend la place libre, wrap si étroit */

/* Longs noms de ZIP = casse automatique */
.break, .fname, .list .row > *:first-child{
  word-break:break-word;
  overflow-wrap:anywhere;
  min-width:220px;
}

.pub{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.pub input,
.pub textarea{
  padding:.5rem .6rem;border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);color:inherit;
  min-width:180px;flex:1 1 200px
}
.pub textarea{min-height:40px}

/* “Mes templates” */
.my-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.my-card{padding:1rem}

/* ==================== Divers ==================== */
hr{border:0;border-top:1px solid rgba(255,255,255,.08);margin:.6rem 0}
