/* ════════════════════════════════════════════════════════════
   Design System — tuveuxboirequoi.fr
   Mobile-first
   ════════════════════════════════════════════════════════════ */

:root {
  --bg:          #0a0a0a;
  --bg2:         #0f0f0f;
  --card-bg:     #111111;
  --card-bg2:    #161616;
  --border:      #1e1e1e;
  --border2:     #2a2a2a;

  --pink:        #ff2d78;
  --violet:      #9b30ff;
  --cyan:        #00e5ff;
  --text:        #f0f0f0;
  --text-muted:  #888888;
  --text-dim:    #555555;
  --success:     #00e676;
  --warning:     #ffab00;
  --danger:      #ff3d3d;

  --gradient:      linear-gradient(90deg, #ff2d78, #9b30ff, #00e5ff);
  --gradient-v:    linear-gradient(180deg, #ff2d78, #9b30ff, #00e5ff);
  --gradient-card: linear-gradient(135deg, rgba(155,48,255,0.08), rgba(0,229,255,0.04));

  --glow-pink:   0 0 16px rgba(255,45,120,0.55);
  --glow-violet: 0 0 16px rgba(155,48,255,0.55);
  --glow-cyan:   0 0 16px rgba(0,229,255,0.55);
  --glow-sm:     0 0 8px rgba(155,48,255,0.35);

  --font-heading: 'Rajdhani', sans-serif;
  --font-body:    'Exo 2', sans-serif;
  --radius:       8px;
  --radius-lg:    14px;
  --transition:   0.2s ease;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  /* Smooth scroll désactivé en PWA standalone — cause des sauts iOS */
  scroll-behavior: auto;
  -webkit-text-size-adjust: 100%;
  /* Hauteur correcte sur iOS (100vh inclut la barre Safari) */
  height: -webkit-fill-available;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  /* Utiliser svh + fallback pour iOS */
  min-height: 100svh;
  min-height: -webkit-fill-available;
  overflow-x: hidden;
  /* Empêche le scroll rebond iOS en mode standalone */
  overscroll-behavior: none;
}

img { max-width: 100%; display: block; }
a   { color: var(--cyan); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--pink); }

/* ── Typography ────────────────────────────────────────────── */
h1, h2, h3, h4 { font-family: var(--font-heading); line-height: 1.1; }

h1 { font-size: clamp(1.8rem, 5vw, 3.5rem); font-weight: 700; }
h2 { font-size: clamp(1.3rem, 3vw, 2.2rem); font-weight: 700; }
h3 { font-size: clamp(1rem, 2.5vw, 1.3rem); font-weight: 600; }
h4 { font-size: 1rem; font-weight: 600; }

.gradient-text {
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Layout ─────────────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }
.section   { padding: 3rem 0; }

.flex        { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.gap-1 { gap: 0.5rem; }
.gap-2 { gap: 1rem; }
.gap-3 { gap: 1.5rem; }
.mt-1  { margin-top: 0.5rem; }
.mt-2  { margin-top: 1rem; }
.mt-3  { margin-top: 1.5rem; }
.mb-2  { margin-bottom: 1rem; }
.text-center { text-align: center; }
.text-muted  { color: var(--text-muted); }

/* ── Card ──────────────────────────────────────────────────── */
.card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: box-shadow var(--transition), border-color var(--transition);
}
.card:hover {
  box-shadow: var(--glow-sm);
  border-color: rgba(155,48,255,0.4);
}

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 1.3rem;
  border-radius: var(--radius);
  border: none;
  cursor: pointer;
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  transition: all var(--transition);
  text-decoration: none;
  white-space: nowrap;
  /* Touch target minimum */
  min-height: 44px;
}

.btn-primary {
  background: var(--gradient);
  color: #fff;
}
.btn-primary:hover { box-shadow: var(--glow-violet); color: #fff; filter: brightness(1.1); }

.btn-outline {
  background: transparent;
  border: 1px solid var(--pink);
  color: var(--pink);
}
.btn-outline:hover { background: rgba(255,45,120,0.1); box-shadow: var(--glow-pink); color: var(--pink); }

.btn-ghost {
  background: transparent;
  border: 1px solid var(--border2);
  color: var(--text-muted);
}
.btn-ghost:hover { border-color: var(--cyan); color: var(--cyan); }

.btn-danger {
  background: transparent;
  border: 1px solid var(--danger);
  color: var(--danger);
}
.btn-danger:hover { background: rgba(255,61,61,0.1); box-shadow: 0 0 12px rgba(255,61,61,0.4); }

.btn-sm   { padding: 0.35rem 0.85rem; font-size: 0.85rem; min-height: 36px; }
.btn-lg   { padding: 0.85rem 2rem; font-size: 1.1rem; }
.btn-full { width: 100%; justify-content: center; }

/* ── Forms ─────────────────────────────────────────────────── */
.form-group { margin-bottom: 1.1rem; }

label {
  display: block;
  margin-bottom: 0.3rem;
  font-weight: 600;
  font-size: 0.82rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
input[type="file"],
select,
textarea {
  width: 100%;
  background: var(--card-bg2);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1rem;
  /* 16px minimum prevents iOS auto-zoom */
  font-size: max(16px, 1rem);
  padding: 0.7rem 0.9rem;
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
  /* Better touch target */
  min-height: 44px;
  -webkit-appearance: none;
  appearance: none;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--violet);
  box-shadow: 0 0 0 3px rgba(155,48,255,0.12);
}

textarea { resize: vertical; min-height: 80px; }
select   { cursor: pointer; }

/* ── Badges ─────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 0.18rem 0.65rem;
  border-radius: 99px;
  font-size: 0.75rem;
  font-weight: 700;
  font-family: var(--font-heading);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.badge-pink   { background: rgba(255,45,120,0.15); color: var(--pink);       border: 1px solid rgba(255,45,120,0.3); }
.badge-violet { background: rgba(155,48,255,0.15); color: var(--violet);     border: 1px solid rgba(155,48,255,0.3); }
.badge-cyan   { background: rgba(0,229,255,0.15);  color: var(--cyan);       border: 1px solid rgba(0,229,255,0.3); }
.badge-green  { background: rgba(0,230,118,0.15);  color: var(--success);    border: 1px solid rgba(0,230,118,0.3); }
.badge-red    { background: rgba(255,61,61,0.15);  color: var(--danger);     border: 1px solid rgba(255,61,61,0.3); }
.badge-grey   { background: rgba(136,136,136,0.15);color: var(--text-muted); border: 1px solid rgba(136,136,136,0.3); }
.badge-orange { background: rgba(255,171,0,0.15);  color: var(--warning);    border: 1px solid rgba(255,171,0,0.3); }

/* Status badges — defined directly without @extend */
.status-pending   { display: inline-block; padding: 0.18rem 0.65rem; border-radius: 99px; font-size: 0.75rem; font-weight: 700; font-family: var(--font-heading); letter-spacing: 0.04em; text-transform: uppercase; background: rgba(255,171,0,0.15); color: var(--warning); border: 1px solid rgba(255,171,0,0.3); }
.status-confirmed { display: inline-block; padding: 0.18rem 0.65rem; border-radius: 99px; font-size: 0.75rem; font-weight: 700; font-family: var(--font-heading); letter-spacing: 0.04em; text-transform: uppercase; background: rgba(0,229,255,0.15);  color: var(--cyan);    border: 1px solid rgba(0,229,255,0.3); }
.status-enroute   { display: inline-block; padding: 0.18rem 0.65rem; border-radius: 99px; font-size: 0.75rem; font-weight: 700; font-family: var(--font-heading); letter-spacing: 0.04em; text-transform: uppercase; background: rgba(155,48,255,0.15); color: var(--violet);  border: 1px solid rgba(155,48,255,0.3); }
.status-delivered { display: inline-block; padding: 0.18rem 0.65rem; border-radius: 99px; font-size: 0.75rem; font-weight: 700; font-family: var(--font-heading); letter-spacing: 0.04em; text-transform: uppercase; background: rgba(0,230,118,0.15);  color: var(--success); border: 1px solid rgba(0,230,118,0.3); }
.status-cancelled { display: inline-block; padding: 0.18rem 0.65rem; border-radius: 99px; font-size: 0.75rem; font-weight: 700; font-family: var(--font-heading); letter-spacing: 0.04em; text-transform: uppercase; background: rgba(255,61,61,0.15);  color: var(--danger);  border: 1px solid rgba(255,61,61,0.3); }

/* ── Divider ────────────────────────────────────────────────── */
.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--violet), transparent);
  border: none;
  margin: 2rem 0;
  opacity: 0.3;
}

/* ── Alerts ─────────────────────────────────────────────────── */
.alert {
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  margin-bottom: 1rem;
  font-size: 0.9rem;
  border-left: 3px solid;
}
.alert-success { background: rgba(0,230,118,0.08); border-color: var(--success); color: var(--success); }
.alert-error   { background: rgba(255,61,61,0.08);  border-color: var(--danger);  color: var(--danger); }
.alert-info    { background: rgba(0,229,255,0.08);  border-color: var(--cyan);    color: var(--cyan); }

/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg2); }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--violet); }

/* ── Tap highlight (mobile) ─────────────────────────────────── */
a, button { -webkit-tap-highlight-color: transparent; }

/* ── Responsive visibility ──────────────────────────────────── */
@media (max-width: 768px) {
  .hide-mobile  { display: none !important; }
  .section      { padding: 2rem 0; }
  .container    { padding: 0 1rem; }
}
@media (min-width: 769px) {
  .hide-desktop { display: none !important; }
}
