/* =========================================================
   SUPER TAMPON — Thème moderne (surcouche Bootstrap 5)
   Toutes les classes custom préfixées "supertampon-"
   ========================================================= */

:root {
  /* Palette principale */
  --supertampon-ink:        #0b1220;      /* texte sombre */
  --supertampon-ink-soft:   #475467;      /* texte secondaire */
  --supertampon-bg:         #ffffff;
  --supertampon-bg-soft:    #f6f8fb;
  --supertampon-bg-deep:    #0f172a;      /* hero / footer */
  --supertampon-border:     #e4e9f0;

  --supertampon-primary:    #3b6dff;      /* bleu électrique */
  --supertampon-primary-dk: #2147c2;
  --supertampon-accent:     #ff5a36;      /* corail (CTA) */
  --supertampon-accent-dk:  #d63a18;
  --supertampon-warm:       #ffd23f;      /* jaune chaud */
  --supertampon-stamp-ink:  #c4332c;      /* couleur "encre" tampon preview */

  --supertampon-radius-sm:  10px;
  --supertampon-radius:     18px;
  --supertampon-radius-lg:  28px;

  --supertampon-shadow-sm:  0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);
  --supertampon-shadow:     0 4px 10px rgba(15,23,42,.04), 0 12px 28px rgba(15,23,42,.08);
  --supertampon-shadow-lg:  0 8px 20px rgba(15,23,42,.06), 0 24px 48px rgba(15,23,42,.14);
}

/* ---------- Reset typo ---------- */
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--supertampon-ink);
  background: var(--supertampon-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5, h6, .supertampon-display {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  letter-spacing: -.02em;
  font-weight: 700;
  color: var(--supertampon-ink);
}
h1 { font-size: clamp(2.4rem, 4.5vw, 3.6rem); line-height: 1.05; }
h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); line-height: 1.1; }

a { color: var(--supertampon-primary); text-decoration: none; }
a:hover { color: var(--supertampon-primary-dk); }

/* ---------- Navbar ---------- */
.supertampon-navbar {
  background: rgba(255,255,255,.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--supertampon-border);
  padding: .6rem 0;
}
.supertampon-navbar .nav-link {
  color: var(--supertampon-ink) !important;
  font-weight: 500;
  padding-inline: 1rem;
  border-radius: 8px;
}
.supertampon-navbar .nav-link:hover {
  color: var(--supertampon-primary) !important;
  background: var(--supertampon-bg-soft);
}
.supertampon-logo { height: 48px; width: auto; }

/* ---------- Hero ---------- */
.supertampon-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(1100px 600px at 110% -10%, rgba(255,90,54,.16), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(59,109,255,.20), transparent 55%),
    linear-gradient(180deg, #ffffff 0%, #f6f8fb 100%);
  padding: 6rem 0 5rem;
}
.supertampon-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: #fff;
  border: 1px solid var(--supertampon-border);
  color: var(--supertampon-ink-soft);
  font-size: .82rem;
  font-weight: 600;
  padding: .4rem .9rem;
  border-radius: 999px;
  box-shadow: var(--supertampon-shadow-sm);
}
.supertampon-eyebrow::before {
  content: ""; width: 8px; height: 8px;
  background: var(--supertampon-accent);
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(255,90,54,.18);
}
.supertampon-hero-lead {
  color: var(--supertampon-ink-soft);
  font-size: 1.15rem;
  max-width: 540px;
}

/* ---------- Boutons ---------- */
.btn-supertampon,
.btn-supertampon-ghost,
.btn-supertampon-outline {
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: -.01em;
  padding: .75rem 1.4rem;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-supertampon {
  background: var(--supertampon-accent);
  border: 1px solid var(--supertampon-accent);
  color: #fff;
  box-shadow: 0 6px 16px rgba(255,90,54,.32);
}
.btn-supertampon:hover {
  background: var(--supertampon-accent-dk);
  border-color: var(--supertampon-accent-dk);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(214,58,24,.36);
}
.btn-supertampon-ghost {
  background: #fff;
  border: 1px solid var(--supertampon-border);
  color: var(--supertampon-ink);
}
.btn-supertampon-ghost:hover {
  border-color: var(--supertampon-ink);
  color: var(--supertampon-ink);
  transform: translateY(-1px);
}
.btn-supertampon-outline {
  background: transparent;
  border: 1px solid var(--supertampon-ink);
  color: var(--supertampon-ink);
}
.btn-supertampon-outline:hover {
  background: var(--supertampon-ink);
  color: #fff;
}

/* ---------- Trust strip ---------- */
.supertampon-trust {
  border-top: 1px solid var(--supertampon-border);
  border-bottom: 1px solid var(--supertampon-border);
  background: #fff;
}
.supertampon-trust-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: 1.2rem 0;
  color: var(--supertampon-ink-soft);
  font-weight: 500;
  font-size: .95rem;
}
.supertampon-trust-item .icon {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--supertampon-bg-soft);
  border-radius: 10px;
  color: var(--supertampon-primary);
}

/* ---------- Cartes produit ---------- */
.supertampon-section { padding: 5rem 0; }
.supertampon-section-title { margin-bottom: 3rem; }

.supertampon-product-card {
  position: relative;
  display: block;
  background: #fff;
  border: 1px solid var(--supertampon-border);
  border-radius: var(--supertampon-radius);
  padding: 1.5rem;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.supertampon-product-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--supertampon-shadow-lg);
  border-color: transparent;
}
.supertampon-product-card .thumb {
  background: linear-gradient(180deg, #f5f8fd 0%, #e9eff8 100%);
  border-radius: var(--supertampon-radius-sm);
  padding: 1.5rem;
  margin-bottom: 1rem;
  display: flex; align-items: center; justify-content: center;
  aspect-ratio: 4 / 3;
}
.supertampon-product-card .thumb img { max-height: 100%; max-width: 100%; }
.supertampon-product-card .meta {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .25rem;
  color: var(--supertampon-ink-soft);
  font-size: .82rem;
  font-weight: 500;
}
.supertampon-product-card .meta::before {
  content: ""; width: 6px; height: 6px;
  background: var(--supertampon-primary);
  border-radius: 50%;
}
.supertampon-product-card .name {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: .25rem;
}
.supertampon-product-card .price {
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--supertampon-ink);
}
.supertampon-product-card .arrow {
  position: absolute; top: 1.5rem; right: 1.5rem;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--supertampon-bg-soft);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--supertampon-ink);
  font-size: 1.1rem;
  transition: background .2s, color .2s, transform .2s;
}
.supertampon-product-card:hover .arrow {
  background: var(--supertampon-accent);
  color: #fff;
  transform: rotate(-45deg);
}

/* ---------- Features ---------- */
.supertampon-feature {
  background: #fff;
  border: 1px solid var(--supertampon-border);
  border-radius: var(--supertampon-radius);
  padding: 2rem;
  height: 100%;
  transition: transform .2s, box-shadow .2s;
}
.supertampon-feature:hover {
  transform: translateY(-4px);
  box-shadow: var(--supertampon-shadow);
}
.supertampon-feature .num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--supertampon-primary);
  text-transform: uppercase;
}
.supertampon-feature h3 { font-size: 1.3rem; margin-top: .5rem; }
.supertampon-feature p { color: var(--supertampon-ink-soft); margin-bottom: 0; }

/* ---------- Page band (breadcrumb sobre) ---------- */
.supertampon-pageband {
  background: var(--supertampon-bg-soft);
  border-bottom: 1px solid var(--supertampon-border);
  padding: 1.2rem 0;
}
.supertampon-pageband .breadcrumb { margin: 0; }
.supertampon-pageband .breadcrumb a { color: var(--supertampon-ink-soft); }
.supertampon-pageband .breadcrumb .active { color: var(--supertampon-ink); font-weight: 500; }

/* ---------- Configurator (page produit) ---------- */
.supertampon-configurator {
  background: #fff;
  border: 1px solid var(--supertampon-border);
  border-radius: var(--supertampon-radius);
  padding: 1.75rem;
  box-shadow: var(--supertampon-shadow-sm);
}
.supertampon-configurator label {
  color: var(--supertampon-ink);
  font-weight: 500;
  font-size: .92rem;
  margin-bottom: .35rem;
}
.supertampon-configurator .form-control {
  border-radius: 10px;
  border: 1px solid var(--supertampon-border);
  padding: .7rem .95rem;
  font-size: 1rem;
  transition: border-color .15s, box-shadow .15s;
}
.supertampon-configurator .form-control:focus {
  border-color: var(--supertampon-primary);
  box-shadow: 0 0 0 4px rgba(59,109,255,.15);
}

/* ---------- Live stamp preview (vraie empreinte) ---------- */
.supertampon-preview {
  background:
    repeating-linear-gradient(45deg, #fafafa 0 6px, #f3f3f3 6px 12px);
  border: 1px solid var(--supertampon-border);
  border-radius: var(--supertampon-radius-sm);
  padding: 2rem 1rem;
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.supertampon-stamp {
  display: inline-block;
  padding: .85rem 1.6rem;
  border: 2px solid var(--supertampon-stamp-ink);
  border-radius: 4px;
  background: transparent;
  color: var(--supertampon-stamp-ink);
  font-family: 'Inter', Arial, sans-serif;
  font-weight: 600;
  text-align: center;
  transform: rotate(-4deg);
  position: relative;
  min-width: 240px;
  /* effet "encre légèrement irrégulière" */
  filter: contrast(1.05);
  letter-spacing: .02em;
  /* texture inégale */
  box-shadow:
    inset 0 0 0 1px rgba(196,51,44,.35),
    0 0 0 0 transparent;
}
.supertampon-stamp::before,
.supertampon-stamp::after {
  /* moucheture d'encre */
  content: "";
  position: absolute;
  background: var(--supertampon-stamp-ink);
  opacity: .25;
  border-radius: 50%;
}
.supertampon-stamp::before { width: 3px; height: 3px; top: -6px; left: 12%; }
.supertampon-stamp::after  { width: 4px; height: 4px; bottom: -7px; right: 18%; opacity: .2; }
.supertampon-stamp .line {
  line-height: 1.35;
  font-size: 1rem;
  white-space: nowrap;
}
.supertampon-stamp .line:first-child {
  font-weight: 800;
  font-size: 1.12rem;
  letter-spacing: .04em;
}
.supertampon-stamp .placeholder-line {
  opacity: .35;
  font-style: italic;
  font-weight: 500;
}

/* ---------- Tableau panier ---------- */
.supertampon-cart-table th {
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--supertampon-ink-soft);
  font-weight: 600;
  border-bottom: 1px solid var(--supertampon-border);
}
.supertampon-cart-table td { border-bottom: 1px solid var(--supertampon-border); }

.supertampon-summary {
  background: var(--supertampon-bg-soft);
  border: 1px solid var(--supertampon-border);
  border-radius: var(--supertampon-radius);
  padding: 1.5rem;
}

/* ---------- Footer ---------- */
.supertampon-footer {
  background: var(--supertampon-bg-deep);
  color: #cfd6e2;
  padding: 4rem 0 2rem;
}
.supertampon-footer h5 { color: #fff; font-size: 1rem; margin-bottom: 1rem; }
.supertampon-footer a  { color: #cfd6e2; }
.supertampon-footer a:hover { color: #fff; }
.supertampon-footer hr { border-color: rgba(255,255,255,.08); }

/* ---------- Cart badge dans nav ---------- */
.supertampon-cart-badge {
  background: var(--supertampon-accent);
  color: #fff;
  border-radius: 999px;
  font-size: .7rem;
  padding: .12rem .42rem;
  font-weight: 700;
  position: relative;
  top: -8px;
  left: -2px;
}

/* ---------- Tag jaune (eyebrow secondaire) ---------- */
.supertampon-tag {
  background: var(--supertampon-warm);
  color: var(--supertampon-ink);
  padding: .25rem .65rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .78rem;
}

/* ---------- Animations légères ---------- */
@keyframes supertampon-pop {
  0%   { transform: scale(.96); opacity: 0; }
  100% { transform: scale(1);    opacity: 1; }
}
.supertampon-pop { animation: supertampon-pop .25s ease-out; }
