/* ============================================================
   NoizVinyle — Design System 2026
   Glassmorphisme · Contraste élevé · Mobile-first
============================================================ */

:root {
  --bg:        #e8eaf4;
  --glass:     rgba(255,255,255,0.72);
  --glass-s:   rgba(255,255,255,0.88);
  --glass-b:   rgba(255,255,255,0.94);
  --shadow:    0 4px 24px rgba(80,90,160,0.13),0 1px 4px rgba(80,90,160,0.07);
  --shadow-lg: 0 10px 48px rgba(60,80,180,0.18),0 2px 12px rgba(60,80,180,0.09);
  --accent:    #4c5ce8;
  --accent2:   #9f7df5;
  --green:     #16a34a;
  --amber:     #d97706;
  --red:       #dc2626;
  --text:      #0f1117;
  --text2:     #3d4455;
  --text3:     #7a8299;
  --border:    rgba(255,255,255,0.92);
  --topbar-h:  64px;
  --radius:    18px;
  --radius-md: 12px;
  --radius-sm: 9px;
  --sans:      'Instrument Sans', sans-serif;
  --serif:     'Instrument Serif', serif;
  --mono:      'DM Mono', monospace;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:15px; }
body {
  font-family:var(--sans); background:var(--bg); color:var(--text);
  min-height:100vh; overflow-x:hidden;
}
body::before {
  content:''; position:fixed; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse 800px 600px at 10% 5%,  rgba(159,125,245,.20) 0%,transparent 70%),
    radial-gradient(ellipse 600px 500px at 90% 85%, rgba(76,92,232,.17)   0%,transparent 70%),
    radial-gradient(ellipse 500px 400px at 55% 40%, rgba(22,163,74,.08)   0%,transparent 70%);
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; }
input,select,textarea,button { font-family:var(--sans); }

/* ── Glass ───────────────────────────────────────────────── */
.glass {
  background:var(--glass); backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.glass-sm {
  background:var(--glass-s); backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border); border-radius:var(--radius-md);
  box-shadow:var(--shadow);
}

/* ── Topbar desktop ──────────────────────────────────────── */
.topbar-desktop {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:var(--topbar-h);
  display:flex; align-items:center; gap:0;
  background:var(--glass-b); backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  border-bottom:1.5px solid rgba(200,205,230,0.6);
  box-shadow:var(--shadow); padding:0 28px;
}
.topbar-mobile { display:none; }

.tb-brand {
  font-family:var(--serif); font-style:italic; font-size:22px;
  letter-spacing:-.3px; flex-shrink:0; margin-right:24px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.tb-stats { display:flex; align-items:center; gap:0; flex-shrink:0; }
.tb-stat  {
  display:flex; flex-direction:column; align-items:center;
  padding:0 18px; cursor:pointer; transition:opacity .15s;
}
.tb-stat:hover { opacity:.7; }
.tb-stat-val { font-size:17px; font-weight:700; letter-spacing:-.5px; color:var(--text); line-height:1.1; }
.tb-stat-lbl { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:.8px; margin-top:1px; }
.tb-sep  { width:1px; height:30px; background:rgba(0,0,0,.10); flex-shrink:0; }
.tb-actions { display:flex; align-items:center; gap:10px; margin-left:auto; }

.tb-search-wrap { position:relative; }
.tb-search-icon { position:absolute; left:11px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:14px; pointer-events:none; }
.tb-search-input {
  background:rgba(255,255,255,.75); border:1.5px solid rgba(200,210,240,.7);
  border-radius:var(--radius-sm); padding:9px 14px 9px 34px;
  font-family:var(--sans); font-size:13px; color:var(--text);
  width:220px; outline:none; transition:border .2s,width .3s,box-shadow .2s;
}
.tb-search-input:focus {
  border-color:rgba(76,92,232,.5); width:280px;
  box-shadow:0 0 0 3px rgba(76,92,232,.1);
  background:rgba(255,255,255,.95);
}
.tb-search-input::placeholder { color:var(--text3); }
.tb-dropdown {
  position:absolute; top:calc(100% + 6px); left:0; right:0;
  background:var(--glass-b); backdrop-filter:blur(20px);
  border:1px solid var(--border); border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg); z-index:500; max-height:300px; overflow-y:auto;
}
.tb-btn-icon {
  width:40px; height:40px; border-radius:var(--radius-sm);
  background:rgba(255,255,255,.7); border:1.5px solid rgba(200,210,240,.7);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--text2); font-size:16px; transition:all .15s;
}
.tb-btn-icon:hover { background:rgba(76,92,232,.1); color:var(--accent); border-color:rgba(76,92,232,.3); }
.tb-btn-add {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 20px; background:linear-gradient(135deg,var(--accent),#6c3aed);
  color:#fff; border:none; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; cursor:pointer;
  box-shadow:0 3px 14px rgba(76,92,232,.35); transition:all .2s;
}
.tb-btn-add:hover { transform:translateY(-1px); box-shadow:0 5px 20px rgba(76,92,232,.45); }
.tb-btn-ghost {
  display:inline-flex; align-items:center; gap:7px; padding:9px 18px;
  background:rgba(255,255,255,.6); border:1.5px solid rgba(200,210,240,.7);
  border-radius:var(--radius-sm); font-size:13px; font-weight:500;
  color:var(--text2); cursor:pointer; transition:all .2s;
}
.tb-btn-ghost:hover { background:rgba(255,255,255,.95); color:var(--text); }

.tb-user-wrap { position:relative; }
.tb-avatar {
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:13px; font-weight:600; cursor:pointer;
  box-shadow:0 2px 8px rgba(76,92,232,.35);
}
.tb-user-menu {
  display:none; position:absolute; top:calc(100% + 8px); right:0;
  background:var(--glass-b); backdrop-filter:blur(20px);
  border:1px solid var(--border); border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg); padding:4px; min-width:160px; z-index:300;
}
.tb-user-wrap:hover .tb-user-menu { display:block; }
.tb-user-menu a {
  display:flex; align-items:center; gap:8px; padding:10px 13px;
  border-radius:8px; font-size:13px; color:var(--text2); transition:background .12s;
}
.tb-user-menu a:hover { background:rgba(220,38,38,.07); color:var(--red); }

/* ── Main ────────────────────────────────────────────────── */
.main-content {
  padding:calc(var(--topbar-h) + 28px) 36px 100px;
  max-width:1700px; margin:0 auto;
}

/* ── Bottom nav mobile ───────────────────────────────────── */
.bottom-nav {
  position:fixed; bottom:0; left:0; right:0;
  display:none; padding:8px 16px 14px; z-index:200;
}
.bottom-nav::before {
  content:''; position:absolute; inset:0;
  background:var(--glass-b); backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-top:1.5px solid rgba(200,210,240,.6);
  box-shadow:0 -4px 24px rgba(60,80,180,.1);
}
.bn-btn {
  display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:6px 8px; border-radius:12px; font-size:10px; color:var(--text3);
  font-family:var(--mono); transition:all .15s; flex:1; position:relative; z-index:1;
}
.bn-btn.on,.bn-btn:hover { color:var(--accent); }
.bn-btn.on { background:rgba(76,92,232,.09); }
.bn-btn i  { font-size:21px; }
.scanner-fab {
  width:50px; height:50px; border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#6c3aed);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:21px; box-shadow:0 4px 18px rgba(76,92,232,.45);
  margin-top:-18px;
}

/* ── Page header ─────────────────────────────────────────── */
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:26px; }
.page-title  { font-family:var(--serif); font-style:italic; font-size:32px; letter-spacing:-.5px; color:var(--text); }
.page-sub    { font-size:13px; color:var(--text2); margin-top:3px; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; gap:7px; padding:11px 22px;
  background:linear-gradient(135deg,var(--accent),#6c3aed); color:#fff;
  border:none; border-radius:var(--radius-sm); font-size:13px; font-weight:600;
  cursor:pointer; box-shadow:0 4px 16px rgba(76,92,232,.30); transition:all .2s;
}
.btn-primary:hover { transform:translateY(-1px); }
.btn-primary.btn-sm { padding:7px 14px; font-size:12px; }
.btn-ghost {
  display:inline-flex; align-items:center; gap:7px; padding:11px 20px;
  background:var(--glass-s); border:1.5px solid rgba(200,210,240,.7);
  border-radius:var(--radius-sm); font-size:13px; font-weight:500;
  color:var(--text2); cursor:pointer; transition:all .2s;
}
.btn-ghost:hover { background:rgba(255,255,255,.98); color:var(--text); }
.btn-danger {
  display:inline-flex; align-items:center; gap:7px; padding:9px 18px;
  background:rgba(220,38,38,.09); border:1.5px solid rgba(220,38,38,.25);
  border-radius:var(--radius-sm); color:var(--red);
  font-size:13px; font-weight:500; cursor:pointer; transition:all .2s;
}
.btn-danger:hover { background:rgba(220,38,38,.16); }

/* ── Stats dashboard ─────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:26px; }
.stat-card  { padding:22px 20px; }
.stat-val   { font-size:36px; font-weight:700; letter-spacing:-1.5px; line-height:1; color:var(--text); }
.stat-val.accent { color:var(--accent); }
.stat-val.green  { color:var(--green); }
.stat-val.amber  { color:var(--amber); }
.stat-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1.5px; margin-top:8px; }
.stat-sub   { font-size:12px; color:var(--text2); margin-top:4px; }
.dash-grid  { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.dash-block { padding:22px 24px; }
.block-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.block-title  { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:1.5px; }
.block-link   { font-size:12px; color:var(--accent); font-weight:500; }

/* ── Recent list ─────────────────────────────────────────── */
.recent-list { display:flex; flex-direction:column; }
.recent-item {
  display:flex; align-items:center; gap:14px; padding:11px 8px;
  border-bottom:1px solid rgba(0,0,0,.06); border-radius:8px; transition:background .15s;
}
.recent-item:last-child { border-bottom:none; }
.recent-item:hover { background:rgba(76,92,232,.05); }
.recent-info   { flex:1; min-width:0; }
.recent-title  { font-size:14px; font-weight:600; color:var(--text); }
.recent-artist { font-size:12px; color:var(--text2); margin-top:2px; }
.vinyl-disc-sm {
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  background:conic-gradient(#d0d3e8 0 18deg,#bbbfda 18deg 36deg,#d0d3e8 36deg 54deg,#bbbfda 54deg 72deg,#d0d3e8 72deg 90deg,#bbbfda 90deg 108deg,#d0d3e8 108deg 126deg,#bbbfda 126deg 144deg,#d0d3e8 144deg 162deg,#bbbfda 162deg 180deg,#d0d3e8 180deg 198deg,#bbbfda 198deg 216deg,#d0d3e8 216deg 234deg,#bbbfda 234deg 252deg,#d0d3e8 252deg 270deg,#bbbfda 270deg 288deg,#d0d3e8 288deg 306deg,#bbbfda 306deg 324deg,#d0d3e8 324deg 342deg,#bbbfda 342deg 360deg);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.vinyl-disc-sm::after { content:''; width:13px; height:13px; border-radius:50%; background:var(--bg); border:2px solid rgba(255,255,255,.8); }
.vinyl-disc-sm.colored { background:conic-gradient(#b8d8f0 0 18deg,#90bce0 18deg 36deg,#b8d8f0 36deg 54deg,#90bce0 54deg 72deg,#b8d8f0 72deg 90deg,#90bce0 90deg 108deg,#b8d8f0 108deg 126deg,#90bce0 126deg 144deg,#b8d8f0 144deg 162deg,#90bce0 162deg 180deg,#b8d8f0 180deg 198deg,#90bce0 198deg 216deg,#b8d8f0 216deg 234deg,#90bce0 234deg 252deg,#b8d8f0 252deg 270deg,#90bce0 270deg 288deg,#b8d8f0 288deg 306deg,#90bce0 306deg 324deg,#b8d8f0 324deg 342deg,#90bce0 342deg 360deg); }

/* ── State pills ─────────────────────────────────────────── */
.state-pill { font-family:var(--mono); font-size:10px; font-weight:600; padding:4px 10px; border-radius:20px; flex-shrink:0; }
.state-m,.state-nm      { background:rgba(22,163,74,.13);  color:var(--green); border:1px solid rgba(22,163,74,.2); }
.state-vgplus,.state-vg { background:rgba(217,119,6,.12);  color:var(--amber); border:1px solid rgba(217,119,6,.2); }
.state-gplus,.state-g   { background:rgba(220,38,38,.10);  color:var(--red);   border:1px solid rgba(220,38,38,.18); }
.state-f,.state-p       { background:rgba(61,68,85,.10);   color:var(--text2); border:1px solid rgba(61,68,85,.15); }

/* ── Finances ────────────────────────────────────────────── */
.fin-table { display:flex; flex-direction:column; }
.fin-row   { display:flex; justify-content:space-between; align-items:center; padding:9px 0; border-bottom:1px solid rgba(0,0,0,.06); font-size:13px; }
.fin-row:last-child { border-bottom:none; }
.fin-key   { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:.5px; }
.fin-val   { font-family:var(--mono); font-size:12px; font-weight:600; color:var(--text); }
.fin-val.green { color:var(--green); }
.fin-val.red   { color:var(--red); }
.etat-bars { display:flex; flex-direction:column; gap:7px; }
.etat-row  { display:flex; align-items:center; gap:10px; font-size:12px; }
.etat-label { font-family:var(--mono); font-size:10px; width:30px; color:var(--text2); font-weight:600; }
.etat-bar-wrap { flex:1; height:6px; background:rgba(0,0,0,.08); border-radius:3px; overflow:hidden; }
.etat-bar { height:100%; background:linear-gradient(90deg,var(--accent),var(--accent2)); border-radius:3px; }
.etat-count { font-family:var(--mono); font-size:10px; color:var(--text3); min-width:26px; text-align:right; }
.genre-cloud { display:flex; flex-wrap:wrap; gap:7px; }
.genre-chip {
  font-family:var(--mono); font-size:10px; padding:7px 14px; border-radius:20px;
  background:rgba(255,255,255,.65); border:1.5px solid rgba(200,210,240,.7);
  color:var(--text2); cursor:pointer; transition:all .15s;
  display:flex; align-items:center; gap:6px;
}
.genre-chip:hover { background:rgba(76,92,232,.09); color:var(--accent); border-color:rgba(76,92,232,.3); }
.genre-count { font-size:9px; color:var(--text3); }
.pays-list { display:flex; flex-direction:column; gap:4px; }
.pays-row  { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid rgba(0,0,0,.06); font-size:13px; }
.pays-name { color:var(--text2); font-weight:500; }
.pays-n    { font-family:var(--mono); font-size:11px; font-weight:600; color:var(--accent); }

/* ── Collection page ─────────────────────────────────────── */
.collection-page { padding-top:4px; }
.mobile-filter-bar { display:none; gap:10px; align-items:center; margin-bottom:16px; }
.search-wrap  { position:relative; flex:1; }
.search-icon  { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:14px; }
.search-input {
  width:100%; background:var(--glass-s); backdrop-filter:blur(12px);
  border:1.5px solid rgba(200,210,240,.7); border-radius:var(--radius-md);
  padding:12px 14px 12px 40px; font-size:14px; color:var(--text); outline:none;
  box-shadow:var(--shadow); transition:border .2s,box-shadow .2s;
}
.search-input:focus { border-color:rgba(76,92,232,.5); box-shadow:0 0 0 3px rgba(76,92,232,.1),var(--shadow); }
.search-input::placeholder { color:var(--text3); }

/* ── Grille vinyles — cartes grandes ─────────────────────── */
.vinyl-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:18px;
}
.vinyl-card {
  background:var(--glass); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1.5px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
  overflow:hidden; cursor:pointer; transition:transform .2s,box-shadow .2s;
}
.vinyl-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.vinyl-card:hover .vc-overlay { opacity:1; }

/* Cover CARRÉ — c'est le bloc clé */
.vc-cover {
  width:100%;
  padding-top:100%; /* ratio 1:1 */
  position:relative;
  background:linear-gradient(135deg,#d8daf2,#c4c8e8);
  overflow:hidden;
}
.vc-cover img,
.vc-disc,
.vc-overlay {
  position:absolute;
  top:0; left:0; width:100%; height:100%;
}
.vc-cover img   { object-fit:cover; }
.vc-disc {
  display:flex; align-items:center; justify-content:center;
  background:transparent;
}
/* Disque SVG-like via pseudo */
.vc-disc::before {
  content:'';
  width:62%; aspect-ratio:1; border-radius:50%;
  display:block;
  background:conic-gradient(#b4b8cc 0 12deg,#a0a4b8 12deg 24deg,#b4b8cc 24deg 36deg,#a0a4b8 36deg 48deg,#b4b8cc 48deg 60deg,#a0a4b8 60deg 72deg,#b4b8cc 72deg 84deg,#a0a4b8 84deg 96deg,#b4b8cc 96deg 108deg,#a0a4b8 108deg 120deg,#b4b8cc 120deg 132deg,#a0a4b8 132deg 144deg,#b4b8cc 144deg 156deg,#a0a4b8 156deg 168deg,#b4b8cc 168deg 180deg,#a0a4b8 180deg 192deg,#b4b8cc 192deg 204deg,#a0a4b8 204deg 216deg,#b4b8cc 216deg 228deg,#a0a4b8 228deg 240deg,#b4b8cc 240deg 252deg,#a0a4b8 252deg 264deg,#b4b8cc 264deg 276deg,#a0a4b8 276deg 288deg,#b4b8cc 288deg 300deg,#a0a4b8 300deg 312deg,#b4b8cc 312deg 324deg,#a0a4b8 324deg 336deg,#b4b8cc 336deg 348deg,#a0a4b8 348deg 360deg);
  box-shadow:0 4px 18px rgba(0,0,0,.15);
  position:relative;
}
.vc-disc::after {
  content:''; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:19%; aspect-ratio:1; border-radius:50%;
  background:#d8daf2; border:3px solid rgba(255,255,255,.8);
  pointer-events:none;
}
.vc-disc.colored::before { background:conic-gradient(#a8c8e8 0 12deg,#88b0d8 12deg 24deg,#a8c8e8 24deg 36deg,#88b0d8 36deg 48deg,#a8c8e8 48deg 60deg,#88b0d8 60deg 72deg,#a8c8e8 72deg 84deg,#88b0d8 84deg 96deg,#a8c8e8 96deg 108deg,#88b0d8 108deg 120deg,#a8c8e8 120deg 132deg,#88b0d8 132deg 144deg,#a8c8e8 144deg 156deg,#88b0d8 156deg 168deg,#a8c8e8 168deg 180deg,#88b0d8 180deg 192deg,#a8c8e8 192deg 204deg,#88b0d8 204deg 216deg,#a8c8e8 216deg 228deg,#88b0d8 228deg 240deg,#a8c8e8 240deg 252deg,#88b0d8 252deg 264deg,#a8c8e8 264deg 276deg,#88b0d8 276deg 288deg,#a8c8e8 288deg 300deg,#88b0d8 300deg 312deg,#a8c8e8 312deg 324deg,#88b0d8 324deg 336deg,#a8c8e8 336deg 348deg,#88b0d8 348deg 360deg); }

.vc-tag {
  position:absolute; top:9px; left:9px; z-index:2;
  font-family:var(--mono); font-size:9px; padding:3px 9px; border-radius:10px;
  background:rgba(255,255,255,.88); backdrop-filter:blur(8px);
  color:var(--text2); border:1px solid rgba(255,255,255,.95);
  font-weight:600;
}
.vc-heart { position:absolute; top:9px; right:9px; font-size:14px; z-index:2; }
.vc-overlay {
  background:rgba(76,92,232,.15); opacity:0; transition:opacity .2s;
  display:flex; align-items:center; justify-content:center; z-index:2;
}
.vc-body  { padding:12px 14px; }
.vc-title { font-size:14px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.vc-artist { font-size:12px; color:var(--text2); margin-top:3px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.vc-footer { display:flex; justify-content:space-between; align-items:center; padding:9px 14px; border-top:1px solid rgba(0,0,0,.06); }
.vc-price  { font-family:var(--mono); font-size:12px; font-weight:700; color:var(--accent); }

/* ── MODALE AJOUT — Plein écran avec panneau filtres ─────── */
.modal-overlay {
  position:fixed; inset:0; z-index:1000;
  background:rgba(232,234,244,.97); backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  flex-direction:column; overflow:hidden;
  display:none;
}
.modal-overlay.open { display:flex; }

.modal-box { width:100%; height:100%; display:flex; flex-direction:column; }

.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; border-bottom:1.5px solid rgba(200,210,240,.6); flex-shrink:0;
  background:rgba(255,255,255,.75); backdrop-filter:blur(16px);
}
.modal-title { font-family:var(--serif); font-style:italic; font-size:20px; color:var(--text); }
.modal-close {
  width:34px; height:34px; border-radius:50%;
  border:1.5px solid rgba(200,210,240,.8); background:rgba(255,255,255,.7);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--text2); transition:all .15s;
}
.modal-close:hover { background:rgba(220,38,38,.1); color:var(--red); border-color:rgba(220,38,38,.3); }

.mfp-filter-toggle {
  display:flex; align-items:center; gap:7px; padding:8px 16px;
  border-radius:var(--radius-sm); background:rgba(255,255,255,.7);
  border:1.5px solid rgba(200,210,240,.8);
  font-size:13px; font-weight:600; color:var(--text2); cursor:pointer; transition:all .2s;
}
.mfp-filter-toggle:hover,.mfp-filter-toggle.on {
  background:rgba(76,92,232,.1); color:var(--accent); border-color:rgba(76,92,232,.3);
}
.mfbt-badge {
  background:var(--accent); color:#fff; border-radius:20px;
  font-family:var(--mono); font-size:10px; font-weight:700; padding:1px 7px;
}

.modal-body-layout { flex:1; display:flex; overflow:hidden; }
.modal-main-col    { flex:1; display:flex; flex-direction:column; overflow:hidden; }

.modal-search-bar {
  display:flex; flex-direction:column; align-items:center;
  padding:18px 24px 12px; border-bottom:1px solid rgba(200,210,240,.5); flex-shrink:0;
}
.modal-search-wrap {
  position:relative; display:flex; align-items:center; gap:10px;
  width:100%; max-width:540px;
}
.modal-scan-btn {
  width:44px; height:44px; flex-shrink:0; border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),#6c3aed); border:none;
  color:#fff; font-size:19px; cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 3px 12px rgba(76,92,232,.35);
}
.modal-search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:15px; pointer-events:none; }
.modal-search-input {
  flex:1; background:rgba(255,255,255,.92); border:2px solid rgba(200,210,240,.8);
  border-radius:var(--radius-sm); padding:12px 44px 12px 40px;
  font-size:15px; color:var(--text); outline:none;
  box-shadow:var(--shadow); transition:border .2s,box-shadow .2s;
}
.modal-search-input:focus { border-color:rgba(76,92,232,.5); box-shadow:0 0 0 4px rgba(76,92,232,.1); background:#fff; }
.modal-search-input::placeholder { color:var(--text3); }
.modal-spinner {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  width:17px; height:17px; border:2.5px solid rgba(76,92,232,.15);
  border-top-color:var(--accent); border-radius:50%; display:none; animation:spin .7s linear infinite;
}
.modal-spinner.on { display:block; }

.mfp-active-filters { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; margin-top:9px; }
.mfp-af-chip {
  display:flex; align-items:center; gap:5px; font-family:var(--mono); font-size:10px;
  padding:4px 10px; border-radius:20px; background:rgba(76,92,232,.12); color:var(--accent);
  border:1.5px solid rgba(76,92,232,.25); font-weight:600; cursor:pointer;
}
.mfp-af-chip:hover { background:rgba(220,38,38,.1); color:var(--red); }

.modal-scan-zone { padding:0 24px 10px; max-width:540px; margin:0 auto; width:100%; flex-shrink:0; }
.modal-results-area { flex:1; overflow-y:auto; padding:18px 24px; scrollbar-width:thin; }
.modal-results-hint { font-family:var(--mono); font-size:11px; color:var(--text3); letter-spacing:1px; text-align:center; padding:48px 0; font-weight:600; }
.modal-results-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(165px,1fr)); gap:13px; }
.modal-footer { padding:12px 24px; border-top:1.5px solid rgba(200,210,240,.6); display:flex; justify-content:center; flex-shrink:0; background:rgba(255,255,255,.5); }

/* Panneau filtres coulissant */
.modal-filter-panel {
  width:0; overflow:hidden;
  background:var(--glass-b); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-left:1.5px solid rgba(200,210,240,.7);
  transition:width .25s ease; flex-shrink:0; display:flex; flex-direction:column;
}
.modal-filter-panel.open { width:300px; }
.mfp-panel-inner { width:300px; height:100%; overflow-y:auto; padding:20px 18px 80px; scrollbar-width:thin; }
.mfp-panel-title { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:2px; font-weight:700; margin-bottom:20px; padding-bottom:10px; border-bottom:1.5px solid rgba(0,0,0,.08); }
.mfp-filter-group { margin-bottom:20px; }
.mfp-filter-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1.5px; font-weight:700; margin-bottom:9px; }
.mfb-chips { display:flex; flex-wrap:wrap; gap:6px; }
.msf-chip {
  font-family:var(--mono); font-size:10px; padding:6px 12px; border-radius:20px;
  background:rgba(255,255,255,.7); border:1.5px solid rgba(200,210,240,.7);
  color:var(--text2); cursor:pointer; transition:all .15s; font-weight:500;
}
.msf-chip:hover { color:var(--accent); border-color:rgba(76,92,232,.3); }
.msf-chip.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.mfp-panel-actions { padding-top:16px; border-top:1.5px solid rgba(0,0,0,.08); }

/* Cartes résultats */
.mfp-result-card { background:var(--glass-s); backdrop-filter:blur(12px); border:1.5px solid var(--border); border-radius:var(--radius-md); overflow:hidden; cursor:pointer; transition:all .18s; display:flex; flex-direction:column; }
.mfp-result-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:rgba(76,92,232,.35); }
.mfp-rc-cover { width:100%; padding-top:100%; background:linear-gradient(135deg,#d8daf2,#c4c8e8); position:relative; overflow:hidden; }
.mfp-rc-cover img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.mfp-rc-disc { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.mfp-rc-disc::before { content:''; width:60%; aspect-ratio:1; border-radius:50%; background:conic-gradient(#b4b8cc 0 15deg,#a0a4b8 15deg 30deg,#b4b8cc 30deg 45deg,#a0a4b8 45deg 60deg,#b4b8cc 60deg 75deg,#a0a4b8 75deg 90deg,#b4b8cc 90deg 105deg,#a0a4b8 105deg 120deg,#b4b8cc 120deg 135deg,#a0a4b8 135deg 150deg,#b4b8cc 150deg 165deg,#a0a4b8 165deg 180deg,#b4b8cc 180deg 195deg,#a0a4b8 195deg 210deg,#b4b8cc 210deg 225deg,#a0a4b8 225deg 240deg,#b4b8cc 240deg 255deg,#a0a4b8 255deg 270deg,#b4b8cc 270deg 285deg,#a0a4b8 285deg 300deg,#b4b8cc 300deg 315deg,#a0a4b8 315deg 330deg,#b4b8cc 330deg 345deg,#a0a4b8 345deg 360deg); display:block; box-shadow:0 3px 12px rgba(0,0,0,.12); }
.mfp-rc-body { padding:10px 12px 12px; }
.mfp-rc-title  { font-size:13px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mfp-rc-artist { font-size:11px; color:var(--text2); margin-top:2px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mfp-rc-meta   { font-family:var(--mono); font-size:9px; color:var(--text3); margin-top:4px; line-height:1.5; }
.mfp-rc-price  { font-family:var(--mono); font-size:10px; color:var(--green); margin-top:4px; font-weight:700; }
.mfp-rc-rarity { display:flex; gap:1px; margin-top:4px; font-size:11px; }
.mfp-no-result { grid-column:1/-1; text-align:center; padding:48px; color:var(--text2); font-size:14px; }

/* ── MODALE FILTRES ──────────────────────────────────────── */
.modal-filters { position:fixed; inset:0; z-index:900; }
.mf-backdrop   { position:absolute; inset:0; background:rgba(0,0,0,.25); backdrop-filter:blur(4px); }
.mf-panel {
  position:absolute; top:0; right:0; bottom:0; width:400px;
  background:var(--glass-b); backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  border-left:1.5px solid rgba(200,210,240,.6); box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column;
}
.mf-header { display:flex; align-items:center; justify-content:space-between; padding:22px 26px; border-bottom:1px solid rgba(0,0,0,.07); flex-shrink:0; }
.mf-title  { font-family:var(--serif); font-style:italic; font-size:22px; color:var(--text); }
.mf-body   { flex:1; overflow-y:auto; padding:20px 26px; scrollbar-width:thin; }
.mf-section { margin-bottom:26px; }
.mf-section-title { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:2px; margin-bottom:12px; font-weight:600; }
.mf-chips  { display:flex; flex-wrap:wrap; gap:7px; }
.mf-chip   {
  font-family:var(--mono); font-size:10px; padding:7px 14px; border-radius:20px;
  background:rgba(255,255,255,.65); border:1.5px solid rgba(200,210,240,.7);
  color:var(--text2); cursor:pointer; transition:all .15s; font-weight:500;
}
.mf-chip:hover { background:rgba(76,92,232,.09); color:var(--accent); border-color:rgba(76,92,232,.3); }
.mf-chip.on    { background:var(--accent); color:#fff; border-color:var(--accent); }
.mf-footer { display:flex; gap:12px; padding:18px 26px; border-top:1px solid rgba(0,0,0,.07); flex-shrink:0; }
.mf-footer .tb-btn-add { flex:1; justify-content:center; }

/* ── Dropdown search results ─────────────────────────────── */
.ss-result-item {
  display:flex; align-items:center; gap:12px; padding:11px 14px;
  cursor:pointer; border-bottom:1px solid rgba(0,0,0,.05); transition:background .12s;
}
.ss-result-item:last-child { border-bottom:none; }
.ss-result-item:hover { background:rgba(76,92,232,.05); }
.ss-result-thumb { width:38px; height:38px; border-radius:7px; background:linear-gradient(135deg,#d8daf2,#c4c8e8); flex-shrink:0; overflow:hidden; }
.ss-result-thumb img { width:100%; height:100%; object-fit:cover; }
.ss-result-title  { font-size:13px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ss-result-artist { font-size:11px; color:var(--text2); margin-top:1px; }
.ss-result-meta   { font-family:var(--mono); font-size:9px; color:var(--text3); margin-top:2px; }
.ss-empty { padding:16px; font-size:13px; color:var(--text2); text-align:center; }

/* ── FICHE VINYLE ────────────────────────────────────────── */
.breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:26px; font-size:13px; color:var(--text3); }
.breadcrumb a { color:var(--text2); font-weight:500; transition:color .15s; }
.breadcrumb a:hover { color:var(--accent); }
.bc-current { color:var(--text); font-weight:600; }
.breadcrumb span { opacity:.4; }

.fiche-layout { display:grid; grid-template-columns:260px 1fr; gap:32px; align-items:start; }
.fiche-aside  { display:flex; flex-direction:column; gap:14px; position:sticky; top:calc(var(--topbar-h)+20px); }

.fiche-cover-card {
  width:100%; aspect-ratio:1; border-radius:var(--radius);
  background:linear-gradient(135deg,#d8daf2,#c4c8e8);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; position:relative; box-shadow:var(--shadow-lg);
}
.fiche-cover-card img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.fiche-big-disc {
  width:75%; aspect-ratio:1; border-radius:50%;
  background:conic-gradient(#b0b4c8 0 10deg,#a0a4b8 10deg 20deg,#b0b4c8 20deg 30deg,#a0a4b8 30deg 40deg,#b0b4c8 40deg 50deg,#a0a4b8 50deg 60deg,#b0b4c8 60deg 70deg,#a0a4b8 70deg 80deg,#b0b4c8 80deg 90deg,#a0a4b8 90deg 100deg,#b0b4c8 100deg 110deg,#a0a4b8 110deg 120deg,#b0b4c8 120deg 130deg,#a0a4b8 130deg 140deg,#b0b4c8 140deg 150deg,#a0a4b8 150deg 160deg,#b0b4c8 160deg 170deg,#a0a4b8 170deg 180deg,#b0b4c8 180deg 190deg,#a0a4b8 190deg 200deg,#b0b4c8 200deg 210deg,#a0a4b8 210deg 220deg,#b0b4c8 220deg 230deg,#a0a4b8 230deg 240deg,#b0b4c8 240deg 250deg,#a0a4b8 250deg 260deg,#b0b4c8 260deg 270deg,#a0a4b8 270deg 280deg,#b0b4c8 280deg 290deg,#a0a4b8 290deg 300deg,#b0b4c8 300deg 310deg,#a0a4b8 310deg 320deg,#b0b4c8 320deg 330deg,#a0a4b8 330deg 340deg,#b0b4c8 340deg 350deg,#a0a4b8 350deg 360deg);
  position:relative; box-shadow:0 8px 32px rgba(0,0,0,.14); display:flex; align-items:center; justify-content:center;
}
.fiche-big-disc::after { content:''; width:25%; aspect-ratio:1; border-radius:50%; background:#d8daf2; border:3px solid rgba(255,255,255,.75); }
.fiche-fav-btn {
  position:absolute; top:12px; right:12px;
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.82); backdrop-filter:blur(8px);
  border:1.5px solid rgba(255,255,255,.95); display:flex; align-items:center; justify-content:center;
  font-size:17px; cursor:pointer; transition:all .2s; color:var(--text3); box-shadow:var(--shadow);
}
.fiche-fav-btn.is-fav { color:var(--red); background:rgba(220,38,38,.12); border-color:rgba(220,38,38,.25); }
.fiche-fav-btn:hover { transform:scale(1.1); }
.fiche-statut-badge {
  position:absolute; bottom:12px; left:12px;
  font-family:var(--mono); font-size:10px; padding:5px 13px; border-radius:20px;
  background:rgba(255,255,255,.85); backdrop-filter:blur(8px);
  color:var(--text2); border:1.5px solid rgba(255,255,255,.95); font-weight:600;
}
.fiche-statut-badge.green  { color:var(--green); background:rgba(22,163,74,.13); border-color:rgba(22,163,74,.25); }
.fiche-statut-badge.accent { color:var(--accent); background:rgba(76,92,232,.13); border-color:rgba(76,92,232,.25); }

.fiche-my-note { padding:13px 15px; }
.fmn-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1px; margin-bottom:7px; font-weight:600; }
.fmn-stars { display:flex; align-items:center; gap:4px; font-size:17px; }
.fmn-stars span { font-family:var(--mono); font-size:12px; color:var(--text2); margin-left:6px; font-weight:600; }

.fiche-my-photos { padding:13px 15px; }
.fiche-photos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:7px; margin-top:9px; }
.fiche-photo-thumb { aspect-ratio:1; border-radius:9px; overflow:hidden; display:block; }
.fiche-photo-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .2s; }
.fiche-photo-thumb:hover img { transform:scale(1.06); }

.fiche-aside-actions { display:flex; flex-direction:column; gap:9px; }
.faa-btn { justify-content:center; width:100%; }

.fiche-main { display:flex; flex-direction:column; gap:32px; }

.fiche-hero { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; }
.fiche-hero-left { flex:1; min-width:0; }
.fiche-title  { font-family:var(--serif); font-style:italic; font-size:38px; letter-spacing:-.5px; line-height:1.1; color:var(--text); }
.fiche-artist { font-size:17px; color:var(--text2); font-weight:600; margin-top:7px; }

.pills-row { display:flex; flex-wrap:wrap; gap:7px; }
.fpill {
  font-family:var(--mono); font-size:10px; padding:5px 13px; border-radius:20px;
  background:rgba(255,255,255,.72); border:1.5px solid rgba(200,210,240,.7);
  color:var(--text2); font-weight:500;
}
.fpill.accent { background:rgba(76,92,232,.12); color:var(--accent); border-color:rgba(76,92,232,.25); font-weight:600; }
.fpill.mono   { font-family:var(--mono); }

.fiche-rarity { display:flex; flex-direction:column; align-items:center; gap:5px; flex-shrink:0; padding:14px 16px; background:rgba(255,255,255,.55); border-radius:var(--radius-sm); border:1.5px solid rgba(200,210,240,.7); }
.fiche-rarity-stars { display:flex; gap:3px; font-size:20px; }
.fiche-rarity-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1px; font-weight:600; }

.fiche-grades { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.fiche-grade-card { padding:16px 18px; }
.fgc-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1px; margin-bottom:7px; font-weight:600; }
.fgc-val   { font-size:26px; font-weight:700; letter-spacing:-.5px; }

.fiche-section { display:flex; flex-direction:column; gap:14px; }
.fiche-section-title {
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:2px;
  padding-bottom:10px; border-bottom:1.5px solid rgba(0,0,0,.08); font-weight:600;
}
.fiche-section-link { font-size:12px; color:var(--accent); display:flex; align-items:center; gap:4px; letter-spacing:0; font-weight:600; }

.fiche-info-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px; }
.fiche-info-cell { padding:12px 14px; }
.fic-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:.8px; margin-bottom:5px; font-weight:600; }
.fic-val   { font-size:14px; font-weight:600; color:var(--text); }

.fiche-hw { display:flex; align-items:center; gap:0; background:rgba(255,255,255,.55); border:1.5px solid rgba(200,210,240,.7); border-radius:var(--radius-md); padding:16px 0; }
.fiche-hw-item { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; padding:0 18px; }
.fiche-hw-item i { font-size:20px; color:var(--text3); }
.fhw-val { font-size:20px; font-weight:700; letter-spacing:-.5px; color:var(--text); }
.fhw-lbl { font-family:var(--mono); font-size:9px; color:var(--text3); font-weight:600; }
.fiche-hw-sep { width:1px; height:44px; background:rgba(0,0,0,.09); flex-shrink:0; }

.fiche-finances { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.ff-card { padding:20px 22px; }
.ff-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1px; margin-bottom:9px; font-weight:600; }
.ff-val   { font-size:28px; font-weight:700; letter-spacing:-.5px; color:var(--text); }
.ff-sub   { font-size:13px; color:var(--text2); margin-top:5px; font-weight:500; }

.fiche-tracklist { border-radius:var(--radius-md); overflow:hidden; }
.ftl-row { display:flex; align-items:center; gap:16px; padding:11px 18px; border-bottom:1px solid rgba(0,0,0,.05); }
.ftl-row:last-child { border-bottom:none; }
.ftl-row:hover { background:rgba(76,92,232,.04); }
.ftl-pos   { font-family:var(--mono); font-size:10px; color:var(--text3); min-width:24px; font-weight:600; }
.ftl-title { flex:1; font-size:14px; color:var(--text); font-weight:500; }
.ftl-dur   { font-family:var(--mono); font-size:10px; color:var(--text3); font-weight:600; }

.fiche-note-perso { padding:22px 24px; display:flex; gap:16px; align-items:flex-start; border-radius:var(--radius-md); }
.fiche-note-icon  { font-size:22px; color:var(--accent); opacity:.5; flex-shrink:0; margin-top:2px; }
.fiche-note-perso p { font-size:15px; color:var(--text2); line-height:1.8; }

.fiche-meta-footer { font-family:var(--mono); font-size:11px; color:var(--text3); padding-top:18px; border-top:1.5px solid rgba(0,0,0,.07); font-weight:500; }

/* ── FORMULAIRE ──────────────────────────────────────────── */
.form-discogs-block {
  background:var(--glass); backdrop-filter:blur(20px);
  border:1.5px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
}
.fdb-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:13px 22px; background:rgba(22,163,74,.07);
  border-bottom:1.5px solid rgba(22,163,74,.18); border-radius:var(--radius) var(--radius) 0 0;
}
.fdb-source { display:flex; align-items:center; gap:8px; }
.fdb-dot    { width:9px; height:9px; border-radius:50%; background:var(--green); flex-shrink:0; }
.fdb-lbl    { font-family:var(--mono); font-size:10px; color:var(--green); letter-spacing:1px; font-weight:700; }
.fdb-link   { font-size:12px; color:var(--accent); display:flex; align-items:center; gap:4px; margin-left:8px; font-weight:600; }
.fdb-lock   { font-family:var(--mono); font-size:9px; color:var(--text3); display:flex; align-items:center; gap:5px; font-weight:600; }
.fdb-preview { display:flex; gap:18px; padding:18px 22px; }
.fdb-cover  { width:86px; height:86px; border-radius:10px; overflow:hidden; flex-shrink:0; box-shadow:var(--shadow); }
.fdb-cover img { width:100%; height:100%; object-fit:cover; }
.fdb-info   { flex:1; }
.fdb-title  { font-family:var(--serif); font-style:italic; font-size:22px; letter-spacing:-.3px; color:var(--text); }
.fdb-artist { font-size:14px; color:var(--text2); margin-top:3px; font-weight:500; }
.fdb-pills  { display:flex; flex-wrap:wrap; gap:5px; margin-top:9px; }
.fdb-pill   { font-family:var(--mono); font-size:9px; padding:3px 9px; border-radius:20px; background:rgba(255,255,255,.72); border:1px solid rgba(200,210,240,.7); color:var(--text2); font-weight:600; }
.fdb-stats  { display:flex; gap:16px; margin-top:9px; font-size:12px; color:var(--text3); flex-wrap:wrap; font-weight:500; }
.fdb-stats span { display:flex; align-items:center; gap:4px; }

.form-card   { padding:22px 24px; }
.form-section-title { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:2px; margin-bottom:16px; font-weight:700; }
.form-grid   { display:grid; grid-template-columns:repeat(2,1fr); gap:15px; }
.form-grid-3 { grid-template-columns:repeat(3,1fr); }
.form-field  { display:flex; flex-direction:column; gap:6px; }
.form-field.full { grid-column:1/-1; }
.form-field label { font-family:var(--mono); font-size:10px; color:var(--text2); letter-spacing:.8px; font-weight:600; }
.field-wrap  { position:relative; }
.field-icon  { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:14px; pointer-events:none; }
.field-input,.field-select,.field-textarea {
  width:100%; background:rgba(255,255,255,.75);
  border:1.5px solid rgba(200,210,240,.7);
  border-radius:var(--radius-sm); padding:11px 14px;
  font-size:14px; color:var(--text); outline:none;
  transition:border .2s,box-shadow .2s; appearance:none;
}
.field-input:focus,.field-select:focus,.field-textarea:focus {
  border-color:rgba(76,92,232,.5); box-shadow:0 0 0 3px rgba(76,92,232,.1);
  background:#fff;
}
.field-input::placeholder { color:var(--text3); }
.field-wrap .field-input { padding-left:38px; }
.field-textarea { resize:vertical; min-height:90px; }
.field-check { display:flex; align-items:center; gap:10px; cursor:pointer; }
.field-check input[type="checkbox"] { width:17px; height:17px; accent-color:var(--accent); }
.form-submit-bar { display:flex; justify-content:flex-end; gap:12px; padding:18px 0 0; border-top:1.5px solid rgba(0,0,0,.08); }

/* Wrapper qui space les glass form-card dans le formulaire */
#vinyleForm { display:flex; flex-direction:column; gap:18px; }

/* Étoiles */
.stars-field { display:flex; align-items:center; gap:5px; padding:8px 0; }
.star-btn    { background:none; border:none; cursor:pointer; font-size:24px; color:var(--text3); padding:2px; transition:all .15s; line-height:1; }
.star-btn.on { color:var(--amber); }
.star-btn.on.accent { color:var(--accent); }
.stars-hint  { font-family:var(--mono); font-size:12px; color:var(--text2); margin-left:8px; font-weight:600; }

/* Statut choices */
.statut-choices { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.statut-choice  {
  display:flex; align-items:center; gap:9px; padding:11px 20px;
  border-radius:var(--radius-sm); background:rgba(255,255,255,.6);
  border:1.5px solid rgba(200,210,240,.7); cursor:pointer; transition:all .15s;
}
.statut-choice.on { border-color:var(--accent); background:rgba(76,92,232,.09); }
.statut-choice:hover { background:rgba(255,255,255,.9); }
.sc-icon { font-size:19px; }
.sc-lbl  { font-size:14px; font-weight:600; color:var(--text); }

/* Photo upload */
.photo-upload-zone {
  display:block; cursor:pointer;
  border:2px dashed rgba(76,92,232,.3); border-radius:var(--radius-md);
  padding:26px; text-align:center; transition:all .2s; background:rgba(76,92,232,.03);
}
.photo-upload-zone:hover { border-color:var(--accent); background:rgba(76,92,232,.07); }
.puz-content { display:flex; flex-direction:column; align-items:center; gap:7px; color:var(--text3); }
.puz-content i { font-size:34px; color:var(--accent); opacity:.6; }
.puz-content span:first-of-type { font-size:14px; font-weight:600; color:var(--text2); }
.puz-hint    { font-family:var(--mono); font-size:10px; color:var(--text3); }
.puz-preview { display:flex; flex-wrap:wrap; gap:9px; margin-top:12px; justify-content:center; }
.puz-thumb   { width:76px; height:76px; border-radius:9px; overflow:hidden; }
.puz-thumb img { width:100%; height:100%; object-fit:cover; }
.existing-photos { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:14px; }
.existing-photo-item { position:relative; cursor:pointer; }
.existing-photo-item img { width:82px; height:82px; border-radius:9px; object-fit:cover; display:block; }
.ep-delete-overlay { display:none; position:absolute; inset:0; background:rgba(220,38,38,.75); border-radius:9px; align-items:center; justify-content:center; color:#fff; font-size:12px; gap:4px; font-weight:600; }
.existing-photo-item:has(input:checked) .ep-delete-overlay { display:flex; }

/* YouTube */
.yt-preview { position:relative; margin-top:9px; border-radius:10px; overflow:hidden; }
.yt-preview img { width:100%; display:block; }
.yt-preview-play { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,.2); color:#fff; font-size:38px; transition:background .2s; }
.yt-preview-play:hover { background:rgba(0,0,0,.4); }
.yt-auto-btn { margin-left:9px; padding:3px 11px; border-radius:6px; background:rgba(76,92,232,.11); border:1.5px solid rgba(76,92,232,.25); color:var(--accent); font-size:10px; font-family:var(--mono); cursor:pointer; transition:all .15s; font-weight:600; }
.yt-auto-btn:hover { background:rgba(76,92,232,.2); }

/* Barre de filtres enrichie modale */
.modal-filters-bar {
  width:100%; max-width:900px;
  display:flex; flex-direction:column; gap:10px;
  margin-top:14px;
}
.mfb-group  { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.mfb-label  { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1.5px; font-weight:700; min-width:56px; flex-shrink:0; }
.mfb-chips  { display:flex; gap:6px; flex-wrap:wrap; }
.mfb-sep    { width:100%; height:1px; background:rgba(0,0,0,.07); }

.yt-wrap { position:relative; padding-bottom:56.25%; height:0; border-radius:var(--radius); overflow:hidden; }
.yt-wrap iframe { position:absolute; inset:0; width:100%; height:100%; }

/* Tags */
.tag-chips-wrap { display:flex; flex-wrap:wrap; gap:7px; align-items:center; padding:9px; background:rgba(255,255,255,.75); border:1.5px solid rgba(200,210,240,.7); border-radius:var(--radius-sm); min-height:46px; }
.tag-chip { font-family:var(--mono); font-size:10px; padding:5px 11px; border-radius:20px; background:rgba(76,92,232,.12); color:var(--accent); display:flex; align-items:center; gap:5px; font-weight:600; }
.tag-remove { background:none; border:none; cursor:pointer; color:var(--accent); font-size:15px; line-height:1; padding:0; }

/* ── LOGIN ───────────────────────────────────────────────── */
.login-body  { overflow:hidden; }
.login-page  { min-height:100vh; display:flex; align-items:center; justify-content:center; position:relative; padding:20px; }
.blob { position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; }
.blob-1 { width:600px; height:600px; background:rgba(159,125,245,.22); top:-150px; left:-150px; }
.blob-2 { width:500px; height:500px; background:rgba(76,92,232,.18); bottom:-100px; right:-100px; }
.blob-3 { width:400px; height:400px; background:rgba(22,163,74,.09); top:40%; left:40%; }
.login-wrap    { position:relative; z-index:1; width:100%; max-width:420px; }
.login-logo    { text-align:center; padding:0 0 34px; }
.login-brand   { font-family:var(--serif); font-style:italic; font-size:58px; letter-spacing:-1px; background:linear-gradient(135deg,var(--accent),var(--accent2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1; }
.login-tagline { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:4px; margin-top:9px; font-weight:600; }
.login-card    { padding:34px 30px; }
.login-card .form-field { margin-bottom:18px; }
.login-card .form-field label { display:block; font-family:var(--mono); font-size:10px; letter-spacing:1.5px; color:var(--text2); margin-bottom:8px; font-weight:700; }
.login-card .field-icon { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:16px; pointer-events:none; z-index:1; }
.login-card .field-input { width:100%; background:rgba(255,255,255,.82); border:1.5px solid rgba(200,210,240,.8); border-radius:var(--radius-sm); padding:13px 14px 13px 42px; font-size:15px; color:var(--text); outline:none; transition:border .2s,box-shadow .2s; }
.login-card .field-input:focus { border-color:rgba(76,92,232,.55); box-shadow:0 0 0 3px rgba(76,92,232,.12); background:#fff; }
.login-card .field-input::placeholder { color:var(--text3); }
.login-error  { display:flex; align-items:center; gap:9px; padding:13px 15px; background:rgba(220,38,38,.09); border:1.5px solid rgba(220,38,38,.25); border-radius:var(--radius-sm); color:var(--red); font-size:14px; margin-bottom:18px; font-weight:500; }
.login-submit { width:100%; justify-content:center; margin-top:9px; padding:14px; font-size:15px; }
.quick-users  { margin-top:22px; padding-top:18px; border-top:1.5px solid rgba(0,0,0,.07); }
.qu-label { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:1px; display:block; margin-bottom:11px; font-weight:700; }
.qu-btns  { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.qu-btn   { display:flex; align-items:center; gap:11px; padding:12px 15px; background:rgba(255,255,255,.65); border:1.5px solid rgba(200,210,240,.7); border-radius:var(--radius-sm); cursor:pointer; transition:all .15s; text-align:left; }
.qu-btn:hover { background:rgba(76,92,232,.08); border-color:rgba(76,92,232,.3); }
.qu-avatar { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:12px; font-weight:700; flex-shrink:0; }
.qu-name   { font-size:14px; font-weight:700; color:var(--text); }
.qu-role   { font-family:var(--mono); font-size:10px; color:var(--text3); font-weight:600; }
.login-footer { text-align:center; font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:2px; margin-top:22px; }

/* ── MISC ────────────────────────────────────────────────── */
.mobile-only  { display:none !important; }
@media (max-width:900px) { .mobile-only { display:inline-flex !important; } }
.desktop-only { display:inline-flex !important; }
@media (max-width:900px) { .desktop-only { display:none !important; } }

.flash-success { position:fixed; top:calc(var(--topbar-h)+12px); right:28px; z-index:500; display:flex; align-items:center; gap:10px; padding:14px 22px; border-radius:var(--radius-sm); background:rgba(22,163,74,.13); border:1.5px solid rgba(22,163,74,.3); color:var(--green); font-size:14px; font-weight:600; backdrop-filter:blur(12px); box-shadow:var(--shadow); animation:slideIn .3s ease; }
@keyframes slideIn { from{transform:translateX(100px);opacity:0} to{transform:none;opacity:1} }

.spinner { width:34px; height:34px; border:3px solid rgba(76,92,232,.15); border-top-color:var(--accent); border-radius:50%; animation:spin .8s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

.empty-state { display:flex; flex-direction:column; align-items:center; gap:14px; padding:48px 20px; color:var(--text2); text-align:center; }
.error-page  { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:60vh; gap:18px; text-align:center; }
.error-code  { font-family:var(--serif); font-style:italic; font-size:88px; color:var(--text3); line-height:1; }

/* Scanner */
.scan-window { border-radius:18px; background:linear-gradient(135deg,rgba(76,92,232,.06),rgba(159,125,245,.09)); border:1.5px solid rgba(200,210,240,.7); position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow); }
.scan-window.detected { border-color:var(--green); box-shadow:0 0 0 3px rgba(22,163,74,.2); }
.scan-corners { position:absolute; inset:20px; pointer-events:none; }
.sc { position:absolute; width:28px; height:28px; }
.sc::before,.sc::after { content:''; position:absolute; background:var(--accent); border-radius:2px; }
.sc.tl::before { width:3px; height:28px; top:0; left:0; }  .sc.tl::after { width:28px; height:3px; top:0; left:0; }
.sc.tr::before { width:3px; height:28px; top:0; right:0; } .sc.tr::after { width:28px; height:3px; top:0; right:0; }
.sc.bl::before { width:3px; height:28px; bottom:0; left:0; }  .sc.bl::after { width:28px; height:3px; bottom:0; left:0; }
.sc.br::before { width:3px; height:28px; bottom:0; right:0; } .sc.br::after { width:28px; height:3px; bottom:0; right:0; }
.scan-laser { display:none; position:absolute; left:20px; right:20px; height:2px; background:linear-gradient(90deg,transparent,var(--accent),transparent); animation:laser 2.5s ease-in-out infinite; box-shadow:0 0 8px var(--accent); }
@keyframes laser { 0%,100%{top:24px;opacity:.9} 50%{top:calc(100% - 26px);opacity:1} }
.scan-placeholder { display:flex; flex-direction:column; align-items:center; gap:9px; color:var(--text3); font-size:13px; }
.scan-placeholder i { font-size:38px; }
#interactive video  { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
#interactive canvas { display:none; }
.scan-formats { display:flex; gap:8px; justify-content:center; }
.sf { font-family:var(--mono); font-size:9px; padding:5px 13px; border-radius:20px; background:rgba(255,255,255,.65); border:1.5px solid rgba(200,210,240,.7); color:var(--text2); font-weight:600; }
.scan-controls { display:flex; gap:12px; justify-content:center; }
.scan-manual   { display:flex; flex-direction:column; gap:9px; padding-top:10px; border-top:1.5px solid rgba(0,0,0,.07); }
.sm-label { font-family:var(--mono); font-size:9px; color:var(--text3); letter-spacing:1px; font-weight:700; }
.sm-row   { display:flex; gap:9px; }
.scanner-layout  { display:grid; grid-template-columns:1fr 1fr; gap:22px; align-items:start; }
.scanner-card    { padding:26px; display:flex; flex-direction:column; gap:18px; }
.scanner-result  { padding:24px; display:flex; flex-direction:column; gap:18px; }
.result-header   { display:flex; align-items:center; justify-content:space-between; }
.result-status   { display:flex; align-items:center; gap:9px; }
.status-dot      { width:9px; height:9px; border-radius:50%; background:var(--text3); }
.status-dot.green { background:var(--green); }
.status-dot.red   { background:var(--red); }
#resultLabel { font-family:var(--mono); font-size:10px; letter-spacing:1px; color:var(--text2); font-weight:600; }
.result-cover { width:100%; max-height:200px; object-fit:cover; border-radius:var(--radius-md); }
.result-rows  { display:flex; flex-direction:column; }
.result-row   { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid rgba(0,0,0,.06); font-size:13px; }
.result-row:last-child { border-bottom:none; }
.rk { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:.5px; font-weight:600; }
.rv { font-weight:600; max-width:55%; text-align:right; color:var(--text); }
.complete-grid { display:grid; grid-template-columns:1fr 1fr; gap:13px; }
.result-cta { display:flex; gap:11px; }
.result-cta .btn-primary { flex:1; justify-content:center; }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width:900px) {
  .topbar-desktop { display:none; }
  .topbar-mobile  {
    display:flex; align-items:center; gap:10px;
    position:sticky; top:0; z-index:200;
    padding:11px 16px;
    background:rgba(232,234,244,.94); backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-bottom:1.5px solid rgba(200,210,240,.6);
    box-shadow:0 2px 12px rgba(60,80,180,.08);
  }
  .tb-brand { font-family:var(--serif); font-style:italic; font-size:19px; flex-shrink:0; background:linear-gradient(135deg,var(--accent),var(--accent2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
  .tb-search-wrap { position:relative; flex:1; }
  .tb-search-input { width:100% !important; padding:10px 14px 10px 34px; font-size:14px; border-radius:10px; }
  .tb-dropdown { position:absolute; top:calc(100% + 6px); left:0; right:0; background:var(--glass-b); backdrop-filter:blur(20px); border:1.5px solid var(--border); border-radius:var(--radius-md); box-shadow:var(--shadow-lg); z-index:600; max-height:290px; overflow-y:auto; }
  .main-content { padding:18px 16px 100px; }
  .bottom-nav   { display:flex; justify-content:space-around; }
  .stats-grid   { grid-template-columns:1fr 1fr; }
  .dash-grid    { grid-template-columns:1fr; }
  .scanner-layout { grid-template-columns:1fr; }
  .fiche-layout   { grid-template-columns:1fr; }
  .fiche-aside    { position:static; }
  .fiche-cover-card { max-width:300px; margin:0 auto; }
  .fiche-grades { grid-template-columns:1fr 1fr; }
  .fiche-info-grid  { grid-template-columns:1fr 1fr; }
  .fiche-finances   { grid-template-columns:1fr; }
  .fiche-hw { flex-direction:column; padding:14px; gap:10px; }
  .fiche-hw-sep { width:100%; height:1.5px; }
  .fiche-hw-item { flex-direction:row; padding:4px 0; gap:12px; justify-content:center; }
  .form-grid    { grid-template-columns:1fr; }
  .form-grid-3  { grid-template-columns:1fr 1fr; }
  .vinyl-grid   { grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:12px; }
  .complete-grid { grid-template-columns:1fr; }
  .mobile-filter-bar { display:flex; }
  .modal-results-grid { grid-template-columns:repeat(auto-fill,minmax(145px,1fr)); }
  .mf-panel { width:100%; border-left:none; border-top:1.5px solid rgba(200,210,240,.6); border-radius:var(--radius) var(--radius) 0 0; top:auto; }
  .modal-search-bar { padding:16px 18px 12px; }
  .modal-search-input { font-size:15px; }
  .modal-results-area { padding:16px 18px; }
  .modal-footer { padding:12px 18px; }
}
@media (max-width:480px) {
  .page-header { flex-direction:column; align-items:flex-start; gap:13px; }
  .stats-grid  { grid-template-columns:1fr 1fr; gap:10px; }
  .stat-val    { font-size:28px; }
  .vinyl-grid  { grid-template-columns:1fr 1fr; gap:10px; }
  .fiche-grades { grid-template-columns:1fr 1fr; }
  .fiche-info-grid { grid-template-columns:1fr 1fr; }
}
