/* ============================================================
   PRICE NINJA — stile custom (basato sui token di Figma)
   ============================================================ */

/* ---------- Design tokens ---------- */
:root {
  /* Colori */
  --pn-blu:           #1D51BF;   /* primario / bottoni */
  --pn-blu-50:        #4E70D9;
  --pn-blu-60:        #6A8AF4;
  --pn-blu-80:        #B6C4FA;
  --pn-blu-90:        #DCE1FC;
  --pn-blu-superficie:#EEF0FE;
  --pn-blu-scuro:     #163DA0;
  --pn-navy:          #051747;   /* testo primario / sfondo scuro */
  --pn-arancione:     #EA4600;
  --pn-neutro-10:     #353333;   /* testo body */
  --pn-neutro-40:     #837E80;   /* placeholder */
  --pn-sfondo-chiaro: #FEF8F8;
  --pn-bianco:        #FFFFFF;
  --pn-sfondo-pagina: #F4F5F8;   /* off-white: sfondo sezioni (le card restano bianche → risaltano) */
  --pn-success:       #0DBD79;
  --pn-divisore:      #DCE1FC;

  /* Tipografia */
  --pn-font-titoli: 'Zalando Sans', 'Inter', system-ui, -apple-system, sans-serif;
  --pn-font-testo:  'Inter', system-ui, -apple-system, sans-serif;

  /* Raggi */
  --pn-raggio-md:   12px;
  --pn-raggio-lg:   16px;
  --pn-raggio-xl:   24px;
  --pn-raggio-pill: 100px;

  /* Spaziature (scala Figma) */
  --pn-sp-2: 4px;  --pn-sp-3: 8px;  --pn-sp-4: 12px; --pn-sp-5: 16px;
  --pn-sp-7: 24px; --pn-sp-9: 40px; --pn-sp-12: 64px; --pn-sp-16: 96px;
}

/* ---------- Base ---------- */
body {
  font-family: var(--pn-font-testo);
  color: var(--pn-neutro-10);
  background: var(--pn-sfondo-pagina);
}
h1, h2, h3, h4, h5, h6 { font-family: var(--pn-font-titoli); }
.t-orange { color: var(--pn-arancione); }

/* Larghezza max contenuto = 1320px (come Figma) */
.container-xxl { max-width: 1320px; }

/* ============================================================
   HEADER
   ============================================================ */
.pn-header {
  background: transparent;
  position: fixed;          /* overlay sopra la hero, così il blu della hero si vede sotto */
  top: 0;
  left: 0;
  right: 0;
  z-index: 1030;
  transition: background-color 240ms ease, box-shadow 240ms ease;
}

body.has-admin-top-menu .pn-header {
  position: sticky;
  top: 0;
  background: var(--pn-blu);
}

/* Da desktop in su: una volta scrollato oltre la soglia, sfondo blu pieno + ombra.
   Su mobile (<768px) il media query in fondo sovrascrive con la solita navy. */
@media (min-width: 768px) {
  .pn-header.is-scrolled {
    background: var(--pn-blu);
    box-shadow: 0 6px 24px rgba(8, 29, 90, .25);
  }
}
.pn-header .navbar { padding-top: 0; padding-bottom: 0; min-height: 90px; }

/* Logo: due immagini sovrapposte nel DOM. Visibilità governata da .is-scrolled. */
.pn-logo { display: flex; align-items: center; }
.pn-logo__img { display: block; }
/* default: la versione orizzontale "full" è visibile, la "mini" (P) è nascosta */
.pn-logo__img--full { width: auto; }
.pn-logo__img--mini { display: none; width: auto; }

/* Desktop ≥1200: i due loghi sono sovrapposti in absolute → crossfade via opacity.
   In compatto il contenitore si restringe (214→58) liberando spazio per la search. */
@media (min-width: 1200px) {
  .pn-logo {
    position: relative;
    width: 214px;
    height: 40px;
    flex: 0 0 auto;
    overflow: hidden;                /* clippa il full logo mentre il contenitore si restringe */
    transition: width 320ms ease;
  }
  /* mini logo aspect ~1.655 → 40px alto = ~66px largo; teniamo 70px per qualche px di respiro */
  .pn-header.is-compact .pn-logo { width: 70px; }
  .pn-logo__img--full,
  .pn-logo__img--mini {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: opacity 280ms ease;
  }
  .pn-logo__img--full { height: 34px; opacity: 1; }
  .pn-logo__img--mini { display: block; height: 40px; opacity: 0; }
  .pn-header.is-compact .pn-logo__img--full { opacity: 0; }
  .pn-header.is-compact .pn-logo__img--mini { opacity: 1; }
}

/* Search bar nell'header (desktop ≥1200, solo quando .is-compact).
   Hidden ovunque per default. A desktop ≥1200 è sempre in flex ma con width:0 in espanso,
   così l'apparizione è uno slide-in animato (width + opacity). */
.pn-header__search {
  display: none;
  align-items: center;
  background: #3256be;             /* var(--pn-blu-50) come da Figma */
  border-radius: 100px;
  flex: 0 0 auto;
  overflow: hidden;
  box-sizing: border-box;
}
.pn-header__search-input {
  background: transparent;
  border: none; outline: none;
  color: #fff;
  flex: 1 1 auto;
  min-width: 0;                /* permette al testo di scorrere dentro l'input quando overflowa */
  font-size: 16px; font-family: var(--pn-font-testo);
  padding: 6px 0;
  /* L'input di tipo "text" scrolla orizzontalmente dentro di sé in modo nativo:
     il cursore resta visibile e il testo precedente scorre fuori a sinistra. */
  text-overflow: ellipsis;     /* "Cerca prodotto…" se overflowa fuori focus */
}
.pn-header__search-input::placeholder { color: #90a7f9; }
.pn-header__search-btn {
  background: transparent;
  border: none; cursor: pointer;
  color: #fff;
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex: 0 0 auto;
  padding: 0;
}
.pn-header__search-btn:hover { color: rgba(255, 255, 255, .85); }
@media (min-width: 1200px) {
  /* Da desktop in su la search è sempre in flex ma collassata (width:0). Quando .is-compact
     parte uno slide-in animato con width + opacity insieme. */
  .pn-header__search {
    display: flex;
    width: 0;
    margin-left: 0;
    padding: 0;
    opacity: 0;
    transition:
      width 320ms ease,
      opacity 240ms ease 60ms,
      margin-left 320ms ease,
      padding 320ms ease;
  }
  .pn-header.is-compact .pn-header__search {
    width: clamp(150px, 12vw, 320px);   /* compensa il logo più largo (70 invece di 58) */
    margin-left: 16px;
    padding: 10px 18px;        /* pillola simmetrica come da Figma */
    gap: 8px;                  /* spazio tra input e icona-search */
    opacity: 1;
  }
}

/* Megamenu: pannello full-width che appare on-hover su .pn-mega.
   Aperto via toggle JS della classe .is-open + popolamento da PN_MEGAMENU. */
.pn-megamenu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--pn-blu);
  border-top: 1px solid rgba(255, 255, 255, .08);
  padding: 28px 0 32px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity 200ms ease, transform 200ms ease, visibility 0s linear 200ms;
  z-index: 1029;       /* sotto al navbar (1030) così il bordo superiore "compenetra" */
}
.pn-megamenu[hidden] { display: none; }
.pn-megamenu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 200ms ease, transform 200ms ease, visibility 0s;
}
.pn-megamenu__inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.pn-megamenu__col {
  padding: 0 32px;
  border-left: 1px solid rgba(255, 255, 255, .12);
}
.pn-megamenu__col:first-child { border-left: 0; padding-left: 16px; }
.pn-megamenu__col:last-child  { padding-right: 16px; }
.pn-megamenu__title {
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 16px;
  letter-spacing: -0.2px;
}
.pn-megamenu__group { margin-bottom: 16px; }
.pn-megamenu__group:last-child { margin-bottom: 0; }
.pn-megamenu__label {
  color: #90a7f9;
  font-size: 13px;
  font-weight: 500;
  margin: 0 0 6px;
}
.pn-megamenu__list { list-style: none; margin: 0; padding: 0; }
.pn-megamenu__list li { margin: 0 0 4px; }
.pn-megamenu__list a {
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 400;
  display: inline-block;
  padding: 2px 0;
  transition: color 120ms ease;
}
.pn-megamenu__list a:hover { color: #90a7f9; }

/* Nasconde il megamenu sotto desktop (su mobile/tablet si usa il menu hamburger) */
@media (max-width: 1199.98px) {
  .pn-megamenu { display: none !important; }
}

/* Link categorie — padding ridotto per fittare 7 voci + search nella stessa riga */
.pn-header .nav-link {
  color: rgba(255, 255, 255, .92);
  font-family: var(--pn-font-testo);
  font-size: 13px;
  font-weight: 500;
  padding: 6px 6px;
  white-space: nowrap;
}
.pn-header .nav-link:hover,
.pn-header .nav-link:focus { color: #fff; }
.pn-header .dropdown-toggle::after { margin-left: 4px; opacity: .8; }
/* Chevron compatta sulle voci del menu mega — piccola per non gonfiare la barra */
.pn-mega .nav-link .bi-chevron-down {
  font-size: 9px;
  opacity: .75;
  margin-left: 3px !important;       /* override Bootstrap ms-1 */
  vertical-align: 2px;
}

/* ---- Sottocategorie nel menu mobile/tablet (accordion sotto ogni categoria) ----
   Iniettate da js/main.js (renderMobileSub). Solo <1200px; su desktop c'è il megamenu. */
@media (min-width: 1200px) {
  .pn-mega__sub { display: none !important; }
}
@media (max-width: 1199.98px) {
  .pn-mega { width: 100%; flex-wrap: wrap; }
  .pn-mega .nav-link { width: 100%; display: flex; align-items: center; justify-content: space-between; }
  .pn-mega .nav-link .bi-chevron-down { font-size: 13px; opacity: .9; vertical-align: 0; }
  .pn-mega .nav-link[aria-expanded="true"] .bi-chevron-down { transform: rotate(180deg); }
  .pn-mega__sub { width: 100%; padding: 2px 0 10px 14px; }
  .pn-mega__sub-col { padding: 6px 0; }
  .pn-mega__sub-title { color: #fff; font-weight: 600; font-size: 13px; margin: 6px 0 4px; }
  .pn-mega__sub-list { list-style: none; margin: 0; padding: 0; }
  .pn-mega__sub-list li { margin: 0; }
  .pn-mega__sub-list a { display: block; color: var(--pn-blu-80); text-decoration: none; font-size: 13px; padding: 5px 0; }
  .pn-mega__sub-list a:hover { color: #fff; }
}

/* Stores / Compara — icona sopra, testo sotto */
.pn-iconlink {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: 12px !important;
  line-height: 1.1;
}
.pn-iconlink i { font-size: 18px; }

/* Divisore verticale */
.pn-vdivider {
  width: 1px;
  height: 40px;
  background: rgba(255, 255, 255, .25);
  margin: 0 12px;
}

/* Toggler mobile */
.navbar-toggler {
  border: none;
  color: #fff;
  font-size: 26px;
  padding: 4px 8px;
}
.navbar-toggler:focus { box-shadow: none; }

/* Su mobile il menu collassato ha sfondo scuro leggibile */
@media (max-width: 1199.98px) {
  .pn-header .navbar-collapse {
    background: var(--pn-blu-scuro);
    border-radius: var(--pn-raggio-lg);
    padding: 12px 16px;
    margin-top: 12px;
  }
  .pn-iconlink { flex-direction: row; gap: 8px; justify-content: flex-start; }
  .pn-iconlink i { font-size: 16px; }
}

/* ============================================================
   HERO
   ============================================================ */
.pn-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #0d2a7e 0%, #081d5a 55%, var(--pn-navy) 100%);
  padding: 300px 0 280px;    /* hero più alta: l'header è fixed/overlay, serve aria sotto al menu */
  border-bottom-left-radius: 40px;
  border-bottom-right-radius: 40px;
}

/* Bagliore animato dietro la barra di ricerca (pulsa + segue il mouse) */
.pn-hero__glow {
  position: absolute;
  z-index: 0;
  top: 64%;
  left: 50%;
  width: min(82%, 1040px);
  aspect-ratio: 1 / 1;
  transform: translate(-50%, -50%) translate(var(--gx, 0px), var(--gy, 0px));
  transition: transform .5s ease-out;
  pointer-events: none;
}
.pn-hero__glow-core {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(120, 150, 255, .8) 0%, rgba(78, 112, 217, .35) 42%, rgba(5, 23, 71, 0) 70%);
  filter: blur(22px);
  animation: pn-glow-pulse 5.5s ease-in-out infinite;
}
@keyframes pn-glow-pulse {
  0%, 100% { transform: scale(.95); opacity: .5; }
  50%      { transform: scale(1.22); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .pn-hero__glow { transition: none; }
  .pn-hero__glow-core { animation: none; }
}

.pn-hero__inner {
  position: relative;
  z-index: 2;
  text-align: center;
}

.pn-hero__title {
  color: var(--pn-bianco);
  font-weight: 600;
  font-size: clamp(34px, 5vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.5px;
  margin: 0 auto 12px;
}

.pn-hero__subtitle {
  color: rgba(255, 255, 255, .85);
  font-size: clamp(15px, 2vw, 20px);
  margin-bottom: 40px;
}

/* ---------- Barra di ricerca ---------- */
.pn-search {
  display: flex;
  align-items: center;
  gap: 8px;
  max-width: 872px;
  margin: 0 auto;
  background: var(--pn-bianco);
  border-radius: var(--pn-raggio-lg);
  padding: 8px 8px 8px 20px;
  box-shadow: 0 18px 45px rgba(5, 23, 71, .35);
}
.pn-search__catbtn,
.pn-home .pn-search .pn-search__catbtn.btn {
  background: transparent;
  border: none;
  color: var(--pn-navy);
  font-weight: 600;
  font-size: 16px;
  white-space: nowrap;
  padding: 8px 4px;
  box-shadow: none;
}
.pn-search__catbtn:hover,
.pn-home .pn-search .pn-search__catbtn.btn:hover,
.pn-home .pn-search .pn-search__catbtn.btn:focus {
  color: var(--pn-blu);
  background: transparent;
  border: none;
  box-shadow: none;
}
.pn-search__cat .dropdown-menu {
  min-width: 176px;
  margin-top: 0;
  padding: 10px 0;
  border: 1px solid var(--pn-divisore);
  border-radius: 6px;
  background: var(--pn-bianco);
  box-shadow: 0 12px 30px rgba(5, 23, 71, .14);
  transform: none !important;
}
.pn-search__cat .dropdown-item {
  display: block;
  padding: 8px 18px;
  color: var(--pn-neutro-10);
  font-size: 16px;
  line-height: 1.3;
  text-decoration: none;
  white-space: nowrap;
}
.pn-search__cat .dropdown-item:hover,
.pn-search__cat .dropdown-item:focus {
  color: var(--pn-neutro-10);
  background: rgba(16, 80, 173, .08);
}
.pn-search__vdivider {
  width: 1px;
  height: 32px;
  background: var(--pn-divisore);
  flex: 0 0 auto;
}
.pn-search__input {
  flex: 1 1 auto;
  border: none;
  outline: none;
  font-size: 16px;
  color: var(--pn-neutro-10);
  min-width: 0;
  padding: 8px 4px;
}
.pn-search__input::placeholder { color: var(--pn-neutro-40); }
.pn-search__clear {
  border: none;
  background: transparent;
  color: var(--pn-neutro-40);
  font-size: 14px;
  padding: 6px 8px;
  cursor: pointer;
}
.pn-search__clear:hover { color: var(--pn-neutro-10); }
.pn-search__submit {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--pn-blu);
  color: #fff;
  border: none;
  border-radius: var(--pn-raggio-md);
  font-weight: 600;
  font-size: 16px;
  padding: 12px 20px;
  cursor: pointer;
  transition: background .15s ease;
}
.pn-search__submit:hover { background: var(--pn-blu-scuro); }

/* ---------- Chips popolari ---------- */
.pn-hero__suggest {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}
.pn-hero__suggest-label {
  color: rgba(255, 255, 255, .55);
  font-size: 14px;
  margin-right: 4px;
}
.pn-chip {
  display: inline-block;
  padding: 6px 14px;
  border: 1px solid rgba(255, 255, 255, .25);
  border-radius: var(--pn-raggio-pill);
  color: rgba(255, 255, 255, .9);
  font-size: 13px;
  text-decoration: none;
  transition: background .15s ease, border-color .15s ease;
}
.pn-chip:hover {
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .5);
  color: #fff;
}

/* ---------- Immagini 3D fluttuanti ---------- */
/* Layer ancorato alla stessa area del frame Figma (1544 x 680). */
.pn-hero__decor {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
.pn-float {
  position: absolute;
  height: auto;
  filter: drop-shadow(0 24px 40px rgba(0, 0, 0, .35));
  will-change: transform;       /* fluidità del parallax */
  transform: translateY(var(--py, 0px));   /* spostamento parallax (impostato da JS) */
}
/* posizioni in % (left/width su 1544, top su 680) — icone ridimensionate ~16% in meno.
   Top row liberare la zona dell'header (overlay trasparente).
   MacBook shiftato a destra per non finire sotto la "P" di "Paga meno". */
.pn-float--dyson      { left: -2%;   top: 18%;  width: 16%;  }
.pn-float--macbook    { left: 30%;   top: 14%;  width: 14%;  }
.pn-float--controller { left: 58%;   top: 10%;  width: 13%;  }
.pn-float--sneakers   { left: 75%;   top: 16%;  width: 11.5%;}
.pn-float--sunglasses { left: 81%;   top: 60%;  width: 12%;  }
.pn-float--headphones { left: 18%;   top: 68%;  width: 13%;  }
.pn-float--yogamat    { left: 57%;   top: 68%;  width: 14.5%;}
.pn-float--bikini     { left: 1%;    top: 62%;  width: 15%;  }
.pn-float--flipflops  { left: 44%;   top: 68%;  width: 13%;  }

/* Mobile (<768px): icone hero grandi, distribuite top/bottom (stile Figma mobile V3). */
@media (max-width: 991.98px) {
  .pn-hero { padding: 64px 0 80px; }
  .pn-hero__decor { display: block; }
  .pn-float--dyson      { left: -14%; top: 9%;  width: 42%; }
  .pn-float--macbook    { left: 27%;  top: 6%;  width: 38%; }
  .pn-float--controller { left: 72%;  top: 9%;  width: 42%; }
  .pn-float--sneakers   { display: none; }
  .pn-float--sunglasses { display: none; }
  .pn-float--bikini     { left: -15%; top: 74%; width: 46%; }
  .pn-float--headphones { left: 4%;   top: 86%; width: 38%; }
  .pn-float--flipflops  { left: 70%;  top: 74%; width: 40%; }
  .pn-float--yogamat    { left: 48%;  top: 85%; width: 36%; }
}

/* Tablet portrait (768-991px): icone più piccole e spinte verso gli angoli
   così non si sovrappongono al titolo e alla search bar, e hero più alta. */
@media (min-width: 768px) and (max-width: 991.98px) {
  .pn-hero { padding: 200px 0 240px; }
  .pn-float--dyson      { left: -3%;  top: 14%; width: 22%; }
  .pn-float--macbook    { left: 39%;  top: 8%;  width: 22%; }
  .pn-float--controller { left: 78%;  top: 14%; width: 22%; }
  .pn-float--bikini     { left: -2%;  top: 68%; width: 22%; }
  .pn-float--headphones { left: 78%;  top: 68%; width: 22%; }
  .pn-float--flipflops  { left: 22%;  top: 80%; width: 22%; }
  .pn-float--yogamat    { left: 55%;  top: 80%; width: 22%; }
}

/* Ricerca responsive: su mobile manda a capo elegantemente */
@media (max-width: 575.98px) {
  .pn-search { flex-wrap: wrap; border-radius: var(--pn-raggio-lg); }
  .pn-search__vdivider { display: none; }
  .pn-search__input { flex-basis: 100%; order: 3; border-top: 1px solid var(--pn-divisore); margin-top: 4px; padding-top: 12px; }
  .pn-search__submit { order: 4; flex: 1 1 100%; justify-content: center; }
}

/* ============================================================
   COMPONENTI RIUTILIZZABILI
   ============================================================ */

/* Bottone primario blu */
.pn-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--pn-blu);
  color: #fff;
  border: none;
  border-radius: var(--pn-raggio-md);
  font-family: var(--pn-font-testo);
  font-weight: 600;
  font-size: 16px;
  line-height: 1;
  padding: 12px 20px;
  text-decoration: none;
  white-space: nowrap;
  transition: background .15s ease;
}
.pn-btn-primary:hover { background: var(--pn-blu-scuro); color: #fff; }

/* Chip "Offerta a tempo" */
.pn-chip-time {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  align-self: flex-start;
  background: var(--pn-blu-superficie);
  color: var(--pn-blu-scuro);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--pn-raggio-pill);
}

/* Pallini del carosello */
.pn-dots {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  margin-top: 16px;
}
.pn-dot {
  width: 8px; height: 8px;
  border-radius: var(--pn-raggio-pill);
  background: var(--pn-blu-60);
  border: none; padding: 0; cursor: pointer;
  -webkit-appearance: none; appearance: none;
  transition: width .25s ease, background .25s ease;
}
.pn-dot--active { width: 24px; background: var(--pn-arancione); }

/* ============================================================
   SEZIONE CAROSELLO
   ============================================================ */
.pn-carousel {
  position: relative;
  z-index: 3;
  background: transparent;      /* lascia vedere gli angoli arrotondati della hero */
  padding: 0 0 64px;
  margin-top: -64px;            /* il banner emerge sopra la hero, come nel Figma */
}
.pn-carousel__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
/* Tablet (≥768px): banner e featured fianco-a-fianco con ratio bilanciato (50/50)
   e altezza uguale (il banner stretcha a tutta l'altezza della featured). */
@media (min-width: 768px) {
  .pn-carousel__grid { grid-template-columns: 1fr 1fr; align-items: stretch; gap: 20px; }
}
@media (min-width: 768px) {
  /* fa crescere il banner a tutta l'altezza della featured card (più alta),
     così la colonna sinistra eguaglia sempre l'altezza di quella destra */
  .pn-banner-wrap { display: flex; flex-direction: column; min-height: 0; }
  .pn-banner-carousel {
    aspect-ratio: auto;
    flex: 1 1 auto;
    min-height: 0;
  }
}
/* Desktop (≥992px): ratio più "Figma" 2:1 con banner più largo */
@media (min-width: 992px) {
  .pn-carousel__grid { grid-template-columns: minmax(0, 2.05fr) minmax(0, 1fr); gap: 24px; }
}

/* --- Banner illustrato --- */
.pn-banner {
  position: relative;
  display: block;
  aspect-ratio: 872 / 490;
  border-radius: var(--pn-raggio-lg);
  overflow: hidden;
  padding: 24px;
  text-decoration: none;
  box-shadow: 0 16px 40px rgba(5, 23, 71, .14);
}
.pn-banner__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pn-banner__overlay {
  position: absolute;
  inset: 0;
  background: rgba(110, 192, 89, .4);
}
.pn-banner__title {
  position: relative;
  color: #1d1b20;
  font-weight: 600;
  font-size: clamp(30px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.5px;
  margin: 0;
}
.pn-banner__cta {
  position: absolute;
  right: 24px;
  bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #1d1b20;
  font-weight: 600;
  font-size: 16px;
}

/* --- Banner carosello (4 slide) --- */
.pn-banner-carousel {
  position: relative;
  aspect-ratio: 872 / 490;
  border-radius: var(--pn-raggio-lg);
  overflow: hidden;
  box-shadow: 0 16px 40px rgba(5, 23, 71, .14);
  cursor: pointer;
  transition: transform 280ms ease, box-shadow 280ms ease;
}
.pn-banner-carousel:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 56px rgba(5, 23, 71, .24);
}
/* zoom morbido dell'immagine bg al hover (sentire la "vita" del card) */
.pn-banner-slide__bg { transition: transform 700ms ease; }
.pn-banner-carousel:hover .pn-banner-slide__bg { transform: scale(1.05); }
/* freccia "VEDI OFFERTE" scivola a destra al hover */
.pn-banner-slide__cta .bi-arrow-right,
.pn-banner-slide__cta i { transition: transform 240ms ease; }
.pn-banner-carousel:hover .pn-banner-slide__cta .bi-arrow-right,
.pn-banner-carousel:hover .pn-banner-slide__cta i { transform: translateX(4px); }
.pn-banner-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity .6s ease;
}
.pn-banner-slide.is-active { opacity: 1; visibility: visible; }
.pn-banner-slide__link {
  position: absolute;
  inset: 0;
  display: block;
  padding: 24px;
  text-decoration: none;
}
.pn-banner-slide__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.pn-banner-slide__overlay { position: absolute; inset: 0; }
.pn-banner-slide__title {
  position: relative;
  font-family: var(--pn-font-titoli);
  font-weight: 600;
  font-size: clamp(30px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.5px;
  margin: 0;
}
.pn-banner-slide__cta {
  position: absolute;
  right: 24px;
  bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 16px;
}
@media (max-width: 575.98px) { .pn-banner-slide__cta { font-size: 14px; } }

/* --- Card prodotto in evidenza --- */
.pn-featured-wrap { display: flex; flex-direction: column; }
.pn-featured {
  flex: 1 1 auto;
  display: flex;
  background: var(--pn-bianco);
  border: 1px solid var(--pn-blu-superficie);
  border-radius: var(--pn-raggio-lg);
  padding: 24px;
  box-shadow: 0 8px 24px rgba(5, 23, 71, .06);
  transition: transform 280ms ease, box-shadow 280ms ease, border-color 280ms ease;
}
.pn-featured:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 56px rgba(5, 23, 71, .14);
  border-color: rgba(50, 86, 190, .35);   /* accent blu sottile */
}
/* la freccia del bottone "Scopri di più" si muove al hover della card */
.pn-featured .pn-btn-primary i { transition: transform 240ms ease; }
.pn-featured:hover .pn-btn-primary i { transform: translateX(4px); }

/* Accessibilità: zero animazioni hover per chi preferisce ridurre il movimento */
@media (prefers-reduced-motion: reduce) {
  .pn-banner-carousel, .pn-banner-carousel:hover,
  .pn-banner-slide__bg, .pn-banner-carousel:hover .pn-banner-slide__bg,
  .pn-banner-slide__cta i, .pn-banner-carousel:hover .pn-banner-slide__cta i,
  .pn-featured, .pn-featured:hover,
  .pn-featured .pn-btn-primary i, .pn-featured:hover .pn-btn-primary i {
    transition: none !important;
    transform: none !important;
  }
}
.pn-featured__inner {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: opacity .3s ease;
}
.pn-featured.is-fading .pn-featured__inner { opacity: 0; }
.pn-featured__img {
  width: 190px;
  height: 190px;
  border-radius: var(--pn-raggio-md);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.pn-featured__img img { width: 100%; height: 100%; object-fit: contain; }
.pn-featured__title {
  color: var(--pn-navy);
  font-weight: 600;
  font-size: 24px;
  line-height: 1.25;
  letter-spacing: -0.15px;
  margin: 4px 0 0;
  min-height: 60px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.pn-featured__desc {
  color: var(--pn-neutro-10);
  font-size: 14px;
  line-height: 1.45;
  margin: 0;
  min-height: 40.6px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.pn-featured__actions {
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
  padding-top: 8px;
}
.pn-featured__empty {
  flex: 1 1 auto;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}
.pn-featured__empty .pn-featured__actions {
  margin-top: 8px;
  justify-content: flex-start;
}

@media (max-width: 575.98px) {
  .pn-featured__img { width: 140px; height: 140px; }
  .pn-banner__cta { font-size: 14px; }
}

/* Tag/etichetta sezione (es. "PERCHÈ PRICE NINJA", "NEWSLETTER") */
.pn-tag {
  display: inline-block;
  background: var(--pn-arancione);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  padding: 4px 16px;
  border-radius: var(--pn-raggio-pill);
}

/* ============================================================
   SEZIONE "PERCHÉ PRICE NINJA"
   ============================================================ */
.pn-why {
  background: var(--pn-sfondo-pagina);
  /* top generoso (continua il distacco dalla hero), bottom ridotto: chiude il gap verso "Prodotti popolari" */
  padding: clamp(64px, 10vw, 140px) 0 clamp(24px, 3vw, 48px);
}
.pn-why__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: start;       /* video allineato in alto col blocco "Perché Price Ninja" */
}
@media (min-width: 992px) {
  .pn-why__grid { grid-template-columns: 424px 1fr; gap: 24px; }
}
.pn-why__illu { display: flex; justify-content: center; }
.pn-why__illu img { width: 100%; max-width: 424px; height: auto; }
.pn-why__video {
  width: 100%;
  max-width: 424px;
  aspect-ratio: 1 / 1;
  object-fit: cover;          /* center crop del video 16:9 nel quadrato */
  border-radius: var(--pn-raggio-lg);
  background: #fff;
  display: block;
}

.pn-why__title {
  color: var(--pn-neutro-10);                 /* #353333 come da design */
  font-weight: 600;
  font-size: clamp(28px, 3.4vw, 36px);
  line-height: 1.22;
  letter-spacing: -0.3px;
  margin: 16px 0 12px;
}
.pn-why__subtitle {
  color: var(--pn-neutro-10);
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.4;
  max-width: 600px;
  margin: 0 0 clamp(40px, 5vw, 64px);
}

/* Statistiche (centrate, come nel Figma) */
.pn-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 24px;
}
@media (min-width: 992px) { .pn-stats { grid-template-columns: repeat(4, 1fr); } }

.pn-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.pn-stat__icon {
  width: clamp(96px, 10vw, 128px);
  height: clamp(96px, 10vw, 128px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pn-stat__icon img { width: 100%; height: 100%; object-fit: contain; }
.pn-stat__num {
  font-family: var(--pn-font-titoli);
  font-weight: 600;
  font-size: clamp(34px, 4vw, 42px);
  color: #3e4142;
  line-height: 1.1;
  letter-spacing: -0.4px;
}
.pn-stat__label {
  font-family: var(--pn-font-titoli);
  font-weight: 600;          /* bold come da brief */
  font-size: clamp(18px, 2vw, 20px);
  color: #3e4142;
  line-height: 1.3;
}
.pn-stat__desc {
  font-weight: 300;
  font-size: 16px;
  line-height: 1.4;
  color: var(--pn-neutro-10);
  margin: 0;
}

/* ============================================================
   SEZIONI PRODOTTO (container più stretto, 1140px)
   ============================================================ */
.pn-container {
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 16px;
}
.pn-section { padding: clamp(40px, 5vw, 64px) 0; background: var(--pn-sfondo-pagina); }
.pn-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
}
.pn-section__title {
  font-family: var(--pn-font-titoli);
  font-weight: 600;
  font-size: 20px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--pn-navy);
  margin: 0;
}

/* Griglia card prodotto */
.pn-products {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (min-width: 576px)  { .pn-products { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 768px)  { .pn-products { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1200px) { .pn-products { grid-template-columns: repeat(6, 1fr); } }

/* ---------- Card prodotto (riutilizzabile) ---------- */
.pn-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--pn-bianco);
  border: 1px solid var(--pn-blu-superficie);
  border-radius: var(--pn-raggio-xl);
  padding: 12px;
  text-decoration: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.pn-card:hover {
  border-color: var(--pn-blu-80);
  background: #fefbff;
  box-shadow: 0 10px 24px rgba(5, 23, 71, .08);
}
.pn-card__media {
  position: relative;
  display: block;
  border-radius: var(--pn-raggio-lg);
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #fff;
}
.pn-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pn-card__badge {
  position: absolute;
  top: 8px;
  left: 8px;
  background: var(--pn-blu-80);
  color: var(--pn-navy);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.1px;
  padding: 4px 12px;
  border-radius: var(--pn-raggio-pill);
}
.pn-card__body { display: flex; flex-direction: column; gap: 8px; }
.pn-card__old { color: var(--pn-neutro-40); font-size: 11px; }
.pn-card__old--placeholder { visibility: hidden; }
.pn-card__now { display: flex; align-items: flex-end; gap: 8px; }
.pn-card__new { color: var(--pn-success); font-size: 16px; line-height: 24px; }
.pn-card__disc { color: #d93025; font-size: 14px; line-height: 20px; }
.pn-card__title {
  color: #212529;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 40px;
}
.pn-card__store {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
}
.pn-card__shop { color: var(--pn-neutro-40); font-size: 11px; letter-spacing: 0.1px; }
.pn-card__rating { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; }
.pn-card__score { color: var(--pn-arancione); }
.pn-card__rating .bi-star-fill { color: var(--pn-arancione); font-size: 10px; }
.pn-card__reviews { color: var(--pn-blu); }

/* ============================================================
   SEZIONE NEWSLETTER
   ============================================================ */
.pn-newsletter {
  position: relative;
  overflow: hidden;
  background: var(--pn-blu);     /* blu pieno, niente striscia chiara */
  padding: 80px 16px 120px;
}
.pn-newsletter__inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
}
.pn-newsletter__envelope { flex: 0 0 auto; }
.pn-newsletter__envelope img {
  width: 300px; max-width: 34vw; height: auto; display: block;
  filter: drop-shadow(0 24px 40px rgba(0, 0, 0, .25));
}
.pn-newsletter__content { flex: 0 1 535px; display: flex; flex-direction: column; gap: 24px; }
.pn-newsletter__content .pn-tag { align-self: flex-start; }
.pn-newsletter__title {
  color: #fff;
  font-family: var(--pn-font-testo);
  font-weight: 600;
  font-size: clamp(20px, 2.3vw, 24px);
  line-height: 1.25;
  letter-spacing: -0.15px;
  margin: 0;
}
.pn-nl-form {
  display: flex; align-items: center; gap: 8px;
  background: var(--pn-blu-superficie);
  border: 1px solid var(--pn-divisore);
  border-radius: var(--pn-raggio-lg);
  padding: 8px 8px 8px 16px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, .16);
}
.pn-nl-input {
  flex: 1 1 auto; border: none; background: transparent; outline: none;
  font-size: 18px; color: var(--pn-neutro-10); min-width: 0; padding: 6px 0;
}
.pn-nl-input::placeholder { color: var(--pn-neutro-10); }
.pn-nl-clear { border: none; background: transparent; color: var(--pn-neutro-40); cursor: pointer; padding: 4px 6px; font-size: 14px; }
.pn-nl-clear:hover { color: var(--pn-neutro-10); }
.pn-nl-form .pn-btn-primary { padding: 12px 16px; }

/* decorazioni fluttuanti newsletter */
.pn-newsletter__decor { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.pn-nl-float { position: absolute; height: auto; filter: drop-shadow(0 16px 28px rgba(0, 0, 0, .25)); will-change: transform; }
/* posizioni pensate per NON coprire il blocco contenuto (tag + testo + barra email, al centro-destra) */
.pn-nl-float--dyson      { left: -9%;  top: 40%;  width: 20%;   transform: translateY(var(--py,0px)) rotate(-23deg); }
.pn-nl-float--macbook    { left: 47%;  top: 68%;  width: 12%;   transform: translateY(var(--py,0px)) rotate(-15deg); }
.pn-nl-float--controller { left: 22%;  top: -14%; width: 14%;   transform: translateY(var(--py,0px)) rotate(42deg); }
.pn-nl-float--sneakers   { left: 86%;  top: -8%;  width: 13%;   transform: translateY(var(--py,0px)) rotate(11deg); }
.pn-nl-float--sunglasses { left: 84%;  top: 54%;  width: 13%;   transform: translateY(var(--py,0px)) rotate(16deg); }
.pn-nl-float--flipflops  { left: 20%;  top: 66%;  width: 14%;   transform: translateY(var(--py,0px)) rotate(25deg); }
.pn-nl-plane { position: absolute; width: 7%; height: auto; filter: drop-shadow(0 10px 18px rgba(0, 0, 0, .2)); will-change: transform; }
.pn-nl-plane--1 { left: 66%; top: -8%; transform: translateY(var(--py,0px)) rotate(63deg); }
.pn-nl-plane--2 { left: 86%; top: 70%; transform: translateY(var(--py,0px)) rotate(-10deg); }
.pn-nl-plane--3 { left: 2%;  top: 4%;  transform: translateY(var(--py,0px)) rotate(2deg); }
.pn-nl-float--nlmacbook { display: none; }   /* solo mobile */

@media (max-width: 991.98px) {
  .pn-newsletter { padding: 56px 16px 72px; }
  .pn-newsletter__decor { display: none; }
  .pn-newsletter__inner { flex-direction: column; text-align: center; }
  .pn-newsletter__content { flex-basis: auto; align-items: center; max-width: 535px; }
  .pn-newsletter__content .pn-tag { align-self: center; }
  .pn-newsletter__envelope img { width: 220px; max-width: 60%; }
}
@media (max-width: 575.98px) {
  .pn-nl-form { flex-wrap: wrap; }
  .pn-nl-input { flex-basis: 100%; }
  .pn-nl-form .pn-btn-primary { flex: 1 1 100%; justify-content: center; }
}

/* ============================================================
   SEZIONE GUIDE ALL'ACQUISTO
   ============================================================ */
.pn-guide { background: var(--pn-blu-superficie); padding: clamp(48px, 6vw, 80px) 0; }
.pn-guide__head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 24px; }
.pn-guide__title {
  font-family: var(--pn-font-testo);
  font-weight: 600; font-size: 20px;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--pn-neutro-10); margin: 0;
}
.pn-guide__link {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--pn-blu-scuro); font-weight: 600; font-size: 16px;
  text-decoration: none; text-transform: uppercase; letter-spacing: 0.3px;
  white-space: nowrap;
}
.pn-guide__link:hover { color: var(--pn-blu); }
.pn-guide__grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 576px) { .pn-guide__grid { grid-template-columns: repeat(2, 1fr); gap: 16px; } }
@media (min-width: 992px) { .pn-guide__grid { grid-template-columns: repeat(4, 1fr); gap: 20px; } }

.pn-article {
  display: flex; flex-direction: column; gap: 16px;
  background: #fff; border: 1px solid #e5e7eb; border-radius: 16px;
  padding: 16px; text-decoration: none;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);
}
.pn-article__img { display: block; height: 190px; border-radius: 8px; overflow: hidden; background: #f3f4f6; }
.pn-article__img img { width: 100%; height: 100%; object-fit: cover; }
.pn-article__meta {
  display: flex;
  flex-direction: column-reverse;   /* data sopra, tag sotto (HTML resta invariato) */
  align-items: flex-start;
  gap: 6px;
}
.pn-article__tag {
  background: rgba(255, 87, 34, .1); color: #ff5722;
  font-size: 12px; font-weight: 600;
  padding: 2px 10px; border-radius: 9999px;
  white-space: nowrap;             /* "Guide all'acquisto" su una riga */
  align-self: flex-start;          /* pillola, non barra a tutta larghezza */
}
.pn-article__date {
  color: #9ca3af;
  font-size: 11px;
  white-space: nowrap;             /* "October 24, 2023" su una riga */
}
.pn-article__title { color: #111827; font-size: 16px; font-weight: 600; line-height: 24px; margin: 0; }
.pn-article__excerpt { color: var(--pn-neutro-10); font-size: 14px; line-height: 20px; margin: 0; }
.pn-article__excerpt a { color: inherit; text-decoration: underline; }

/* Bottone primario grande (es. "Vedi offerte") */
.pn-btn-primary--lg { padding: 16px 20px; border-radius: var(--pn-raggio-lg); font-size: 18px; }
.pn-btn-primary--lg i { font-size: 20px; }

/* ============================================================
   SEZIONE CHI SIAMO (intro + features)
   ============================================================ */
.pn-about { position: relative; background: var(--pn-sfondo-pagina); padding: clamp(64px, 9vw, 140px) 0; /* niente overflow:hidden — romperebbe il position:sticky del nav laterale */ }
.pn-about::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: url("../assets/img/sections/chisiamo-bg.png") center / cover no-repeat;
  opacity: 0.10;
}
.pn-about__inner { position: relative; z-index: 1; display: flex; flex-direction: column; gap: clamp(48px, 7vw, 96px); }
.pn-about__top { display: flex; align-items: flex-end; gap: 24px; }
.pn-about__banner { flex: 1 1 auto; min-width: 0; }
.pn-about__banner img { width: 100%; aspect-ratio: 760 / 296; object-fit: cover; border-radius: var(--pn-raggio-xl); display: block; }
.pn-about__logo { flex: 0 0 auto; }
.pn-about__logo img { width: 280px; max-width: 28vw; height: auto; display: block; }

.pn-about__content { display: grid; grid-template-columns: 1fr; gap: 48px; }
@media (min-width: 992px) { .pn-about__content { grid-template-columns: 300px minmax(0, 648px); justify-content: space-between; gap: 48px; } }

.pn-about__nav { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 200px; align-self: start; }
.pn-about__navitem { display: flex; align-items: center; gap: 10px; text-decoration: none; font-size: 14px; font-weight: 500; line-height: 20px; color: var(--pn-neutro-40); }
.pn-about__navitem img { width: 32px; height: 32px; object-fit: contain; flex: 0 0 auto; }
.pn-about__navitem.is-active { color: var(--pn-neutro-10); font-weight: 600; }
.pn-about__navitem:hover { color: var(--pn-neutro-10); }

.pn-about__blocks { display: flex; flex-direction: column; gap: clamp(40px, 5vw, 64px); }
.pn-about__block { display: flex; flex-direction: column; gap: 24px; scroll-margin-top: 110px; }
.pn-about__icon { width: clamp(88px, 10vw, 120px); height: clamp(88px, 10vw, 120px); object-fit: contain; }
.pn-about__h {
  font-family: var(--pn-font-titoli); font-weight: 600;
  font-size: clamp(28px, 4vw, 42px); line-height: 1.19; letter-spacing: -0.4px;
  color: var(--pn-neutro-10); margin: 0;
}
.pn-about__p {
  font-family: var(--pn-font-titoli); font-weight: 400;
  font-size: clamp(18px, 2.4vw, 28px); line-height: 1.22; letter-spacing: -0.2px;
  color: var(--pn-neutro-10); margin: 0;
}
@media (max-width: 991.98px) {
  .pn-about__nav { display: none; }
  .pn-about__top { flex-direction: column; align-items: flex-start; }
  .pn-about__logo img { max-width: 200px; width: 200px; }
}

/* ============================================================
   SEZIONE CHI SIAMO 2 (loghi partner)
   ============================================================ */
.pn-partners { background: var(--pn-blu-superficie); padding: clamp(48px, 6vw, 80px) 0; }
.pn-partners__inner { display: flex; flex-direction: column; gap: 24px; }
.pn-partners__top { display: flex; align-items: center; gap: 24px; }
.pn-partners__img { flex: 0 0 423px; max-width: 40%; }
.pn-partners__img img { width: 100%; aspect-ratio: 423 / 296; object-fit: cover; border-radius: var(--pn-raggio-xl); display: block; }
.pn-partners__txt { flex: 1 1 auto; min-width: 0; }
.pn-partners__txt h2 {
  font-family: var(--pn-font-titoli); font-weight: 600;
  font-size: clamp(26px, 3.6vw, 42px); line-height: 1.19; letter-spacing: -0.4px;
  color: var(--pn-neutro-10); margin: 0 0 24px;
}
.pn-partners__txt p {
  font-family: var(--pn-font-titoli); font-weight: 400;
  font-size: clamp(16px, 2.2vw, 28px); line-height: 1.22; letter-spacing: -0.2px;
  color: var(--pn-neutro-10); margin: 0;
}
.pn-partners__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (min-width: 576px) { .pn-partners__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .pn-partners__grid { grid-template-columns: repeat(5, 1fr); } }
.pn-partner {
  background: #fff; border: 1px solid var(--pn-divisore); border-radius: var(--pn-raggio-lg);
  height: 112px; display: flex; align-items: center; justify-content: center; padding: 16px;
}
.pn-partner img { max-width: 100%; max-height: 80px; object-fit: contain; }
.pn-partners__cta { display: flex; justify-content: flex-end; }
@media (max-width: 767.98px) {
  .pn-partners__top { flex-direction: column; align-items: flex-start; }
  .pn-partners__img { flex-basis: auto; max-width: 100%; width: 100%; }
  .pn-partners__cta { justify-content: stretch; }
  .pn-partners__cta .pn-btn-primary { flex: 1 1 auto; justify-content: center; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.pn-footer { background: #1050ad; color: #fff; padding: 80px 0 32px; }
.pn-footer__inner { display: flex; flex-direction: column; gap: 32px; }
.pn-footer__top { display: flex; gap: 32px; align-items: stretch; }
.pn-footer__brand { display: flex; flex-direction: column; gap: 24px; flex: 0 0 auto; }
.pn-footer__logo { width: 170px; height: auto; display: block; }
.pn-footer__copy { color: #fff; font-size: 16px; max-width: 319px; margin: 0; }
.pn-footer__vr { width: 1px; background: var(--pn-blu-50); flex: 0 0 auto; }
.pn-footer__col { display: flex; flex-direction: column; gap: 4px; width: 90px; flex: 0 0 auto; }
.pn-footer__col h3 { font-size: 20px; font-weight: 600; margin: 0 0 4px; color: #fff; }
.pn-footer__col a { color: #fff; font-size: 16px; text-decoration: none; }
.pn-footer__col a:hover { text-decoration: underline; }
.pn-footer__legal { flex: 1 1 auto; color: #bbbfbc; font-size: 14px; line-height: 1.5; margin: 0; }
.pn-footer__social { flex: 0 0 208px; }
.pn-footer__social h3 { font-size: 20px; font-weight: 600; margin: 0 0 8px; color: #fff; }
.pn-footer__icons { display: flex; gap: 16px; }
.pn-footer__icons a { color: #fff; font-size: 28px; line-height: 1; }
.pn-footer__icons a:hover { opacity: .8; }
.pn-footer__hr { height: 1px; background: var(--pn-blu-50); width: 100%; }
.pn-footer__bottom { display: flex; justify-content: flex-end; }
.pn-footer__bottom p { color: #fff; font-size: 16px; margin: 0; }
@media (max-width: 991.98px) {
  .pn-footer__top { flex-wrap: wrap; gap: 24px 32px; }
  .pn-footer__vr { display: none; }
  .pn-footer__legal { flex-basis: 100%; order: 6; }
  .pn-footer__social { flex-basis: 100%; }
}

/* ============================================================
   ANIMAZIONE DI ENTRATA — fade-in-up delle sezioni
   (lo stato nascosto è attivo solo con .js-reveal su <html>)
   ============================================================ */
.js-reveal .pn-carousel,
.js-reveal .pn-why,
.js-reveal .pn-section,
.js-reveal .pn-newsletter,
.js-reveal .pn-guide,
.js-reveal .pn-partners,
.js-reveal .pn-about,
.js-reveal .pn-footer {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s ease-out, transform .6s ease-out;
}
.js-reveal .pn-in {
  opacity: 1 !important;
  transform: none !important;
}

/* ============================================================
   TABLET + MOBILE (≤ 1199px) — header "a pillola" con hamburger
   (sotto navbar-expand-xl il menu collassa: stesso layout stile mobile)
   ============================================================ */
@media (max-width: 1199.98px) {
  /* respiro attorno alla pillola: 12px top, 16px sui lati (su mobile sarà sovrascritto) */
  .pn-header { padding: 12px 16px 0; }
  .pn-header .navbar { min-height: 0; padding: 0; }
  .pn-header .container-xxl {
    background: var(--pn-blu);
    border-radius: 18px;
    padding: 12px 14px;
    min-height: 64px;
    flex-wrap: wrap;
    row-gap: 0;
    box-shadow: 0 8px 24px rgba(5, 23, 71, .20);   /* pillola flottante su sfondo trasparente */
  }
  .pn-header .navbar-brand { flex: 0 0 auto; min-width: 0; }
  /* Picture/img sopra le icone: l'altezza si adatta al viewport così non manda a capo */
  .pn-header .navbar-brand picture { display: block; }
  /* Icone destra: mai a capo, dimensione fissa — è il logo che deve cedere spazio */
  .pn-header__mobicons { flex: 0 0 auto; }
  .pn-header .navbar-collapse {
    flex-basis: 100%; width: 100%;
    background: var(--pn-blu-scuro);
    border-radius: 16px;
    margin-top: 10px;
    padding: 12px 16px;
    /* header in overlay: se il menu (con sottocategorie) è alto, scrolla dentro sé stesso */
    max-height: calc(100vh - 96px);
    overflow-y: auto;
  }
  .pn-header .navbar-nav { width: 100%; margin-left: 0 !important; gap: 2px; }
  /* Logo: 34px su viewport ≥568, scala in basso fino a 20px sui telefoni più stretti.
     Aspect ratio orizzontale ~6.3:1 → 20px alto = ~126px largo, ci sta in pillola 320px. */
  .pn-logo__img--full {
    display: block;
    width: auto;
    height: clamp(20px, 6vw, 34px);
    transform: translateY(-1px);
  }
  /* Mini (P+stella) usato solo nello stato compatto desktop ≥1200: qui sempre nascosto */
  .pn-logo__img--mini { display: none !important; }
  /* `.pn-header__icon` is also a Bootstrap `.navbar-toggler`, which brings two
     conflicts at equal specificity: the core navbar stylesheet
     absolutely-positions every `.navbar-toggler` (dropping the hamburger on top
     of the search button), and Bootstrap's own `.navbar-toggler` adds a border
     and a squared border-radius (so it doesn't match the round search pill).
     Scope the layout + visual styles under `.pn-header` so they win. */
  .pn-header .pn-header__icon {
    position: static;
    inset: auto;
    z-index: auto;
    width: 42px; height: 42px; flex: 0 0 auto;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, .14);
    border: none; color: #fff; font-size: 18px; padding: 0;
  }
  .pn-header .pn-header__icon:focus { box-shadow: none; }

  /* --- Ricerca espandibile nell'header mobile/tablet ---
     Chiusa = bottone tondo con lente. Toccando si apre il campo (logo → "P"). */
  .pn-header__msearch {
    display: flex; align-items: center;
    background: rgba(255, 255, 255, .14);
    border-radius: 100px; height: 42px;
    flex: 0 0 42px; width: 42px; min-width: 42px;
    overflow: hidden;
    transition: width .3s ease, flex-basis .3s ease;
  }
  .pn-header__msearch-input {
    flex: 1 1 auto; min-width: 0; width: 100%;
    background: transparent; border: none; outline: none;
    color: #fff; font-size: 16px; padding: 0 4px 0 16px;
    display: none;
  }
  .pn-header__msearch-input::placeholder { color: rgba(255, 255, 255, .7); }
  .pn-header__msearch-btn {
    flex: 0 0 42px; width: 42px; height: 42px;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent; border: none; color: #fff; font-size: 18px; padding: 0; cursor: pointer;
  }
  /* stato aperto: il campo riempie la riga (flex-basis 0 → resta su una sola riga,
     non manda mai a capo), il logo diventa la "P" compatta */
  /* margin-left:0 annulla l'ms-auto di Bootstrap che altrimenti "mangia" lo spazio
     libero impedendo al campo di espandersi */
  .pn-header.is-msearch .pn-header__mobicons { flex: 1 1 0%; min-width: 0; margin-left: 0 !important; }
  .pn-header.is-msearch .pn-header__msearch { flex: 1 1 auto; width: auto; min-width: 0; }
  .pn-header.is-msearch .pn-header__msearch-input { display: block; }
  .pn-header.is-msearch .pn-logo__img--full { display: none; }
  .pn-header.is-msearch .pn-logo__img--mini { display: block !important; height: 30px; width: auto; }
}

/* ============================================================
   MOBILE (≤ 767px) — layout come da Figma "UI Mobile V3"
   ============================================================ */
@media (max-width: 767.98px) {

  /* --- Header a pillola flottante: SEMPRE visibile e in overlay (fixed), così lo
     sfondo della hero (blu) scorre SOTTO la pillola e si vede attorno ad essa
     invece dello sfondo bianco della pagina. Banda trasparente = effetto floating. --- */
  .pn-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1030;
    background: transparent;
    padding: 12px 16px 6px;
  }
  /* (il resto dello stile pillola/icone è nel media query <=1199 più sopra,
     così copre anche tablet portrait/landscape) */

  /* --- Hero: parte da cima pagina (dietro la pillola fixed), titolo più in basso --- */
  .pn-hero { padding: 184px 0 168px; }   /* il top lascia spazio alla pillola flottante */
  .pn-hero__title { font-size: clamp(34px, 10.5vw, 46px); margin-bottom: 18px; }
  .pn-hero__line2 { display: block; }   /* "Senza trucchi." sempre a capo su mobile */
  .pn-hero__subtitle { margin-bottom: 46px; }
  .pn-hero__suggest { margin-top: 26px; }

  /* --- Search bar mobile: niente "Categorie", bottone solo icona --- */
  .pn-search { padding: 8px; gap: 6px; flex-wrap: nowrap; }
  .pn-search__cat, .pn-search__vdivider { display: none; }
  .pn-search__input { order: 0; flex-basis: auto; border-top: none; margin-top: 0; padding: 8px 10px; }
  .pn-search__submit { order: 0; flex: 0 0 auto; padding: 12px 14px; border-radius: var(--pn-raggio-md); }
  .pn-search__txt { display: none; }       /* nasconde la parola "Cerca" */
  .pn-search__clear { order: 0; }

  /* (icone 3D ora gestite nel media query <=991.98 per coprire anche il tablet portrait) */

  /* --- Carosello: banner quasi quadrato (più alto) --- */
  .pn-banner-carousel { aspect-ratio: 408 / 470; }

  /* --- Sezioni prodotto: scorrimento orizzontale (swipe) --- */
  .pn-products {
    display: flex;
    grid-template-columns: none;
    gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
    scrollbar-width: none;          /* Firefox */
  }
  .pn-products::-webkit-scrollbar { display: none; }   /* Chrome/Safari */
  .pn-products > .pn-card {
    flex: 0 0 47%;
    scroll-snap-align: start;
  }

  /* --- Guide all'acquisto: 2 colonne --- */
  .pn-guide__grid { grid-template-columns: repeat(2, 1fr); }
  .pn-guide__head { flex-wrap: wrap; }

  /* --- Sezioni: un filo meno padding verticale --- */
  .pn-section { padding: 36px 0; }

  /* --- Newsletter mobile: icone visibili + testo a sinistra (come Figma) --- */
  .pn-newsletter { padding: 48px 16px 84px; }   /* blocco ~20% più basso */
  .pn-newsletter__inner { text-align: left; gap: 12px; }
  .pn-newsletter__envelope { text-align: center; width: 100%; }
  .pn-newsletter__envelope img { width: 190px; max-width: 54%; }
  .pn-newsletter__content { align-items: flex-start; text-align: left; max-width: none; width: 100%; }
  .pn-newsletter__content .pn-tag { align-self: flex-start; }
  .pn-newsletter__title { text-align: left; }
  .pn-nl-form { width: 100%; flex-wrap: nowrap; }
  .pn-nl-form .pn-nl-input { flex: 1 1 auto; border-top: none; margin-top: 0; padding: 6px 4px; }
  .pn-nl-form .pn-btn-primary { flex: 0 0 auto; }
  .pn-newsletter__decor { display: block; }
  .pn-nl-float--dyson,
  .pn-nl-float--controller,
  .pn-nl-float--flipflops,
  .pn-nl-plane--3 { display: none; }
  .pn-nl-float--sneakers   { left: -2%; top: -7%; width: 44%; transform: translateY(var(--py,0px)) rotate(-25deg); }
  .pn-nl-plane--1          { left: 47%; top: -4%; width: 17%; transform: translateY(var(--py,0px)) rotate(-8deg); }
  .pn-nl-plane--2          { left: 74%; top: 16%; width: 17%; transform: translateY(var(--py,0px)) rotate(17deg); }
  .pn-nl-float--sunglasses { left: 2%;  top: auto; bottom: 1%; width: 37%; transform: translateY(var(--py,0px)) rotate(16deg); }
  .pn-nl-float--nlmacbook  { display: block; left: 50%; top: auto; bottom: 1%; width: 43%; transform: translateY(var(--py,0px)) rotate(13deg); }
}
