/* ============================================================
   style.css v7 — Brasa Noire
   Mobile first · Breakpoints : 640 / 1024 / 1440
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Sora:wght@300;400;500;600;700&display=swap');

:root {
  --void:#080809;
  --coal:#0D0D0F;
  --charcoal:#141416;
  --slate:#1C1C1F;
  --slate-lt:#252528;
  --ember:#FF6B35;
  --ember-dk:#CC4A1A;
  --amber:#F5A623;
  --amber-lt:#FFD98E;
  --gold:#E8C94A;
  --teal:#2DCFB3;
  --teal-dk:#1A9E88;
  --indigo:#6366F1;
  --cream:#F5E6C8;
  --cream-soft:#C9B99A;
  --cream-mute:#7A6E5E;
  --danger:#FF4444;
  --success:#2DCF7A;
  --warn:#F5A623;
  --glass:rgba(20,20,22,0.62);
  --glass-warm:rgba(30,22,14,0.68);
  --glass-teal:rgba(14,30,28,0.68);
  --glass-border:rgba(255,255,255,0.08);
  --r-xs:8px;
  --r-sm:14px;
  --r:22px;
  --r-lg:30px;
  --blur:20px;
  --shadow:0 4px 20px rgba(0,0,0,0.55),0 1px 3px rgba(0,0,0,0.35);
  --shadow-lg:0 12px 48px rgba(0,0,0,0.65),0 4px 16px rgba(0,0,0,0.45);
  --shadow-ember:0 0 40px rgba(255,107,53,0.18),0 8px 32px rgba(0,0,0,0.60);
  --ease:cubic-bezier(.22,1,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --t-fast:140ms var(--ease);
  --t:220ms var(--ease);
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-tap-highlight-color:transparent; -webkit-text-size-adjust:100%; }
body {
  font-family:'Sora', system-ui, sans-serif;
  font-size:14px;
  color:var(--cream);
  background:var(--coal);
  min-height:100vh; min-height:100dvh;
  line-height:1.6; letter-spacing:-0.01em;
  overflow-x:hidden;
}

/* ============================================================
   DECOR DE FOND
   ============================================================ */
body::before {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 60% 50% at 5% 15%, rgba(255,107,53,0.12), transparent 55%),
    radial-gradient(ellipse 50% 60% at 95% 10%, rgba(245,166,35,0.10), transparent 55%),
    radial-gradient(ellipse 80% 70% at 50% 100%, rgba(255,107,53,0.08), transparent 60%),
    linear-gradient(180deg, #0D0D0F 0%, #0A0A0C 50%, #0D0B09 100%);
  animation:halo 20s ease-in-out infinite alternate;
}
@keyframes halo { 0%,100%{opacity:1} 50%{opacity:0.80} }

.grid-bg {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 80%);
}

.ember-field { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.ember {
  position:absolute; width:3px; height:3px; border-radius:50%;
  background:var(--amber); box-shadow:0 0 6px 2px rgba(245,166,35,0.6);
  animation:rise 8s ease-in infinite; opacity:0;
}
.e1{left:12%;bottom:0;animation-delay:0s;animation-duration:9s}
.e2{left:28%;bottom:0;animation-delay:1.5s;animation-duration:11s;background:var(--ember)}
.e3{left:47%;bottom:0;animation-delay:3s;animation-duration:8s;width:4px;height:4px}
.e4{left:63%;bottom:0;animation-delay:5s;animation-duration:12s;background:var(--gold)}
.e5{left:78%;bottom:0;animation-delay:0.8s;animation-duration:10s}
.e6{left:35%;bottom:0;animation-delay:2.2s;animation-duration:9.5s;background:var(--ember)}
.e7{left:90%;bottom:0;animation-delay:4s;animation-duration:11s}
.e8{left:55%;bottom:0;animation-delay:6.5s;animation-duration:7.5s;background:var(--amber)}
@keyframes rise {
  0%{transform:translateY(0);opacity:0}
  10%{opacity:1}
  60%{opacity:.7;transform:translateY(-40vh) scale(.8)}
  100%{transform:translateY(-100vh) scale(.1);opacity:0}
}

/* ============================================================
   LAYOUT — MOBILE FIRST
   ============================================================ */
.app-shell {
  display:flex; flex-direction:column;
  min-height:100vh; min-height:100dvh;
  position:relative; z-index:1;
}

/* ============================================================
   TOPBAR (mobile + tablette)
   ============================================================ */
.topbar {
  position:sticky; top:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  gap:10px;
  padding:12px 16px;
  padding-top:max(12px, env(safe-area-inset-top));
  background:rgba(8,8,9,0.88);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,0.06);
}

.logo-btn {
  display:flex; align-items:center; gap:11px;
  background:none; border:none; padding:0;
  color:inherit; font-family:inherit;
  cursor:pointer; min-width:0;
  transition:transform var(--t);
}
.logo-btn:active { transform:scale(0.96); }

.logo-flame {
  width:34px; height:34px; flex-shrink:0;
  filter:drop-shadow(0 0 12px rgba(255,107,53,0.45));
  transition:filter var(--t);
}
.logo-btn:hover .logo-flame { filter:drop-shadow(0 0 18px rgba(255,107,53,0.7)); }

.logo-text { display:flex; flex-direction:column; line-height:1; min-width:0; }
.logo-name {
  font-family:'Cormorant Garamond', serif;
  font-size:1.4rem; font-weight:700; font-style:italic;
  letter-spacing:-0.02em;
  background:linear-gradient(135deg, var(--cream), var(--cream-soft));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  white-space:nowrap;
}
.logo-tag {
  font-size:9px; font-weight:700;
  letter-spacing:0.15em; text-transform:uppercase;
  color:var(--amber); margin-top:3px;
  white-space:nowrap;
}

.xp-pill {
  display:flex; align-items:center; gap:8px;
  padding:5px 13px 5px 6px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:99px; cursor:pointer;
  color:inherit; font-family:inherit;
  transition:all var(--t); flex-shrink:0;
}
.xp-pill:active { transform:scale(0.96); }
.xp-pill:hover { background:rgba(255,255,255,0.07); border-color:rgba(245,166,35,0.30); }
.xp-ring-mini { width:32px; height:32px; flex-shrink:0; }
.xp-pill-text { display:flex; flex-direction:column; line-height:1; }
.xp-pill-text .xp-val { font-size:13px; font-weight:700; color:var(--amber); letter-spacing:-0.02em; }
.xp-pill-text .xp-lvl { font-size:9px; color:var(--cream-mute); font-weight:600; letter-spacing:0.05em; text-transform:uppercase; margin-top:2px; }

.xp-ring-fill { transition:stroke-dashoffset 0.7s var(--ease); }

/* ============================================================
   NAVBAR — bottom (mobile) → sidebar (desktop)
   ============================================================ */
.navbar {
  position:fixed; bottom:0; left:0; right:0; z-index:90;
  display:flex;
  background:rgba(8,8,9,0.94);
  backdrop-filter:blur(24px) saturate(150%);
  -webkit-backdrop-filter:blur(24px) saturate(150%);
  border-top:1px solid rgba(255,255,255,0.08);
  padding:5px 5px;
  padding-bottom:max(5px, env(safe-area-inset-bottom));
  box-shadow:0 -8px 32px rgba(0,0,0,0.40);
}
.nav-logo-desktop, .nav-xp-desktop { display:none; }

.nav-items { display:flex; flex:1; min-width:0; }

.nav-item {
  flex:1; min-width:0;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:3px; padding:8px 4px 6px;
  border-radius:14px; border:none; background:transparent;
  color:var(--cream-mute);
  font-family:'Sora', sans-serif;
  cursor:pointer; position:relative;
  transition:color var(--t-fast), background var(--t);
  -webkit-tap-highlight-color:transparent;
}
.nav-item::before {
  content:''; position:absolute;
  top:5px; left:50%; transform:translateX(-50%);
  width:0; height:3px;
  background:linear-gradient(90deg, var(--ember), var(--amber));
  border-radius:99px; opacity:0;
  transition:width var(--t) var(--spring), opacity var(--t-fast);
  box-shadow:0 0 8px rgba(255,107,53,0.5);
}
.nav-ico {
  display:flex; align-items:center; justify-content:center;
  width:26px; height:26px;
  transition:transform var(--t) var(--spring);
}
.nav-ico svg { width:100%; height:100%; display:block; }
.nav-lbl {
  font-size:10px; font-weight:600;
  letter-spacing:0.02em; line-height:1.1;
  white-space:nowrap;
}
.nav-item:active { transform:scale(0.94); }
.nav-item:hover { color:var(--cream-soft); }
.nav-item.active { color:var(--amber-lt); }
.nav-item.active::before { width:26px; opacity:1; }
.nav-item.active .nav-ico {
  transform:translateY(-1px) scale(1.05);
  filter:drop-shadow(0 0 8px rgba(255,107,53,0.5));
}

/* ============================================================
   MAIN
   ============================================================ */
.main {
  flex:1; width:100%;
  max-width:1640px; margin:0 auto;
  padding:22px 16px 100px;
  position:relative; z-index:1;
}

/* ============================================================
   PAGE STRUCTURE
   ============================================================ */
.page-header { margin-bottom:24px; }
.page-title {
  font-family:'Cormorant Garamond', serif;
  font-size:2rem; font-weight:600; line-height:0.95;
  letter-spacing:-0.03em; color:var(--cream);
  position:relative;
}
.page-title .accent-line {
  display:block; width:2.5em; height:2px;
  background:linear-gradient(90deg, var(--ember), transparent);
  margin-top:10px; border-radius:2px;
}
.page-subtitle {
  display:block; font-size:13px; font-weight:400;
  color:var(--cream-mute); margin-top:8px;
}
.section-title {
  font-family:'Cormorant Garamond', serif;
  font-size:1.15rem; font-weight:600;
  color:var(--cream-soft); margin-bottom:14px;
  display:flex; align-items:center; gap:8px;
}
.section-title .dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--ember); flex-shrink:0;
  box-shadow:0 0 8px rgba(255,107,53,0.6);
}

/* ============================================================
   CARDS
   ============================================================ */
.card {
  background:var(--glass);
  backdrop-filter:blur(var(--blur)) saturate(130%);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(130%);
  border-radius:var(--r); padding:18px;
  border:1px solid var(--glass-border);
  box-shadow:var(--shadow);
  position:relative; overflow:hidden;
  transition:transform var(--t), box-shadow var(--t), border-color var(--t);
}
.card::before {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(140deg, rgba(255,255,255,0.05) 0%, transparent 35%, transparent 65%, rgba(255,255,255,0.02) 100%);
  pointer-events:none;
}
.card:hover { border-color:rgba(255,255,255,0.13); box-shadow:var(--shadow-lg); }
.card-warm {
  background:linear-gradient(145deg, rgba(30,18,10,0.72), rgba(20,14,8,0.65));
  border-color:rgba(245,166,35,0.18);
}
.card-warm:hover { border-color:rgba(245,166,35,0.30); box-shadow:var(--shadow-ember); }
.card-teal {
  background:linear-gradient(145deg, rgba(10,28,26,0.72), rgba(8,20,18,0.65));
  border-color:rgba(45,207,179,0.18);
}
.card-teal:hover { border-color:rgba(45,207,179,0.30); }

/* ============================================================
   BENTO & GRIDS
   ============================================================ */
.bento-grid { display:grid; grid-template-columns:1fr; gap:14px; }
.b-span-3, .b-span-4, .b-span-5, .b-span-6, .b-span-7, .b-span-8, .b-span-9, .b-span-12 { grid-column:1 / -1; }
.b-row-2 { grid-row:auto; }

.grid-2, .grid-3, .grid-4 { display:grid; grid-template-columns:1fr; gap:14px; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:10px 18px;
  border-radius:var(--r-sm); border:1px solid transparent;
  font-family:'Sora', sans-serif;
  font-size:13px; font-weight:600; letter-spacing:-0.01em;
  cursor:pointer; white-space:nowrap;
  transition:transform var(--t-fast), box-shadow var(--t), background var(--t);
}
.btn:active { transform:scale(0.96); }
.btn:focus-visible { outline:2px solid var(--amber); outline-offset:3px; }
.btn-primary {
  background:linear-gradient(135deg, var(--ember), var(--ember-dk));
  color:#fff; border-color:rgba(255,255,255,0.15);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.20), 0 4px 16px rgba(255,107,53,0.40);
}
.btn-primary:hover { transform:translateY(-1px); box-shadow:inset 0 1px 0 rgba(255,255,255,0.25), 0 6px 20px rgba(255,107,53,0.55); }
.btn-amber {
  background:linear-gradient(135deg, var(--amber), #D4891A);
  color:var(--coal); font-weight:700;
  border-color:rgba(255,255,255,0.20);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.30), 0 4px 16px rgba(245,166,35,0.40);
}
.btn-amber:hover { transform:translateY(-1px); box-shadow:inset 0 1px 0 rgba(255,255,255,0.35), 0 6px 20px rgba(245,166,35,0.55); }
.btn-secondary {
  background:rgba(255,255,255,0.06); color:var(--cream-soft);
  border-color:rgba(255,255,255,0.10);
}
.btn-secondary:hover { background:rgba(255,255,255,0.10); color:var(--cream); border-color:rgba(255,255,255,0.18); transform:translateY(-1px); }
.btn-ghost {
  background:transparent; color:var(--cream-mute);
  border:1px solid rgba(255,255,255,0.10);
}
.btn-ghost:hover { background:rgba(255,255,255,0.05); color:var(--cream-soft); border-color:rgba(255,255,255,0.18); }
.btn-teal {
  background:linear-gradient(135deg, var(--teal), var(--teal-dk));
  color:#fff; border-color:rgba(255,255,255,0.15);
  box-shadow:0 4px 16px rgba(45,207,179,0.35);
}
.btn-teal:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(45,207,179,0.50); }
.btn-danger { background:rgba(255,68,68,0.14); color:#FF7878; border:1px solid rgba(255,68,68,0.25); }
.btn-danger:hover { background:rgba(255,68,68,0.25); color:#FFAAAA; }
.btn-sm { padding:7px 13px; font-size:12px; border-radius:10px; }
.btn-xs { padding:4px 10px; font-size:11px; border-radius:8px; }

/* ============================================================
   INPUTS
   ============================================================ */
input[type="text"], input[type="url"], input[type="number"],
input[type="date"], select, textarea {
  width:100%; padding:11px 14px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-sm);
  background:rgba(255,255,255,0.05);
  backdrop-filter:blur(10px);
  color:var(--cream);
  font-family:'Sora', sans-serif;
  font-size:16px;
  outline:none;
  transition:border-color var(--t), box-shadow var(--t), background var(--t);
}
input:hover, select:hover, textarea:hover { background:rgba(255,255,255,0.07); border-color:rgba(255,255,255,0.15); }
input:focus, select:focus, textarea:focus {
  border-color:var(--amber); background:rgba(255,255,255,0.08);
  box-shadow:0 0 0 3px rgba(245,166,35,0.15), 0 4px 12px rgba(0,0,0,0.30);
}
input::placeholder, textarea::placeholder { color:var(--cream-mute); }
select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A6E5E' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
  padding-right:38px;
}
select option { background:var(--slate); color:var(--cream); }
textarea { resize:vertical; min-height:80px; line-height:1.55; }
label {
  display:block; font-size:11px; font-weight:600;
  color:var(--cream-mute); margin-bottom:5px;
  letter-spacing:0.05em; text-transform:uppercase;
}

/* ============================================================
   COMPOSANTS — Météo
   ============================================================ */
.weather-card {
  background:linear-gradient(145deg, rgba(28,16,8,0.78), rgba(20,14,10,0.70));
  border-color:rgba(245,166,35,0.20);
}
.weather-main { display:flex; align-items:flex-start; gap:14px; margin-bottom:14px; }
.weather-emoji { font-size:3rem; line-height:1; filter:drop-shadow(0 4px 16px rgba(245,166,35,0.30)); }
.weather-temp {
  font-family:'Cormorant Garamond', serif;
  font-size:3.2rem; font-weight:700; line-height:0.9;
  letter-spacing:-0.04em;
  background:linear-gradient(135deg, var(--amber-lt), var(--amber));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.weather-feels { font-size:12px; color:var(--cream-mute); margin-top:4px; }
.weather-desc { font-size:13px; color:var(--cream-soft); margin-bottom:8px; }
.weather-meta { display:flex; gap:8px; flex-wrap:wrap; }
.weather-pill {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 10px; background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.09);
  border-radius:99px; font-size:11px;
  color:var(--cream-soft); font-weight:500;
}
.weather-conseil {
  margin-top:12px; padding:10px 13px;
  background:rgba(245,166,35,0.08);
  border:1px solid rgba(245,166,35,0.18);
  border-radius:var(--r-sm); font-size:12px;
  color:var(--amber-lt); line-height:1.5;
}

/* ============================================================
   COMPOSANTS — Défi
   ============================================================ */
.defi-card {
  background:linear-gradient(145deg, rgba(26,14,8,0.80), rgba(16,10,6,0.74));
  border-color:rgba(255,107,53,0.25);
  box-shadow:0 0 40px rgba(255,107,53,0.10), var(--shadow);
}
.defi-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 12px;
  background:linear-gradient(135deg, rgba(255,107,53,0.22), rgba(245,166,35,0.16));
  border:1px solid rgba(255,107,53,0.32);
  border-radius:99px; font-size:11px;
  font-weight:700; letter-spacing:0.06em;
  text-transform:uppercase; color:var(--amber-lt);
  margin-bottom:12px;
}
.defi-title {
  font-family:'Cormorant Garamond', serif;
  font-size:1.4rem; font-weight:600; color:var(--cream);
  letter-spacing:-0.02em; margin-bottom:8px; line-height:1.2;
}
.defi-desc { font-size:12.5px; color:var(--cream-mute); line-height:1.6; margin-bottom:14px; }
.defi-footer { display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.defi-done {
  display:flex; align-items:center; gap:8px;
  padding:8px 16px; background:rgba(45,207,122,0.12);
  border:1px solid rgba(45,207,122,0.25);
  border-radius:99px; font-size:13px;
  font-weight:600; color:var(--success);
}

/* ============================================================
   COMPOSANTS — Repas (dashboard)
   ============================================================ */
.repas-slot { display:flex; gap:8px; flex-wrap:wrap; }
.repas-pill {
  flex:1 1 calc(50% - 4px); min-width:120px;
  padding:10px 12px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-sm);
  cursor:pointer; transition:all var(--t);
}
.repas-pill:hover { background:rgba(255,107,53,0.10); border-color:rgba(255,107,53,0.25); transform:translateY(-2px); }
.repas-pill .rp-moment {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:0.06em; color:var(--cream-mute); margin-bottom:4px;
}
.repas-pill .rp-titre {
  font-size:13px; font-weight:600; color:var(--cream);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.repas-pill.valide { border-color:rgba(45,207,122,0.25); background:rgba(45,207,122,0.06); }
.repas-pill.valide .rp-titre { color:var(--success); }
.repas-pill.empty .rp-titre { color:var(--cream-mute); font-style:italic; font-weight:400; }

/* ============================================================
   COMPOSANTS — Saison / Éphéméride / Envies
   ============================================================ */
.saison-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; background:rgba(45,207,179,0.10);
  border:1px solid rgba(45,207,179,0.20);
  border-radius:99px; font-size:11px;
  font-weight:600; color:var(--teal);
  margin-right:6px; margin-bottom:6px;
}
.produit-grid { display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.produit-tag {
  padding:4px 10px; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:99px; font-size:11px; color:var(--cream-soft);
}

.ephemeride-item {
  display:flex; gap:12px; padding:9px 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
  font-size:12.5px; color:var(--cream-mute); line-height:1.45;
}
.ephemeride-item:last-child { border-bottom:none; }
.ephemeride-year {
  font-family:'Cormorant Garamond', serif;
  font-weight:700; color:var(--ember);
  flex-shrink:0; min-width:46px; font-size:0.95rem;
}

.envies-grid { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.envie-chip {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 12px; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.09);
  border-radius:99px; font-size:12px;
  color:var(--cream-soft); transition:all var(--t-fast);
}
.envie-chip:hover { background:rgba(255,255,255,0.09); border-color:rgba(255,255,255,0.15); }
.envie-chip .chip-del {
  background:none; border:none; color:var(--cream-mute);
  cursor:pointer; padding:0; font-size:13px; line-height:1;
  transition:color var(--t-fast);
}
.envie-chip .chip-del:hover { color:var(--danger); }
.envie-cat {
  font-size:10px; font-weight:700; letter-spacing:0.06em;
  text-transform:uppercase; padding:2px 6px; border-radius:4px;
  background:rgba(245,166,35,0.15); color:var(--amber);
}

/* ============================================================
   COMPOSANTS — Recettes liste
   ============================================================ */
/* ============================================================
   GRILLE DE CARTES RECETTES (tuiles carrées style Pinterest)
   ============================================================ */
.recette-grid {
  display:grid !important;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
}
.recette-card {
  background:var(--glass);
  backdrop-filter:blur(var(--blur)) saturate(130%);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(130%);
  border-radius:var(--r);
  border:1px solid var(--glass-border);
  overflow:hidden; cursor:pointer;
  display:flex !important; flex-direction:column;
  transition:transform var(--t), box-shadow var(--t), border-color var(--t);
  position:relative;
  -webkit-tap-highlight-color:transparent;
}
.recette-card::before {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(140deg, rgba(255,255,255,0.05) 0%, transparent 35%, transparent 65%, rgba(255,255,255,0.02) 100%);
  pointer-events:none; z-index:1;
}
.recette-card:hover {
  transform:translateY(-4px);
  border-color:rgba(255,107,53,0.30);
  box-shadow:var(--shadow-ember);
}
.recette-card:active { transform:translateY(-1px) scale(0.98); }
.recette-img {
  width:100%; aspect-ratio:1/1;
  object-fit:cover; display:block;
  background:linear-gradient(145deg, rgba(255,107,53,0.12), rgba(245,166,35,0.08));
  font-size:2.8rem;
  align-items:center; justify-content:center;
  color:rgba(245,166,35,0.45);
  border-bottom:1px solid var(--glass-border);
  filter:drop-shadow(0 2px 8px rgba(0,0,0,0.3));
}
div.recette-img { display:flex !important; }
.recette-body {
  padding:11px 13px 13px;
  display:flex; flex-direction:column; gap:5px;
  flex:1; position:relative; z-index:2;
}
.recette-titre {
  font-family:'Cormorant Garamond', serif;
  font-size:1.05rem; font-weight:600;
  color:var(--cream); line-height:1.2;
  letter-spacing:-0.01em;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:2.4em;
}
.recette-meta {
  font-size:10.5px; color:var(--cream-mute);
  line-height:1.4;
}
.tag {
  display:inline-flex; align-items:center;
  padding:3px 9px; background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:99px; font-size:10.5px;
  color:var(--cream-soft); font-weight:500;
}

/* === Modale recette : sélecteur portions === */
.portion-selector {
  display:flex; align-items:center;
  gap:10px; padding:12px 16px;
  background:linear-gradient(135deg, rgba(255,107,53,0.08), rgba(245,166,35,0.05));
  border:1px solid rgba(245,166,35,0.20);
  border-radius:var(--r-sm);
  margin-bottom:18px;
}
.portion-label {
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:0.06em;
  color:var(--amber-lt); flex:1;
}
.portion-btn {
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,107,53,0.15);
  border:1px solid rgba(255,107,53,0.30);
  color:var(--amber-lt);
  font-size:18px; font-weight:700;
  cursor:pointer; display:flex;
  align-items:center; justify-content:center;
  transition:all var(--t-fast);
  -webkit-tap-highlight-color:transparent;
}
.portion-btn:hover { background:rgba(255,107,53,0.30); transform:scale(1.08); }
.portion-btn:active { transform:scale(0.92); }
.portion-btn:disabled { opacity:0.3; cursor:not-allowed; }
.portion-value {
  font-family:'Cormorant Garamond', serif;
  font-size:1.8rem; font-weight:700;
  color:var(--amber-lt); min-width:38px; text-align:center;
  line-height:1; letter-spacing:-0.02em;
}
.portion-unit {
  font-size:11px; color:var(--cream-mute);
  font-weight:600; letter-spacing:0.05em;
  text-transform:uppercase;
}

.ingredient-list {
  list-style:none; padding:0; margin:0 0 8px;
}
.ingredient-list li {
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
  font-size:13px; color:var(--cream-soft); line-height:1.5;
  display:flex; gap:10px; align-items:baseline;
}
.ingredient-list li:last-child { border-bottom:none; }
.ing-qty {
  font-weight:700; color:var(--amber-lt);
  min-width:80px; flex-shrink:0;
}
.ing-qty.updated { animation:qtyFlash 0.5s ease; }
@keyframes qtyFlash {
  0% { color:var(--amber-lt); }
  50% { color:#fff; text-shadow:0 0 12px rgba(245,166,35,0.8); }
  100% { color:var(--amber-lt); }
}
.ing-name { color:var(--cream); flex:1; }
.etape-list {
  list-style:none; padding:0; margin:0;
  counter-reset:etape;
}
.etape-list li {
  counter-increment:etape;
  padding:10px 0 10px 38px;
  border-bottom:1px solid rgba(255,255,255,0.05);
  font-size:13px; color:var(--cream-soft); line-height:1.55;
  position:relative;
}
.etape-list li:last-child { border-bottom:none; }
.etape-list li::before {
  content:counter(etape);
  position:absolute; left:0; top:8px;
  width:26px; height:26px; border-radius:50%;
  background:linear-gradient(135deg, var(--ember), var(--ember-dk));
  color:#fff; font-size:11px; font-weight:700; font-family:'Sora', sans-serif;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 6px rgba(255,107,53,0.30);
}

.express-box {
  margin-top:16px; padding:14px 16px;
  background:rgba(245,166,35,0.08);
  border:1px solid rgba(245,166,35,0.18);
  border-radius:var(--r-sm);
}
.express-title {
  font-family:'Cormorant Garamond', serif;
  font-size:1rem; font-weight:600;
  color:var(--amber-lt); margin-bottom:6px;
}

@media (min-width:640px) {
  .recette-grid { grid-template-columns:repeat(3, 1fr); gap:14px; }
}
@media (min-width:1024px) {
  .recette-grid { grid-template-columns:repeat(4, 1fr); gap:16px; }
}
@media (min-width:1440px) {
  .recette-grid { grid-template-columns:repeat(5, 1fr); gap:18px; }
}
@media (min-width:1800px) {
  .recette-grid { grid-template-columns:repeat(6, 1fr); gap:20px; }
}

/* ============================================================
   GAMIFICATION REFONDUE — Niveau · Badges · Timeline
   ============================================================ */

/* Bloc profil avec orbe SVG */
.profil-head {
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
}
.niveau-orbe {
  position:relative; width:120px; height:120px; flex-shrink:0;
}
.niveau-ring-svg {
  width:100%; height:100%;
  filter:drop-shadow(0 0 20px rgba(255,107,53,0.30));
}
.niveau-orbe-text {
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
}
.niveau-num {
  font-family:'Cormorant Garamond', serif;
  font-size:3rem; font-weight:700;
  background:linear-gradient(135deg, var(--amber-lt), var(--ember));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1; letter-spacing:-0.04em;
}
.niveau-lbl {
  font-size:10px; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--cream-mute); margin-top:4px;
}
.profil-pseudo {
  font-family:'Cormorant Garamond', serif;
  font-size:1.8rem; font-weight:600;
  color:var(--cream); line-height:1;
  letter-spacing:-0.02em;
}
.profil-meta {
  font-size:13px; color:var(--cream-soft);
  margin-top:4px;
  display:flex; align-items:center; gap:6px; flex-wrap:wrap;
}
.dot-sep { color:var(--cream-mute); }

/* Grille badges */
.badges-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(95px, 1fr));
  gap:10px;
}
.badge-tile {
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:14px 8px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-sm);
  text-align:center;
  transition:all var(--t);
  position:relative;
}
.badge-tile.obtenu {
  background:linear-gradient(145deg, rgba(255,107,53,0.14), rgba(245,166,35,0.08));
  border-color:rgba(245,166,35,0.30);
  box-shadow:0 0 16px rgba(245,166,35,0.10);
}
.badge-tile.obtenu:hover {
  transform:translateY(-2px) scale(1.03);
  box-shadow:0 0 24px rgba(245,166,35,0.25);
  border-color:rgba(245,166,35,0.50);
}
.badge-tile.locked {
  opacity:0.45;
  filter:grayscale(0.7);
}
.badge-tile.locked:hover { opacity:0.7; }
.badge-ico {
  font-size:1.8rem; line-height:1; margin-bottom:6px;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,0.5));
}
.badge-nom {
  font-size:11px; font-weight:700;
  color:var(--cream); line-height:1.2;
  margin-bottom:3px;
}
.badge-date {
  font-size:9px; color:var(--cream-mute);
  font-weight:600; letter-spacing:0.04em;
  text-transform:uppercase;
}
.badge-tile.obtenu .badge-date { color:var(--amber); }

/* Projets en cours (envies avec progression) */
.projets-list { display:flex; flex-direction:column; gap:12px; }
.projet-item {
  padding:12px 14px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--r-sm);
}
.projet-head {
  display:flex; align-items:center; gap:8px;
  margin-bottom:8px; flex-wrap:wrap;
}
.projet-nom {
  font-size:13px; font-weight:600; color:var(--cream);
  flex:1; min-width:0;
}
.projet-niveau-bar {
  height:8px; background:rgba(255,255,255,0.07);
  border-radius:99px; overflow:hidden;
  margin-bottom:6px;
}
.projet-niveau-fill {
  height:100%;
  background:linear-gradient(90deg, var(--ember), var(--amber));
  border-radius:99px;
  transition:width 0.6s var(--ease);
  box-shadow:0 0 6px rgba(255,107,53,0.40);
}
.projet-meta {
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:6px;
}
.projet-niv-num {
  font-size:11px; font-weight:700; color:var(--amber-lt);
  letter-spacing:0.03em;
}

/* Stats par catégorie */
.cat-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(120px, 1fr));
  gap:10px;
}
.cat-tile {
  padding:12px 14px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-sm);
  transition:all var(--t);
}
.cat-tile:hover { background:rgba(255,107,53,0.08); border-color:rgba(255,107,53,0.20); }
.cat-nom {
  font-family:'Cormorant Garamond', serif;
  font-size:1.1rem; font-weight:600;
  color:var(--cream-soft); margin-bottom:6px;
}
.cat-niv {
  font-size:12px; color:var(--cream-mute);
  margin-bottom:4px;
}
.cat-niv strong { color:var(--amber-lt); font-size:14px; }
.cat-stats {
  font-size:12px; font-weight:600;
  display:flex; gap:8px;
}

/* Timeline accomplissements */
.timeline {
  display:flex; flex-direction:column; gap:10px;
  position:relative;
}
.timeline::before {
  content:''; position:absolute;
  left:48px; top:8px; bottom:8px; width:2px;
  background:linear-gradient(180deg, var(--ember), transparent);
  opacity:0.3;
}
.timeline-item {
  display:flex; gap:14px; align-items:flex-start;
  position:relative;
}
.timeline-date {
  font-family:'Cormorant Garamond', serif;
  font-size:0.85rem; font-weight:700;
  color:var(--ember);
  min-width:42px; flex-shrink:0;
  padding-top:4px;
}
.timeline-content {
  flex:1; padding:8px 12px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--r-sm);
  min-width:0;
}
.timeline-content::before {
  content:''; position:absolute;
  left:54px; top:14px; width:8px; height:8px;
  border-radius:50%;
  background:var(--ember);
  box-shadow:0 0 8px rgba(255,107,53,0.6);
}
.timeline-titre {
  font-size:13px; font-weight:600;
  color:var(--cream); line-height:1.35;
  margin-bottom:4px;
}
.timeline-meta {
  display:flex; align-items:center; gap:6px; flex-wrap:wrap;
}

/* ============================================================
   PLANNING — Vue jour empilée (mobile par défaut)
   ============================================================ */
.planning-grid { display:none; }
.planning-days {
  display:flex; flex-direction:column;
  gap:12px;
}
.planning-day {
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r);
  overflow:hidden;
  transition:border-color var(--t);
}
.planning-day:hover { border-color:rgba(255,255,255,0.12); }
.planning-day.today {
  border-color:rgba(245,166,35,0.30);
  box-shadow:0 0 24px rgba(245,166,35,0.08);
}
.planning-day-head {
  padding:10px 14px;
  background:rgba(8,8,9,0.50);
  border-bottom:1px solid rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:space-between;
  gap:8px;
}
.planning-day-name {
  font-family:'Cormorant Garamond', serif;
  font-size:1.05rem; font-weight:600;
  color:var(--cream); letter-spacing:-0.01em;
  text-transform:capitalize;
}
.planning-day.today .planning-day-name { color:var(--amber-lt); }
.planning-day-badge {
  padding:3px 10px;
  background:linear-gradient(135deg, var(--ember), var(--amber));
  color:#fff;
  border-radius:99px;
  font-size:10px; font-weight:700;
  letter-spacing:0.05em; text-transform:uppercase;
}
.planning-day-body {
  padding:6px;
  display:flex; flex-direction:column; gap:4px;
}
.day-slot {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  background:transparent;
  border-radius:var(--r-sm);
  cursor:pointer;
  transition:all var(--t);
}
.day-slot:hover { background:rgba(255,107,53,0.06); }
.day-slot:active { transform:scale(0.98); }
.day-slot.has-repas { background:rgba(245,166,35,0.05); }
.day-slot.has-repas:hover { background:rgba(245,166,35,0.10); }
.day-slot.valide { background:rgba(45,207,122,0.06); }
.day-slot.valide:hover { background:rgba(45,207,122,0.12); }
.day-slot-moment {
  font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:0.06em;
  color:var(--cream-mute);
  min-width:60px; flex-shrink:0;
}
.day-slot.has-repas .day-slot-moment { color:var(--amber); }
.day-slot.valide .day-slot-moment { color:var(--success); }
.day-slot-body { flex:1; min-width:0; }
.day-slot-titre {
  font-size:13px; font-weight:600; color:var(--cream);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.day-slot.valide .day-slot-titre { color:var(--success); }
.day-slot-meta {
  font-size:11px; color:var(--cream-mute);
  margin-top:2px;
}
.day-slot-empty {
  font-size:12px; color:var(--cream-mute);
  font-style:italic;
}
.day-slot-x {
  width:24px; height:24px;
  background:rgba(255,68,68,0.10);
  border:1px solid rgba(255,68,68,0.20);
  color:#FF7878;
  border-radius:50%;
  cursor:pointer; font-size:10px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  transition:all var(--t-fast);
}
.day-slot-x:hover { background:var(--danger); color:#fff; transform:scale(1.1); }

/* === Switch mobile/desktop pour le planning === */
@media (min-width:768px) {
  .planning-grid { display:grid; }
  .planning-days { display:none; }
}

.recette-list-item {
  display:flex; align-items:center; gap:12px;
  padding:11px 14px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--r-sm); cursor:pointer;
  transition:all var(--t); margin-bottom:8px;
  flex-wrap:wrap;
}
.recette-list-item:hover { background:rgba(255,107,53,0.08); border-color:rgba(255,107,53,0.20); }
.recette-list-item:last-child { margin-bottom:0; }
.recette-list-left { flex:1; min-width:140px; }
.recette-list-titre {
  font-size:14px; font-weight:600; color:var(--cream);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  margin-bottom:3px;
}
.recette-list-meta {
  font-size:11.5px; color:var(--cream-mute);
  display:flex; gap:8px; flex-wrap:wrap; align-items:center;
}
.nutri-badge {
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; border-radius:5px;
  font-size:11px; font-weight:800;
  flex-shrink:0;
}
.nutri-A { background:#1A7340; color:#fff; }
.nutri-B { background:#51A352; color:#fff; }
.nutri-C { background:#E8BE00; color:#222; }
.nutri-D { background:#E07B39; color:#fff; }
.nutri-E { background:#BE3220; color:#fff; }

/* ============================================================
   COMPOSANTS — Planning
   ============================================================ */
.planning-wrap {
  overflow-x:auto; border-radius:var(--r);
  background:rgba(8,8,9,0.50);
  border:1px solid rgba(255,255,255,0.06);
  padding:5px;
  -webkit-overflow-scrolling:touch;
}
.planning-wrap::-webkit-scrollbar { height:6px; }
.planning-wrap::-webkit-scrollbar-thumb { background:rgba(255,107,53,0.30); border-radius:99px; }
.planning-grid {
  display:grid;
  grid-template-columns:60px repeat(7, minmax(96px, 1fr));
  gap:4px; min-width:max-content;
}
.planning-head {
  background:rgba(255,255,255,0.04);
  border-radius:10px; padding:9px 6px;
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:0.05em;
  color:var(--cream-mute); text-align:center;
}
.planning-moment {
  background:rgba(255,107,53,0.08);
  border-radius:10px; padding:9px 6px;
  font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:0.05em;
  color:var(--ember);
  display:flex; align-items:center; justify-content:center;
}
.planning-cell {
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.05);
  border-radius:10px; padding:8px;
  min-height:72px; cursor:pointer;
  transition:all var(--t); position:relative;
}
.planning-cell:hover { background:rgba(255,107,53,0.07); border-color:rgba(255,107,53,0.18); }
.planning-cell.occupied { background:rgba(245,166,35,0.07); border-color:rgba(245,166,35,0.15); }
.planning-cell.occupied:hover { background:rgba(245,166,35,0.12); border-color:rgba(245,166,35,0.28); }
.planning-cell.valide { background:rgba(45,207,122,0.07); border-color:rgba(45,207,122,0.20); }
.pc-titre {
  font-size:11px; font-weight:600; color:var(--cream-soft);
  line-height:1.35;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden;
}
.pc-meta { font-size:10px; color:var(--cream-mute); margin-top:4px; }
.pc-add {
  font-size:22px; color:rgba(255,255,255,0.12);
  display:flex; align-items:center; justify-content:center; height:100%;
}
.planning-nav {
  display:flex; align-items:center; gap:10px;
  margin-bottom:14px; flex-wrap:wrap;
}
.semaine-label {
  font-family:'Cormorant Garamond', serif;
  font-size:1.1rem; font-weight:600;
  color:var(--cream-soft);
}

/* ============================================================
   COMPOSANTS — Réserve
   ============================================================ */
.reserve-list { display:flex; flex-direction:column; gap:8px; }
.reserve-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r-sm); transition:all var(--t);
  flex-wrap:wrap;
}
.reserve-item:hover { background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.12); }
.reserve-icon { font-size:20px; flex-shrink:0; }
.reserve-info { flex:1; min-width:140px; }
.reserve-nom { font-size:13px; font-weight:600; color:var(--cream); }
.reserve-meta { font-size:11px; color:var(--cream-mute); margin-top:2px; }
.reserve-peremption {
  font-size:10px; font-weight:700;
  padding:3px 8px; border-radius:99px; flex-shrink:0;
}
.perim-ok   { background:rgba(45,207,122,0.12); border:1px solid rgba(45,207,122,0.25); color:var(--success); }
.perim-soon { background:rgba(245,166,35,0.15); border:1px solid rgba(245,166,35,0.30); color:var(--warn); }
.perim-late { background:rgba(255,68,68,0.15); border:1px solid rgba(255,68,68,0.30); color:var(--danger); }

/* ============================================================
   COMPOSANTS — Gamification
   ============================================================ */
.niveau-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 16px;
  background:linear-gradient(135deg, rgba(255,107,53,0.18), rgba(245,166,35,0.14));
  border:1px solid rgba(245,166,35,0.30);
  border-radius:99px; font-size:14px;
  font-weight:700; color:var(--amber-lt);
  box-shadow:0 0 20px rgba(245,166,35,0.15);
}
.xp-bar-container {
  height:6px; background:rgba(255,255,255,0.08);
  border-radius:99px; overflow:hidden; margin:6px 0;
}
.xp-bar {
  height:100%;
  background:linear-gradient(90deg, var(--ember), var(--amber));
  border-radius:99px;
  transition:width 0.8s var(--ease);
  box-shadow:0 0 8px rgba(255,107,53,0.40);
}
.historique-item {
  display:flex; align-items:center; gap:10px;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
  font-size:12px;
}
.historique-item:last-child { border-bottom:none; }
.xp-delta-pos { color:var(--success); font-weight:700; min-width:36px; }
.xp-delta-neg { color:var(--danger); font-weight:700; min-width:36px; }

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay {
  position:fixed; inset:0; z-index:900;
  background:rgba(0,0,0,0.75); backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center;
  padding:16px;
}
.modal-overlay.open { display:flex; animation:fadeIn 0.18s var(--ease); }
.modal {
  background:var(--slate);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-lg);
  width:100%; max-width:720px;
  max-height:92vh; max-height:92dvh;
  overflow-y:auto;
  box-shadow:0 0 80px rgba(255,107,53,0.10), 0 24px 80px rgba(0,0,0,0.70);
  animation:slideUp 0.25s var(--spring);
  -webkit-overflow-scrolling:touch;
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes slideUp { from{opacity:0;transform:translateY(30px) scale(.97)} to{opacity:1;transform:translateY(0) scale(1)} }
.modal-header {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:12px; padding:20px 22px 14px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.modal-title {
  font-family:'Cormorant Garamond', serif;
  font-size:1.4rem; font-weight:600;
  color:var(--cream); line-height:1.2;
}
.modal-close {
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.10);
  color:var(--cream-mute);
  width:32px; height:32px; border-radius:50%;
  cursor:pointer; font-size:16px;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--t-fast); flex-shrink:0;
}
.modal-close:hover { background:rgba(255,68,68,0.20); border-color:rgba(255,68,68,0.30); color:#FF7878; }
.modal-body { padding:18px 22px 22px; }

/* ============================================================
   TOASTS / LOADING
   ============================================================ */
.toasts {
  position:fixed; bottom:90px; left:14px; right:14px;
  z-index:9999; display:flex; flex-direction:column;
  gap:8px; pointer-events:none; align-items:flex-end;
}
.toast {
  padding:11px 16px; border-radius:var(--r-sm);
  font-size:13px; font-weight:600;
  backdrop-filter:blur(16px);
  animation:toastIn 0.25s var(--spring), toastOut 0.3s var(--ease) 3.2s forwards;
  box-shadow:var(--shadow-lg); max-width:360px;
}
.toast.success { background:rgba(10,30,20,0.92); border:1px solid rgba(45,207,122,0.30); color:var(--success); }
.toast.error   { background:rgba(30,8,8,0.92); border:1px solid rgba(255,68,68,0.30); color:#FF7878; }
.toast.info    { background:rgba(12,16,30,0.92); border:1px solid rgba(99,102,241,0.30); color:#9899F5; }
@keyframes toastIn { from{opacity:0;transform:translateX(30px)} to{opacity:1;transform:translateX(0)} }
@keyframes toastOut { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(30px)} }

.loader {
  position:fixed; inset:0; z-index:1000;
  background:rgba(8,8,9,0.82); backdrop-filter:blur(12px);
  display:none; align-items:center; justify-content:center;
  flex-direction:column; gap:18px;
}
.loader.active { display:flex; }
.loader-flame { width:64px; height:64px; animation:flamePulse 0.8s ease-in-out infinite alternate; filter:drop-shadow(0 0 18px rgba(255,107,53,0.6)); }
@keyframes flamePulse { from{transform:scale(1) rotate(-2deg);opacity:0.85} to{transform:scale(1.12) rotate(2deg);opacity:1} }
.loader-text { font-size:14px; font-weight:600; color:var(--cream-mute); letter-spacing:0.04em; }

.boot { display:flex; flex-direction:column; align-items:center; justify-content:center; height:60vh; gap:14px; }
.boot-flame { width:72px; height:72px; animation:flamePulse 0.9s ease-in-out infinite alternate; filter:drop-shadow(0 0 20px rgba(255,107,53,0.5)); }
.boot-text { font-size:14px; color:var(--cream-mute); font-weight:500; }

.spinner {
  width:28px; height:28px;
  border:2px solid rgba(255,255,255,0.10);
  border-top-color:var(--amber);
  border-radius:50%;
  animation:spin 0.7s linear infinite;
  margin:20px auto;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ============================================================
   IMPORT ZONE / EDIT
   ============================================================ */
.import-zone {
  text-align:center; padding:30px 18px;
  border:1.5px dashed rgba(255,107,53,0.22);
  border-radius:var(--r);
  background:radial-gradient(ellipse 70% 50% at 50% 0%, rgba(255,107,53,0.06), transparent 60%);
}
.import-icon { font-size:2.5rem; margin-bottom:10px; filter:drop-shadow(0 4px 12px rgba(255,107,53,0.20)); }
.import-title {
  font-family:'Cormorant Garamond', serif;
  font-size:1.35rem; font-weight:600;
  color:var(--cream); margin-bottom:6px;
}
.import-help {
  font-size:12.5px; color:var(--cream-mute);
  margin-bottom:18px; max-width:520px;
  margin-left:auto; margin-right:auto; line-height:1.55;
}
.import-input-wrap {
  display:flex; flex-direction:column; gap:8px;
  max-width:540px; margin:0 auto 12px;
}
.import-or {
  font-size:11px; color:var(--cream-mute);
  margin:10px 0 8px;
  text-transform:uppercase; letter-spacing:1.5px; font-weight:600;
}
.import-status {
  margin-top:14px; padding:10px 16px;
  border-radius:var(--r-sm);
  font-size:12.5px; font-weight:500; text-align:left;
  max-width:540px; margin-left:auto; margin-right:auto;
}
.status-pending { background:rgba(245,166,35,0.10); border:1px solid rgba(245,166,35,0.22); color:var(--amber-lt); }
.status-error { background:rgba(255,68,68,0.10); border:1px solid rgba(255,68,68,0.22); color:#FF9090; }
.status-info { background:rgba(99,102,241,0.10); border:1px solid rgba(99,102,241,0.22); color:#9899F5; }

.source-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:99px;
  font-size:11px; font-weight:700; white-space:nowrap;
}
.badge-ok { background:rgba(45,207,122,0.12); border:1px solid rgba(45,207,122,0.28); color:var(--success); }
.badge-ia { background:rgba(99,102,241,0.12); border:1px solid rgba(99,102,241,0.28); color:#9899F5; }
.badge-warn { background:rgba(245,166,35,0.12); border:1px solid rgba(245,166,35,0.28); color:var(--amber); }

.ed-list { display:flex; flex-direction:column; gap:6px; margin-top:8px; }
.ed-row {
  display:flex; gap:5px; align-items:center; flex-wrap:wrap;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:10px; padding:5px 8px;
}
.ed-row input, .ed-row textarea {
  border:none; background:transparent; padding:5px 7px;
  box-shadow:none; font-size:13px; color:var(--cream);
}
.ed-qte { width:65px; flex-shrink:0; }
.ed-unit { width:85px; flex-shrink:0; }
.ed-nom { flex:1 1 100%; min-width:0; }
.ed-step { flex:1; min-width:0; resize:vertical; min-height:44px; }
.ed-step-num {
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0; width:26px; height:26px; border-radius:50%;
  background:linear-gradient(135deg, var(--ember), var(--ember-dk));
  color:#fff; font-size:11px; font-weight:700;
  margin-top:3px; box-shadow:0 2px 6px rgba(255,107,53,0.25);
}
.btn-icon-mini {
  background:rgba(255,68,68,0.10);
  border:1px solid rgba(255,68,68,0.20);
  color:#FF7878;
  width:26px; height:26px; border-radius:50%;
  cursor:pointer; font-size:11px; flex-shrink:0;
  padding:0; display:inline-flex; align-items:center; justify-content:center;
  transition:all var(--t-fast);
}
.btn-icon-mini:hover { background:var(--danger); color:#fff; transform:scale(1.1); }

.chk-pill {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 12px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:99px;
  font-size:12px; cursor:pointer;
  user-select:none; text-transform:capitalize;
  color:var(--cream-soft);
  transition:all var(--t-fast);
}
.chk-pill:hover { background:rgba(255,255,255,0.09); border-color:rgba(255,107,53,0.30); }
.chk-pill input[type=checkbox] { width:auto; margin:0; accent-color:var(--ember); }
.chk-pill:has(input:checked) {
  background:rgba(45,207,179,0.12);
  border-color:rgba(45,207,179,0.30);
  color:var(--teal); font-weight:600;
}

/* ============================================================
   UTILS
   ============================================================ */
.hidden { display:none !important; }
.flex { display:flex; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.justify-end { justify-content:flex-end; }
.gap-8 { gap:8px; } .gap-12 { gap:12px; } .gap-16 { gap:16px; }
.flex-wrap { flex-wrap:wrap; }
.flex-1 { flex:1; }
.min-w-0 { min-width:0; }
.mt-8 { margin-top:8px; } .mt-12 { margin-top:12px; } .mt-16 { margin-top:16px; } .mt-24 { margin-top:24px; }
.mb-6 { margin-bottom:6px; } .mb-8 { margin-bottom:8px; } .mb-12 { margin-bottom:12px; } .mb-16 { margin-bottom:16px; } .mb-24 { margin-bottom:24px; }
.font-bold { font-weight:700; } .font-600 { font-weight:600; }
.text-sm { font-size:12.5px; } .text-xs { font-size:11px; }
.text-muted { color:var(--cream-mute); }
.text-soft { color:var(--cream-soft); }
.text-amber { color:var(--amber); }
.text-teal { color:var(--teal); }
.text-danger { color:var(--danger); }
.text-success { color:var(--success); }
.text-center { text-align:center; }

/* ============================================================
   ===== RESPONSIVE — 3 PALIERS =====
   ============================================================ */

/* === 640px+ : Grand mobile / Tablette portrait === */
@media (min-width:640px) {
  body { font-size:14px; }
  .main { padding:28px 24px 110px; }
  .page-title { font-size:2.5rem; }
  .logo-flame { width:38px; height:38px; }
  .logo-name { font-size:1.55rem; }
  .nav-lbl { font-size:11px; }
  .toasts { left:auto; right:24px; }
  .grid-2 { grid-template-columns:repeat(2, 1fr); }
  .grid-3, .grid-4 { grid-template-columns:repeat(2, 1fr); }
  .bento-grid { grid-template-columns:repeat(2, 1fr); gap:16px; }
  .b-span-3, .b-span-4, .b-span-5, .b-span-6, .b-span-7, .b-span-8, .b-span-9, .b-span-12 { grid-column:span 2; }
  .import-input-wrap { flex-direction:row; }
  input[type="text"], input[type="url"], input[type="number"],
  input[type="date"], select, textarea { font-size:13.5px; }
}

/* === 1024px+ : DESKTOP — sidebar + Bento 12 cols === */
@media (min-width:1024px) {
  /* Topbar disparait, sidebar verticale */
  .app-shell {
    display:grid;
    grid-template-columns:90px 1fr;
  }
  .topbar { display:none; }

  /* Sidebar */
  .navbar {
    position:sticky; top:0; bottom:auto; left:auto; right:auto;
    height:100vh; height:100dvh; width:auto;
    flex-direction:column;
    padding:18px 10px;
    padding-bottom:18px;
    border-top:none;
    border-right:1px solid rgba(255,255,255,0.06);
    box-shadow:none;
  }

  /* Logo desktop */
  .nav-logo-desktop {
    display:flex; align-items:center; justify-content:center;
    width:50px; height:50px;
    margin:0 auto 22px;
    border-radius:14px;
    background:linear-gradient(145deg, rgba(255,107,53,0.12), rgba(245,166,35,0.06));
    border:1px solid rgba(245,166,35,0.20);
    box-shadow:0 0 24px rgba(255,107,53,0.15), inset 0 1px 0 rgba(255,255,255,0.08);
    cursor:pointer;
    color:inherit; font-family:inherit;
    transition:all var(--t);
  }
  .nav-logo-desktop:hover { transform:scale(1.05); box-shadow:0 0 32px rgba(255,107,53,0.30), inset 0 1px 0 rgba(255,255,255,0.12); }
  .nav-logo-desktop .logo-flame { width:34px; height:34px; }

  /* Items verticaux */
  .nav-items { flex-direction:column; gap:5px; width:100%; }
  .nav-item {
    flex:0 0 auto; width:100%; max-width:72px;
    margin:0 auto;
    padding:11px 6px; gap:5px;
  }
  .nav-item::before {
    top:50%; left:0; transform:translateY(-50%);
    width:3px; height:0; border-radius:0 3px 3px 0;
  }
  .nav-item.active::before { width:3px; height:28px; opacity:1; }
  .nav-item.active {
    background:linear-gradient(145deg, rgba(255,107,53,0.18), rgba(245,166,35,0.10));
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.08);
  }
  .nav-item:hover { background:rgba(255,255,255,0.04); }
  .nav-ico { width:24px; height:24px; }
  .nav-lbl { font-size:10px; }

  /* XP ring desktop */
  .nav-xp-desktop {
    display:flex; flex-direction:column;
    align-items:center; gap:4px;
    margin-top:auto;
    padding:10px 0 4px;
    background:none; border:none;
    cursor:pointer; color:inherit;
    transition:transform var(--t);
  }
  .nav-xp-desktop:hover { transform:scale(1.05); }
  .xp-ring { width:52px; height:52px; }
  .nav-xp-desktop .xp-val { font-size:11px; font-weight:700; color:var(--amber); margin-top:-2px; }
  .nav-xp-desktop .xp-lvl { font-size:9px; color:var(--cream-mute); font-weight:600; letter-spacing:0.05em; text-transform:uppercase; }

  /* Main : généreux */
  .main { padding:34px 36px 50px; }
  .page-title { font-size:3rem; }
  .page-header { margin-bottom:32px; }
  .card { padding:22px 24px; }

  /* Bento 12 cols complet */
  .bento-grid { grid-template-columns:repeat(12, 1fr); gap:18px; }
  .b-span-3 { grid-column:span 3; }
  .b-span-4 { grid-column:span 4; }
  .b-span-5 { grid-column:span 5; }
  .b-span-6 { grid-column:span 6; }
  .b-span-7 { grid-column:span 7; }
  .b-span-8 { grid-column:span 8; }
  .b-span-9 { grid-column:span 9; }
  .b-span-12 { grid-column:span 12; }
  .b-row-2 { grid-row:span 2; }

  .grid-3 { grid-template-columns:repeat(3, 1fr); gap:16px; }
  .grid-4 { grid-template-columns:repeat(4, 1fr); gap:14px; }

  /* Composants ampliés */
  .weather-emoji { font-size:3.5rem; }
  .weather-temp { font-size:3.8rem; }
  .defi-title { font-size:1.55rem; }
  .planning-grid { grid-template-columns:70px repeat(7, minmax(110px, 1fr)); }
  .toasts { bottom:24px; }
  .modal-overlay { padding:28px; }
  .btn { padding:11px 22px; font-size:13.5px; }
}

/* === 1440px+ : Grand desktop === */
@media (min-width:1440px) {
  .app-shell { grid-template-columns:104px 1fr; }
  .nav-logo-desktop { width:56px; height:56px; }
  .nav-logo-desktop .logo-flame { width:38px; height:38px; }
  .main { padding:42px 52px 56px; }
  .page-title { font-size:3.4rem; }
  .card { padding:26px 28px; }
  .bento-grid { gap:22px; }
  .nav-item { max-width:84px; padding:13px 8px; }
  .nav-ico { width:26px; height:26px; }
  .nav-lbl { font-size:11px; }
  .xp-ring { width:60px; height:60px; }
  .weather-temp { font-size:4.2rem; }
  .planning-grid { grid-template-columns:84px repeat(7, minmax(130px, 1fr)); }
}

/* === 1800px+ : Très grand écran === */
@media (min-width:1800px) {
  .app-shell { grid-template-columns:124px 1fr; }
  .nav-logo-desktop { width:64px; height:64px; }
  .nav-logo-desktop .logo-flame { width:44px; height:44px; }
  .main { padding:52px 72px 64px; }
  .page-title { font-size:4rem; }
  .nav-item { max-width:96px; padding:16px 10px; }
}

/* === Accessibilité === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  body::before { animation:none; }
  .ember { display:none; }
}
