/* ============================================================
   Urbanito - Homepage (home.css)
   Hero immersif "énergie claire" : mesh, produit flottant, chips.
   ============================================================ */

.hero { position: relative; padding: 76px 0 64px; overflow: hidden; border-bottom: 1px solid var(--line); }
.hero__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(720px 460px at 82% -8%, rgba(20, 224, 176, .22), transparent 60%),
    radial-gradient(640px 520px at 6% 4%, var(--brand-soft), transparent 58%),
    radial-gradient(520px 420px at 50% 120%, rgba(10, 184, 154, .12), transparent 60%);
}
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(21, 127, 102, .06) 1px, transparent 1px);
  background-size: 26px 26px; mask-image: radial-gradient(70% 60% at 50% 40%, #000, transparent 75%);
  -webkit-mask-image: radial-gradient(70% 60% at 50% 40%, #000, transparent 75%);
}
.hero__grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.12fr .88fr; gap: 52px; align-items: center; }
.hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; color: var(--brand-dark); font-weight: 700; font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; margin-bottom: 18px; background: rgba(20,224,176,.14); border: 1px solid rgba(21,127,102,.18); padding: 7px 14px; border-radius: 999px; }
.hero__eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--brand-mint); box-shadow: 0 0 0 4px rgba(20,224,176,.25); }
.hero__title { margin-bottom: 20px; line-height: 1.04; font-size: clamp(2.4rem, 5.8vw, 4rem); }
.hero__subtitle { font-size: 1.16rem; color: var(--text); max-width: 48ch; margin-bottom: 28px; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 34px; }
.hero__stats { display: flex; align-items: center; gap: 26px; }
.hero__stat { display: flex; flex-direction: column; }
.hero__stat-num { font-family: var(--font-display); font-size: 1.9rem; font-weight: 700; color: var(--ink); letter-spacing: -.02em; line-height: 1; }
.hero__stat-label { font-size: .78rem; color: var(--muted); margin-top: 4px; }
.hero__stat-sep { width: 1px; height: 38px; background: var(--line); }

.hero__panel { position: relative; }
.hero__panel-media {
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
  padding: 26px; position: relative;
  --acc-rgb: var(--acc-mint-rgb);
}
.hero__panel-media img { width: 100%; aspect-ratio: 4/3; object-fit: contain; }
.hero__float {
  position: absolute; z-index: 2;
  background: rgba(255,255,255,.9); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--line); box-shadow: var(--shadow);
  font-weight: 700; font-size: .82rem; color: var(--ink);
  padding: 9px 14px; border-radius: 999px; display: inline-flex; align-items: center; gap: 7px;
  animation: heroFloat 4.5s ease-in-out infinite;
}
.hero__float--1 { top: 14px; right: 14px; color: var(--brand-dark); }
.hero__float--2 { bottom: 64px; left: -14px; animation-delay: .6s; }
.hero__float .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--grad-mint); }
@keyframes heroFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@media (prefers-reduced-motion: reduce) { .hero__float { animation: none; } }
.hero__panel-foot { padding: 16px 6px 2px; }
.hero__panel-foot .pcard__link { font-weight: 700; }

@media (max-width: 860px) {
  .hero__grid { grid-template-columns: 1fr; gap: 36px; }
  .hero__panel { max-width: 440px; }
  .hero__float--2 { left: 8px; }
}
@media (max-width: 420px) {
  .hero__stats { gap: 16px; }
  .hero__stat-num { font-size: 1.5rem; }
  .hero { padding: 52px 0 48px; }
}
