/* ============================================================
   DULCES DE CÉCILE — style.css
   ⚠️  Ne pas modifier ce fichier
============================================================ */

:root {
  /* Couleurs */
  --bg:          #fffef6;
  --card-bg:     #ffffff;
  --white:       #ffffff;
  --black:       #1c1a14;
  --lemon:       #f7e549;
  --lemon-soft:  #faf6ca;
  --lemon-chip:  #fcf098;
  --text:        #2a2720;
  --muted:       #7a7668;
  --border:      #e9e4cf;
  --green:       #25D366;
  --danger:      #c0392b;
  --danger-soft: #fef0ef;

  /* Typographie */
  --font-serif: 'Cormorant Garamond', serif;
  --font-sans:  'DM Sans', sans-serif;

  /* Forme */
  --radius:      6px;
  --radius-pill: 40px;

  /* Ombres */
  --shadow:        0 2px 14px rgba(28,26,20,.07);
  --shadow-green:  0 3px 14px rgba(37,211,102,.32);

  /* Animation */
  --transition: .18s;

  /* 🍋 Citron SVG — modifiez les couleurs fill='%23...' (le %23 = #) */
  --lemon-img: url("data:image/svg+xml,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><circle cx='100' cy='100' r='99' fill='%23f0d000'/><circle cx='100' cy='100' r='86' fill='%23ffffff'/><circle cx='100' cy='100' r='80' fill='%23f5e330'/><g stroke='white' stroke-width='2.5'><line x1='100' y1='100' x2='100' y2='20'/><line x1='100' y1='100' x2='148' y2='34'/><line x1='100' y1='100' x2='178' y2='75'/><line x1='100' y1='100' x2='178' y2='125'/><line x1='100' y1='100' x2='148' y2='166'/><line x1='100' y1='100' x2='100' y2='180'/><line x1='100' y1='100' x2='52' y2='166'/><line x1='100' y1='100' x2='22' y2='125'/><line x1='100' y1='100' x2='22' y2='75'/><line x1='100' y1='100' x2='52' y2='34'/></g><circle cx='100' cy='100' r='11' fill='white'/></svg>");
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }

#lemon-deco {
  position: fixed;
  top: -70px; left: -70px;
  width: 200px; height: 200px;
  pointer-events: none;
  z-index: -1;
  opacity: 0.25;
  background-image: var(--lemon-img);
  background-size: contain;
  background-repeat: no-repeat;
}

html { scroll-behavior: smooth; }
body {
  background-color: var(--bg);
  background-image: radial-gradient(circle, rgba(240,204,0,0.09) 1.5px, transparent 1.5px);
  background-size: 22px 22px;
  color: var(--text);
  font-family: var(--font-sans);
  font-weight: 400;
  overflow-x: hidden;
  padding-bottom: 90px;
}

/* ── TOP BAR (fixe au scroll) ── */
#top-bar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  background: var(--white);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  transform: translateY(-110%);
  transition: transform .28s cubic-bezier(.4,0,.2,1);
}
#top-bar.visible { transform: translateY(0); }
#top-bar-logo { font-family:var(--font-serif); font-size:1.15rem; font-weight:400; letter-spacing:.02em; color:var(--black); }
#top-bar-logo em { font-style:italic; }

/* ── LANG ── */
.lang-bar { display:flex; justify-content:flex-end; padding:10px 16px; gap:6px; position:fixed; top:0; right:0; z-index:300; }
.lang-btn { background:var(--white); border:1.5px solid var(--border); border-radius:var(--radius-pill); padding:4px 13px; font-size:.62rem; letter-spacing:.1em; cursor:pointer; font-family:var(--font-sans); font-weight:500; color:var(--muted); transition:all var(--transition); }
.lang-btn.active { background:var(--black); color:var(--white); border-color:var(--black); }

/* ── HEADER ── */
header { text-align:center; padding:52px 24px 22px; }
.logo-main { font-family:var(--font-serif); font-size:clamp(2.4rem,9.5vw,4.4rem); font-weight:400; letter-spacing:.02em; line-height:1; color:var(--black); }
.logo-main em { font-style:italic; }
.logo-lemon { display:inline-block; width:clamp(24px,6vw,44px); height:clamp(24px,6vw,44px); vertical-align:middle; margin-left:clamp(6px,2vw,12px); position:relative; top:-3px; animation:pop 3s ease-in-out infinite; background-image:var(--lemon-img); background-size:contain; background-repeat:no-repeat; }
@keyframes pop { 0%,100%{transform:scale(1)} 50%{transform:scale(1.12)} }
.logo-rule { height:1px; background:var(--border); margin:10px 0 7px; }
.logo-sub { font-size:clamp(.5rem,1.8vw,.65rem); letter-spacing:.32em; text-transform:uppercase; color:var(--muted); }

/* ── CHEF ── */
.chef { display:flex; align-items:center; gap:14px; max-width:600px; margin:0 auto; padding:14px 18px 20px; }
.chef-ava { width:72px; height:72px; border-radius:50%; border:0.5px solid var(--lemon); flex-shrink:0; background:var(--lemon-soft); display:flex; align-items:center; justify-content:center; font-size:1.8rem; overflow:hidden; }
.chef-ava img { width:100%; height:100%; object-fit:cover; object-position:top; }
.chef-name { font-family:var(--font-serif); font-size:1.35rem; font-weight:600; margin-bottom:2px; }
.chef-bio { font-size:.74rem; color:var(--muted); line-height:1.6; margin-bottom:6px; }
.badge { display:inline-block; background:var(--lemon-soft); color:var(--black); font-size:.57rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; padding:3px 10px; border-radius:var(--radius-pill); }

/* ── SECTION TITLE ── */
.section-title { font-family:var(--font-serif); font-size:clamp(1.3rem,4.5vw,1.7rem); font-style:italic; font-weight:400; padding:4px 18px 12px; max-width:600px; margin:0 auto; display:flex; align-items:center; gap:10px; }
.section-title::after { content:''; flex:1; height:1px; background:var(--border); }

/* ── CARDS ── */
.cards { display:flex; flex-direction:column; gap:24px; padding:0 13px 20px; max-width:600px; margin:0 auto; scroll-snap-type:y proximity; }
.card { background:var(--card-bg); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); animation:fadeUp .55s ease both; scroll-snap-align:start; }
.card:nth-child(1){animation-delay:.04s} .card:nth-child(2){animation-delay:.1s}
.card:nth-child(3){animation-delay:.16s} .card:nth-child(4){animation-delay:.22s}
.card:nth-child(5){animation-delay:.28s} .card:nth-child(6){animation-delay:.34s}

/* slider */
.slider { position:relative; overflow:hidden; background:var(--card-bg); height:280px; touch-action:pan-y; margin:16px 16px 0; border-radius:14px; }
.slides { display:flex; transition:transform .32s cubic-bezier(.4,0,.2,1); height:100%; width:100%; }
.slide { min-width:100%; height:100%; position:relative; flex-shrink:0; background:var(--card-bg); font-size:5rem; display:flex; align-items:center; justify-content:center; }
.slide img { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); max-width:100%; max-height:100%; width:auto; height:auto; }

.dots { position:absolute; bottom:9px; left:50%; transform:translateX(-50%); display:flex; gap:5px; z-index:2; }
.dot { width:6px; height:6px; border-radius:50%; background:rgba(28,26,20,.2); transition:background .2s,transform .2s; }
.dot.active { background:var(--black); transform:scale(1.3); }

.sl-arrow { position:absolute; top:50%; transform:translateY(-50%); width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.85); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; z-index:2; box-shadow:0 1px 6px rgba(0,0,0,.12); transition:opacity var(--transition); }
.sl-arrow.prev { left:8px; }
.sl-arrow.next { right:8px; }
.sl-arrow.hidden { opacity:0; pointer-events:none; }
.sl-arrow svg { width:14px; height:14px; }

/* card body */
.card-body { padding:16px 16px 18px; }
.card-name { font-family:var(--font-serif); font-size:1.45rem; font-weight:600; margin-bottom:6px; line-height:1.2; }
.card-desc { font-size:.78rem; color:var(--muted); line-height:1.65; margin-bottom:14px; }
.options-label { font-size:.65rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--text); margin-bottom:8px; }

.chips { display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.chip { background:var(--lemon-soft); border:1.5px solid transparent; border-radius:var(--radius-pill); padding:7px 10px; font-size:.75rem; font-weight:500; color:var(--text); cursor:pointer; transition:all var(--transition); display:flex; align-items:center; justify-content:center; gap:5px; -webkit-user-select:none; user-select:none; }
.chip:hover { border-color:var(--lemon); background:var(--lemon-chip); }
.chip.in-cart { border-color:var(--black); background:var(--lemon-chip); font-weight:600; }
.chip.chip-added { background:var(--green); color:var(--white); border-color:var(--green); transform:scale(1.05); }
.chip-qty { display:none; background:var(--black); color:var(--lemon); border-radius:8px; padding:1px 6px; font-size:.58rem; font-weight:700; line-height:1.5; }
.chip.in-cart .chip-qty { display:inline-block; }
.chip.chip-added .chip-qty { display:none; }

/* ── CONDITIONS ── */
.conditions-wrap { max-width:600px; margin:4px auto 20px; padding:0 13px; }
.conditions { background:var(--black); color:var(--white); border-radius:var(--radius); padding:22px 20px; }
.conditions h3 { font-family:var(--font-serif); font-size:1.15rem; font-style:italic; font-weight:400; color:var(--lemon); margin-bottom:12px; }
.cond-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.cond-item { display:flex; align-items:flex-start; gap:7px; font-size:.70rem; line-height:1.5; }
.cond-dot { width:7px; height:7px; min-width:7px; background:var(--lemon); border-radius:50%; margin-top:4px; }
.cond-link { color:inherit; text-decoration:underline; text-underline-offset:2px; text-decoration-color:rgba(255,255,255,.35); }

/* ── STICKY FOOTER ── */
.sticky-footer { position:fixed; bottom:0; left:0; right:0; z-index:100; background:var(--white); border-top:1px solid var(--border); padding:10px 16px max(10px,env(safe-area-inset-bottom)); display:flex; align-items:center; gap:10px; box-shadow:0 -3px 20px rgba(28,26,20,.07); }
.footer-text { flex:1; font-size:.7rem; color:var(--muted); line-height:1.4; }
.footer-text strong { display:block; font-weight:600; font-size:.76rem; color:var(--text); }
.footer-location { display:block; font-size:.68rem; color:var(--muted); text-decoration:none; margin-top:2px; }
.footer-location:hover { color:var(--text); }
.wa-btn { display:flex; align-items:center; gap:8px; background:var(--green); color:var(--white); text-decoration:none; font-size:.8rem; font-weight:600; padding:11px 18px; border-radius:var(--radius-pill); box-shadow:var(--shadow-green); white-space:nowrap; flex-shrink:0; transition:transform var(--transition); }
.wa-btn:active { transform:scale(.96); }
.wa-btn svg { width:18px; height:18px; }

/* ── CART FAB ── */
#cart-fab {
  position: fixed;
  top: 90px; right: 16px;
  z-index: 300;
  background: var(--black);
  color: var(--white);
  border: none;
  border-radius: 50%;
  width: 48px; height: 48px;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(28,26,20,.25);
  transition: transform var(--transition);
}
#cart-fab.visible { display: flex; }
#cart-fab:active { transform: scale(.93); }
#cart-fab svg { width: 20px; height: 20px; }
#cart-badge {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--lemon);
  color: var(--black);
  border-radius: 50%;
  width: 20px; height: 20px;
  font-size: .6rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  border: 2px solid var(--bg);
}

/* ── CART OVERLAY ── */
#cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(28,26,20,.5);
  z-index: 400;
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s;
}
#cart-overlay.open { opacity: 1; pointer-events: all; }

/* ── CART PANEL ── */
#cart-panel {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 500;
  background: var(--white);
  border-radius: 16px 16px 0 0;
  max-height: calc(100dvh - 80px);
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
}
#cart-panel.open { transform: translateY(0); }

.cart-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.cart-header h2 { font-family:var(--font-serif); font-size:1.35rem; font-style:italic; font-weight:400; }
.cart-close-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  color: var(--muted);
  display: flex;
  align-items: center;
  border-radius: 50%;
  transition: background var(--transition);
}
.cart-close-btn:hover { background: var(--border); }
.cart-close-btn svg { width: 20px; height: 20px; }

#cart-items-list { flex: 1; overflow-y: auto; padding: 6px 0; }
.cart-empty { text-align: center; color: var(--muted); font-size: .8rem; padding: 36px 20px; }

.cart-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 18px;
  border-bottom: 1px solid var(--border);
}
.cart-item:last-child { border-bottom: none; }
.cart-item-img { width:52px; height:52px; border-radius:var(--radius); object-fit:cover; flex-shrink:0; }
.cart-item-img-spacer { width:52px; flex-shrink:0; }
.cart-item-info { flex: 1; }
.cart-item-name { font-family:var(--font-serif); font-size:1.1rem; font-weight:600; line-height:1.2; }
.cart-item-size { font-size:.72rem; color:var(--muted); margin-top:3px; }
.cart-item-remove {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  padding: 7px;
  border-radius: 50%;
  transition: all var(--transition);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.cart-item-remove:hover { color: var(--danger); background: var(--danger-soft); }
.cart-item-remove svg { width: 16px; height: 16px; }

.cart-footer-actions {
  padding: 12px 16px max(16px, env(safe-area-inset-bottom));
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#cart-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text);
  padding: 2px 4px;
}
#cart-total span { font-family: var(--font-serif); font-size: 1.1rem; }
#cart-send-btn {
  width: 100%;
  background: var(--green);
  color: var(--white);
  border: none;
  border-radius: var(--radius-pill);
  padding: 13px 20px;
  font-family: var(--font-sans);
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: var(--shadow-green);
  transition: transform var(--transition);
}
#cart-send-btn:active { transform: scale(.97); }
#cart-send-btn svg { width: 18px; height: 18px; flex-shrink: 0; }

@keyframes fadeUp    { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
@keyframes badge-pop { 0%{transform:scale(1)} 40%{transform:scale(1.55)} 70%{transform:scale(.85)} 100%{transform:scale(1)} }
.badge-pop { animation: badge-pop .4s cubic-bezier(.34,1.56,.64,1) both; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
