/* ═══════════════════════════════════════════════════════════
   SHEINPROXY — Global Stylesheet
   Design system · Reset · Shared components
   ═══════════════════════════════════════════════════════════ */

/* ─── TOKENS ─── */
:root {
  /* Palette — warm sand + coral accent */
  --clr-bg:          #f7f3ee;
  --clr-bg-card:     #ffffff;
  --clr-bg-dark:     #1a1714;
  --clr-text:        #2c2420;
  --clr-text-muted:  #7a6e64;
  --clr-text-light:  #ffffff;

  --clr-accent:      #e8553d;       /* coral */
  --clr-accent-hover:#d14430;
  --clr-accent-soft: rgba(232,85,61,.12);

  --clr-gold:        #c9a55a;       /* gold accent for badges */
  --clr-gold-soft:   rgba(201,165,90,.15);

  --clr-success:     #2aab6b;
  --clr-success-soft:rgba(42,171,107,.12);
  --clr-warning:     #e8a020;
  --clr-warning-soft:rgba(232,160,32,.12);
  --clr-info:        #3a8fd9;
  --clr-info-soft:   rgba(58,143,217,.12);
  --clr-danger:      #e8553d;
  --clr-danger-soft: rgba(232,85,61,.12);

  --clr-border:      rgba(44,36,32,.1);
  --clr-border-focus:var(--clr-accent);

  /* Shadows */
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
  --shadow-md:  0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:  0 12px 40px rgba(0,0,0,.14);
  --shadow-card:0 2px 24px rgba(44,36,32,.07);

  /* Radii */
  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-xl:  32px;
  --radius-pill:999px;

  /* Spacing */
  --sp-1: 4px;  --sp-2: 8px;   --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px;  --sp-7: 48px;  --sp-8: 64px;

  /* Typography */
  --font-display:'Syne', sans-serif;
  --font-body:   'DM Sans', sans-serif;

  /* Layout */
  --max-w:       1120px;
  --nav-h:       72px;

  /* Transitions */
  --ease:        cubic-bezier(.4,0,.2,1);
  --trans-fast:  .18s var(--ease);
  --trans-med:   .32s var(--ease);
  --trans-slow:  .48s var(--ease);
}

/* ─── RESET ─── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.6;
  color:var(--clr-text);
  background:var(--clr-bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img, video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
input, textarea, select {
  font-family:inherit;
  font-size:inherit;
  color:inherit;
  border:none;
  outline:none;
}
ul, ol { list-style:none; }

/* ─── NOISE OVERLAY (subtle grain) ─── */
.noise-overlay {
  position:fixed; inset:0; z-index:999;
  pointer-events:none;
  opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px 256px;
}

/* ─── CONTAINER ─── */
.container { width:100%; max-width:var(--max-w); margin:0 auto; padding:0 var(--sp-5); }

/* ─── BUTTONS ─── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--clr-accent);
  color:#fff;
  padding:14px 28px;
  border-radius:var(--radius-pill);
  font-weight:600; font-size:15px;
  transition:background var(--trans-fast), transform var(--trans-fast), box-shadow var(--trans-fast);
  box-shadow:0 4px 18px rgba(232,85,61,.35);
}
.btn-primary:hover {
  background:var(--clr-accent-hover);
  transform:translateY(-1px);
  box-shadow:0 6px 24px rgba(232,85,61,.42);
}
.btn-primary:active { transform:translateY(0); }
.btn-primary.btn-lg { padding:17px 34px; font-size:16px; }
.btn-primary.btn-sm { padding:10px 20px; font-size:13px; }

.btn-ghost {
  display:inline-flex; align-items:center; gap:6px;
  color:var(--clr-text);
  padding:12px 22px;
  border-radius:var(--radius-pill);
  font-weight:500; font-size:15px;
  border:1.5px solid var(--clr-border);
  transition:border-color var(--trans-fast), background var(--trans-fast);
  background:transparent;
}
.btn-ghost:hover { border-color:var(--clr-accent); background:var(--clr-accent-soft); }
.btn-ghost.btn-lg { padding:15px 28px; font-size:16px; }

.btn-danger {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--clr-danger);
  color:#fff;
  border:none; cursor:pointer;
  padding:10px 22px;
  border-radius:var(--radius-pill);
  font-weight:600; font-size:14px;
  transition:background var(--trans-fast), transform var(--trans-fast);
}
.btn-danger:hover { background:#c14430; transform:translateY(-1px); }
.btn-danger:active { transform:translateY(0); }

.btn-secondary {
  display:inline-flex; align-items:center; gap:6px;
  background:#F3F4F6;
  color:#4B5563;
  border:1px solid #E5E7EB; cursor:pointer;
  padding:10px 22px;
  border-radius:var(--radius-pill);
  font-weight:500; font-size:14px;
  transition:background var(--trans-fast), border-color var(--trans-fast);
}
.btn-secondary:hover { background:#E5E7EB; border-color:#D1D5DB; }

/* ─── BADGES / STATUS ─── */
.badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px;
  border-radius:var(--radius-pill);
  font-size:12px; font-weight:600;
  text-transform:uppercase; letter-spacing:.4px;
}
.badge-awaiting_quote    { background:#FEF3C7; color:#B45309; }
.badge-quote_sent        { background:#DBEAFE; color:#1D4ED8; }
.badge-pending           { background:var(--clr-warning-soft); color:var(--clr-warning); }
.badge-awaiting_advance  { background:#FFF7ED; color:#EA580C; }
.badge-advance_submitted { background:#ECFDF5; color:#059669; }
.badge-to_order          { background:#F5F3FF; color:#7C3AED; }
.badge-ordered           { background:var(--clr-info-soft);    color:var(--clr-info); }
.badge-shipping          { background:var(--clr-gold-soft);    color:#9a7a2e; }
.badge-delivered         { background:var(--clr-success-soft); color:var(--clr-success); }
.badge-cancelled         { background:var(--clr-danger-soft);  color:var(--clr-danger); }

.badge-dot {
  width:7px; height:7px;
  border-radius:50%;
  background:currentColor;
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; }
  50%      { opacity:.4; }
}

/* ─── STATUS LABELS (utilisées dans les formulaires) ─── */
.status-pending   { color:var(--clr-warning); }
.status-ordered   { color:var(--clr-info); }
.status-shipping  { color:var(--clr-gold); }
.status-delivered { color:var(--clr-success); }

/* ─── CARDS ─── */
.card {
  background:var(--clr-bg-card);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  border:1px solid var(--clr-border);
  padding:var(--sp-5);
  transition:box-shadow var(--trans-med);
}
.card:hover { box-shadow:var(--shadow-md); }

/* ─── FORM ELEMENTS ─── */
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:13px; font-weight:600; color:var(--clr-text-muted); text-transform:uppercase; letter-spacing:.5px; }

.form-input {
  width:100%;
  padding:13px 16px;
  border:1.5px solid var(--clr-border);
  border-radius:var(--radius-md);
  font-size:15px;
  background:#fff;
  color:var(--clr-text);
  transition:border-color var(--trans-fast), box-shadow var(--trans-fast);
}
.form-input::placeholder { color:var(--clr-text-muted); opacity:.6; }
.form-input:focus {
  border-color:var(--clr-border-focus);
  box-shadow:0 0 0 3px var(--clr-accent-soft);
}
.form-input.input-error {
  border-color:var(--clr-danger);
}
textarea.form-input { resize:vertical; min-height:80px; }
select.form-input { appearance:none; background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a6e64' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; }

.form-hint { font-size:12px; color:var(--clr-text-muted); margin-top:2px; }
.form-error { font-size:12px; color:var(--clr-danger); font-weight:500; display:none; }
.form-error.visible { display:block; }

/* ─── TOAST ─── */
.toast-container { position:fixed; top:24px; right:24px; z-index:2000; display:flex; flex-direction:column; gap:10px; }
.toast {
  display:flex; align-items:center; gap:12px;
  background:#fff; border-radius:var(--radius-md);
  padding:16px 20px;
  box-shadow:var(--shadow-lg);
  border-left:4px solid var(--clr-success);
  max-width:340px;
  animation:toast-in .35s var(--ease) forwards;
  opacity:0;
}
.toast.toast-error { border-left-color:var(--clr-danger); }
.toast.toast-warning { border-left-color:var(--clr-warning); }
.toast.toast-info { border-left-color:var(--clr-info); }
.toast-icon { font-size:20px; }
.toast-text { font-size:14px; font-weight:500; }
.toast.toast-out { animation:toast-out .25s var(--ease) forwards; }

@keyframes toast-in  { to { opacity:1; transform:translateY(0); } from { opacity:0; transform:translateY(-12px); } }
@keyframes toast-out { to { opacity:0; transform:translateX(40px); } }

/* ─── RESPONSIVE ─── */
@media (max-width:640px) {
  :root { --sp-5:16px; --sp-6:24px; }
  .container { padding:0 var(--sp-4); }
  .toast-container { top:auto; bottom:24px; right:16px; left:16px; }
}
