/* Eli Tech — Home Bento "Nos secteurs"
   Real video layer + poster fallback for all 8 sector cards. */
.bento-sectors {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 720px) {
  .bento-sectors {
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: minmax(180px, auto);
  }
  .bento-card--xl   { grid-column: span 6; grid-row: span 2; }
  .bento-card--lg   { grid-column: span 6; grid-row: span 2; }
  .bento-card--md   { grid-column: span 2; grid-row: span 2; }
  .bento-card--sm   { grid-column: span 2; grid-row: span 1; }
}

@media (min-width: 1024px) {
  .bento-sectors {
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: minmax(170px, auto);
  }
  .bento-card--xl   { grid-column: span 7; grid-row: span 2; }
  .bento-card--lg   { grid-column: span 5; grid-row: span 2; }
  .bento-card--md   { grid-column: span 4; grid-row: span 2; }
  .bento-card--sm   { grid-column: span 4; grid-row: span 1; }
}

.bento-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 240px;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid #e6ecf3;
  background: #0a172a;
  color: #ffffff;
  text-decoration: none;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  isolation: isolate;
}
.bento-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--bento-accent, #1E40AF) 50%, #d9e2ec);
  box-shadow: 0 26px 60px -28px color-mix(in srgb, var(--bento-accent, #1E40AF) 70%, rgba(15, 23, 42, 0.5));
}
.bento-card:focus-visible {
  outline: 2px solid var(--bento-accent, #1E40AF);
  outline-offset: 4px;
}

/* Visual layer: real poster image (or premium fallback) */
.bento-card-visual {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-color: #0a172a;
  background-image: var(--bento-poster, none);
  background-size: cover;
  background-position: center;
  transition: transform 0.6s ease;
  overflow: hidden;
}
.bento-card:hover .bento-card-visual { transform: scale(1.04); }

/* Real video layer — lazy-attached source via IntersectionObserver in index.js
   Plays muted / looped / playsinline only when the card is on screen, idle
   otherwise so LCP and bandwidth stay clean. */
.bento-card-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.bento-card-video.is-ready { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  .bento-card-video { display: none; }
}

/* Premium fallback for sectors without a real poster */
.bento-card-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(70% 60% at 80% 0%, color-mix(in srgb, var(--bento-accent, #1E40AF) 65%, transparent), transparent 65%),
    radial-gradient(60% 60% at 20% 100%, color-mix(in srgb, var(--bento-accent, #1E40AF) 45%, transparent), transparent 70%),
    linear-gradient(135deg, color-mix(in srgb, var(--bento-accent, #1E40AF) 80%, #0a172a) 0%, #0a172a 80%);
  opacity: var(--bento-fallback-opacity, 0);
}

/* Readability gradient — sits between the image and the text */
.bento-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(10, 23, 42, 0) 0%, rgba(10, 23, 42, 0) 35%, rgba(10, 23, 42, 0.55) 70%, rgba(10, 23, 42, 0.85) 100%),
    linear-gradient(160deg, rgba(10, 23, 42, 0.10) 0%, rgba(10, 23, 42, 0.0) 50%);
}

/* Subtle accent rim glow on hover */
.bento-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--bento-accent, #1E40AF) 25%, transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.bento-card:hover::after { opacity: 1; }

.bento-card .bento-badge {
  position: absolute;
  top: 18px; left: 18px;
  padding: 6px 10px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 999px;
  font: 700 11px/1 Inter, sans-serif;
  color: var(--bento-accent, #1E40AF);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.bento-card-title {
  font: 800 clamp(20px, 2.6vw, 30px)/1.15 Inter, sans-serif;
  letter-spacing: -0.01em;
  margin: 0;
  color: #ffffff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}
.bento-card-line {
  margin: 8px 0 0;
  font: 500 14px/1.5 Inter, sans-serif;
  color: rgba(255, 255, 255, 0.92);
  max-width: 32ch;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.4);
}
.bento-card-line em {
  font-family: "Instrument Serif", serif;
  font-style: italic;
  font-weight: 400;
  color: #ffffff;
}
.bento-card-cta {
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: 700 13px/1 Inter, sans-serif;
  color: #ffffff;
}
.bento-card-cta::after {
  content: "→";
  transition: transform 0.2s ease;
}
.bento-card:hover .bento-card-cta::after { transform: translateX(3px); }

.bento-card--xl .bento-card-title { font-size: clamp(26px, 3.2vw, 38px); }
.bento-card--xl { min-height: 320px; }
.bento-card--lg { min-height: 280px; }
.bento-card--sm { min-height: 160px; }
.bento-card--sm .bento-card-title { font-size: clamp(17px, 2vw, 22px); }
.bento-card--sm .bento-card-line { font-size: 13px; }

@media (prefers-reduced-motion: reduce) {
  .bento-card,
  .bento-card-visual { transition: none; }
  .bento-card:hover .bento-card-visual { transform: none; }
}

/* Sector accents */
.bento-card--s-restaurant    { --bento-accent: #D97706; }
.bento-card--s-garage        { --bento-accent: #1E40AF; }
.bento-card--s-barbier       { --bento-accent: #18181B; }
.bento-card--s-beaute        { --bento-accent: #BE185D; }
.bento-card--s-fitness       { --bento-accent: #DC2626; }
.bento-card--s-evenementiel  { --bento-accent: #7C3AED; }
.bento-card--s-boulangerie   { --bento-accent: #B45309; }
.bento-card--s-bar           { --bento-accent: #3D2418; }

/* Real poster backgrounds for all 8 sectors */
.bento-card--s-restaurant    { --bento-poster: url("/assets/videos/restaurant-poster.webp"); }
.bento-card--s-garage        { --bento-poster: url("/assets/videos/garage-poster.webp"); }
.bento-card--s-barbier       { --bento-poster: url("/assets/videos/barbershop-poster.webp"); }
.bento-card--s-beaute        { --bento-poster: url("/assets/videos/salon-poster.webp"); }
.bento-card--s-fitness       { --bento-poster: url("/assets/videos/fitness-poster.webp"); }
.bento-card--s-evenementiel  { --bento-poster: url("/assets/videos/evenementiel-poster.webp"); }
.bento-card--s-boulangerie   { --bento-poster: url("/assets/videos/boulangerie-poster.webp"); }
.bento-card--s-bar           { --bento-poster: url("/assets/videos/bar-poster.webp"); }

/* Button reset for bento cards rendered as <button> (modal triggers) */
button.bento-card {
  margin: 0;
  font: inherit;
  color: inherit;
  text-align: inherit;
  cursor: pointer;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
}
