/* ============================================================
   Leo Lamp — "Insegna campana modernizzata"
   Palette: blu cobalto + crema + rosso + ambra (bagliore luce)
   ============================================================ */

:root{
  /* brand */
  --blue:        #15357C;   /* cobalto primario */
  --blue-deep:   #0E2456;   /* gradiente profondo */
  --blue-bright: #2E5BC0;   /* blu vivo */
  --cream:       #F6F1E7;   /* carta calda */
  --cream-2:     #EFE7D6;   /* crema piu profonda (alternanza) */
  --paper:       #FCFAF4;   /* superficie chiara card */
  --red:         #C42A2A;   /* accento rosso */
  --red-deep:    #A41F1F;
  --amber:       #E7B45A;   /* bagliore lampada */
  --amber-soft:  #F3DBA8;
  --ink:         #1C2642;   /* testo navy */
  --ink-soft:    #4A5475;   /* testo muto */
  --border:      #DDD4C0;   /* bordo caldo */

  --font-display: "Baloo 2", system-ui, sans-serif;
  --font-body:    "Mulish", system-ui, sans-serif;

  --maxw: 1140px;
  --radius: 18px;
  --radius-sm: 12px;
  --header-h: 64px;

  --shadow-sm: 0 2px 10px rgba(28,38,66,.08);
  --shadow-md: 0 14px 34px rgba(14,36,86,.14);
  --shadow-lg: 0 24px 60px rgba(14,36,86,.22);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; height:auto; display:block; }

h1,h2,h3{ font-family:var(--font-display); line-height:1.06; margin:0; font-weight:800; letter-spacing:-.01em; }

a{ color:var(--blue); text-decoration:none; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:22px; }
.narrow{ max-width:760px; }
.center{ text-align:center; }

.skip-link{
  position:absolute; left:12px; top:-60px; z-index:200;
  background:var(--blue); color:var(--cream); padding:10px 16px; border-radius:10px;
  transition:top .2s var(--ease);
}
.skip-link:focus{ top:12px; }

:focus-visible{ outline:3px solid var(--amber); outline-offset:3px; border-radius:6px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60;
  height:var(--header-h);
  background:rgba(246,241,231,.92);
  border-bottom:1px solid var(--border);
}
.header__inner{ height:var(--header-h); display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand{ display:flex; align-items:center; }
.brand__mark{ height:30px; width:auto; }

.nav-desktop{ display:none; }

.nav-desktop a{
  font-weight:700; color:var(--ink); font-size:15px; padding:8px 4px;
  position:relative;
}
.nav-desktop a:not(.nav-cta)::after{
  content:""; position:absolute; left:4px; right:4px; bottom:2px; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease);
}
.nav-desktop a:not(.nav-cta):hover::after{ transform:scaleX(1); }
.nav-cta{
  background:var(--blue); color:var(--cream)!important; padding:10px 18px!important;
  border-radius:999px; font-weight:700; transition:background .2s var(--ease), transform .2s var(--ease);
}
.nav-cta:hover{ background:var(--blue-bright); transform:translateY(-1px); }

/* hamburger */
.hamburger{
  display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
  width:46px; height:46px; padding:11px; border:none; background:transparent; cursor:pointer;
}
.hamburger span{ height:3px; width:100%; background:var(--blue); border-radius:3px; transition:transform .3s var(--ease), opacity .2s var(--ease); }
.hamburger[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ============================================================
   MOBILE NAV (overlay fixed inset:0 — niente translateY math)
   ============================================================ */
.mobile-nav{
  position:fixed; inset:0; z-index:55;
  background:linear-gradient(165deg,var(--blue) 0%,var(--blue-deep) 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:opacity .28s var(--ease), transform .28s var(--ease), visibility .28s;
}
.mobile-nav.is-open{ opacity:1; visibility:visible; transform:translateY(0); }
.mobile-nav nav{ display:flex; flex-direction:column; align-items:center; gap:4px; }
.mobile-nav a{
  font-family:var(--font-display); font-weight:700; font-size:30px; color:var(--cream);
  padding:12px 18px; min-height:44px; display:flex; align-items:center;
}
.mobile-nav a:active{ color:var(--amber); }
.mobile-nav__foot{ margin-top:26px; color:var(--amber-soft); font-size:14px; font-weight:600; letter-spacing:.02em; }
body.menu-open{ overflow:hidden; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; isolation:isolate; overflow:hidden;
  background:radial-gradient(120% 90% at 50% -10%, var(--blue-bright) 0%, var(--blue) 42%, var(--blue-deep) 100%);
  color:var(--cream);
  padding:54px 0 0;
  text-align:center;
}
.hero__glow{
  position:absolute; z-index:-1; top:-14%; left:50%; transform:translateX(-50%);
  width:min(680px,108%); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(231,180,90,.55) 0%, rgba(231,180,90,.16) 38%, transparent 66%);
  filter:blur(6px);
}
.hero__rays{
  position:absolute; inset:0; z-index:-1; opacity:.5;
  background:
    repeating-conic-gradient(from 0deg at 50% 6%,
      rgba(255,255,255,.06) 0deg 3deg, transparent 3deg 11deg);
  -webkit-mask-image:radial-gradient(70% 60% at 50% 4%, #000 0%, transparent 70%);
          mask-image:radial-gradient(70% 60% at 50% 4%, #000 0%, transparent 70%);
}
.hero__inner{ position:relative; padding-bottom:36px; }

.hero__eyebrow{
  display:inline-block; margin:0 0 18px;
  font-weight:700; font-size:13.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--amber);
  background:rgba(255,255,255,.08); border:1px solid rgba(231,180,90,.4);
  padding:7px 16px; border-radius:999px;
}
.hero__title{ font-size:clamp(2.5rem,11vw,4.6rem); margin:0 0 18px; color:var(--cream); text-shadow:0 2px 18px rgba(8,20,52,.35); }
.glow-word{ color:var(--amber); }
.hero__sub{
  max-width:600px; margin:0 auto 28px; font-size:clamp(1rem,2.6vw,1.18rem);
  color:rgba(246,241,231,.92); line-height:1.6;
}

.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.btn{
  display:inline-flex; align-items:center; justify-content:center; min-height:52px;
  padding:14px 28px; border-radius:999px; font-family:var(--font-display); font-weight:700; font-size:17px;
  cursor:pointer; transition:transform .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease);
}
.btn--primary{ background:var(--amber); color:var(--ink); box-shadow:0 10px 26px rgba(231,180,90,.34); }
.btn--primary:hover{ transform:translateY(-2px); background:var(--amber-soft); box-shadow:0 16px 34px rgba(231,180,90,.42); }
.btn--ghost{ background:transparent; color:var(--cream); border:2px solid rgba(246,241,231,.55); }
.btn--ghost:hover{ transform:translateY(-2px); border-color:var(--cream); background:rgba(255,255,255,.08); }

.hero__stats{
  list-style:none; margin:38px auto 0; padding:0; max-width:560px;
  display:grid; grid-template-columns:repeat(2,1fr); gap:18px 12px;
}
.hero__stats li{ display:flex; flex-direction:column; gap:2px; }
.hero__stats strong{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:var(--amber); line-height:1; }
.hero__stats span{ font-size:13.5px; color:rgba(246,241,231,.82); }

.hero__shopfront{
  margin-top:8px; position:relative; z-index:1;
  border-top:4px solid var(--amber);
}
.hero__shopfront img{ width:100%; height:clamp(180px,42vw,320px); object-fit:cover; object-position:center 38%; }

/* ============================================================
   SECTIONS
   ============================================================ */
.section{ padding:64px 0; }
.section--cream{ background:var(--cream); }
.section--blue{ background:linear-gradient(160deg,var(--blue) 0%,var(--blue-deep) 100%); color:var(--cream); }
.section.section--negozi{ background:var(--cream-2); padding-bottom:0; }

.kicker{
  font-weight:800; font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red); margin:0 0 12px;
}
.kicker--light{ color:var(--amber); }

.section__title{ font-size:clamp(1.8rem,5.2vw,2.7rem); color:var(--blue); max-width:18ch; }
.section--cream .section__title{ color:var(--blue); }
.section__title--light{ color:var(--cream); max-width:20ch; }
.section__title em{ font-style:normal; color:var(--red); }
.section__title--light em{ color:var(--amber); }

.section__lead{ font-size:1.1rem; color:var(--ink-soft); max-width:60ch; margin:18px 0 0; }
.section__lead--light{ color:rgba(246,241,231,.9); }

.prose{ margin-top:20px; }
.prose p{ font-size:1.08rem; color:var(--ink); margin:0 0 16px; max-width:62ch; }

/* ============================================================
   CARDS (cosa facciamo)
   ============================================================ */
.cards{
  list-style:none; margin:38px 0 0; padding:0;
  display:grid; grid-template-columns:1fr; gap:18px;
}
.card{
  background:rgba(252,250,244,.06);
  border:1px solid rgba(231,180,90,.28);
  border-radius:var(--radius); padding:26px 24px;
  transition:transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.card:hover{ transform:translateY(-4px); border-color:var(--amber); background:rgba(252,250,244,.1); }
.card__icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:58px; height:58px; border-radius:16px; margin-bottom:16px;
  background:rgba(231,180,90,.16); color:var(--amber);
}
.card__icon svg{ width:32px; height:32px; }
.card h3{ font-size:1.32rem; color:var(--cream); margin-bottom:8px; }
.card p{ margin:0; color:rgba(246,241,231,.82); font-size:1rem; }

/* ============================================================
   PERCHÉ
   ============================================================ */
/* lista editoriale (volutamente diversa dalle card blu di "cosa facciamo") */
.why{
  margin-top:36px; display:grid; grid-template-columns:1fr; column-gap:46px; row-gap:0;
}
.why__item{
  padding:24px 2px; border-top:2px solid var(--amber); background:none;
}
.why__item h3{ font-size:1.26rem; color:var(--blue); margin-bottom:7px; }
.why__item p{ margin:0; color:var(--ink-soft); max-width:46ch; }

.audience{
  margin-top:34px; padding:24px 22px; background:var(--blue);
  border-radius:var(--radius); color:var(--cream);
}
.audience__intro{ margin:0 0 12px; font-family:var(--font-display); font-weight:700; color:var(--amber); }
.audience__list{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.audience__list li{ font-size:1.02rem; color:rgba(246,241,231,.92); }
.audience__list strong{ color:var(--cream); }

/* ============================================================
   NEGOZI
   ============================================================ */
.negozi__head{ display:flex; flex-direction:column; gap:14px; padding-bottom:48px; }
.negozi__seven{
  font-family:var(--font-display); font-weight:800; font-size:5.5rem; line-height:.8;
  color:var(--blue);
  -webkit-text-stroke:0;
  text-shadow:3px 4px 0 var(--amber);
}
.band{ margin:0; border-top:4px solid var(--blue); border-bottom:4px solid var(--amber); }
.band img{ width:100%; height:clamp(190px,38vw,330px); object-fit:cover; object-position:center 42%; }

/* ============================================================
   CONTATTI
   ============================================================ */
.contatti .section__lead--light{ margin-inline:auto; }
.wa-card{
  margin:34px auto 0; max-width:460px;
  background:rgba(252,250,244,.07); border:1px solid rgba(231,180,90,.4);
  border-radius:var(--radius); padding:30px 26px;
  display:flex; flex-direction:column; gap:8px; align-items:center;
}
.wa-card__label{ font-family:var(--font-display); font-weight:700; color:var(--amber); font-size:1.05rem; }
.wa-card__number{
  font-family:var(--font-display); font-weight:800; color:var(--cream);
  font-size:clamp(1.5rem,7vw,2.1rem); letter-spacing:.01em;
}
.wa-card__hint{ font-size:.95rem; color:rgba(246,241,231,.78); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--blue-deep); color:var(--cream); padding:44px 0 34px; }
.footer__inner{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px; }
/* logo e blu su trasparente: su footer scuro va su una pastiglia crema per contrasto */
.footer__mark{ height:34px; width:auto; background:var(--cream); padding:9px 16px; border-radius:12px; box-sizing:content-box; }
.footer__tag{ margin:6px 0 0; color:rgba(246,241,231,.84); font-size:.98rem; }
.footer__wa{ margin:2px 0 0; color:rgba(246,241,231,.7); font-size:.95rem; }
.footer__wa span{ color:var(--amber); font-weight:700; }
.footer__legal{ margin:10px 0 0; color:rgba(246,241,231,.55); font-size:.85rem; }
.footer-credit{ margin:4px 0 0; color:rgba(246,241,231,.6); font-size:.82rem; }
.footer-credit a{ color:var(--amber-soft); text-decoration:underline; text-underline-offset:2px; }
.footer-credit a:hover{ color:var(--cream); }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in-view{ opacity:1; transform:none; }
.hero .reveal{ transition-duration:.8s; }
.hero .reveal:nth-child(1){ transition-delay:.05s; }
.hero__title.reveal{ transition-delay:.12s; }
.hero__sub.reveal{ transition-delay:.2s; }
.hero__cta.reveal{ transition-delay:.28s; }
.hero__stats.reveal{ transition-delay:.36s; }
.hero__shopfront.reveal{ transition-delay:.18s; }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1!important; transform:none!important; transition:none!important; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:560px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .why{ grid-template-columns:repeat(2,1fr); }
  .audience__list{ grid-template-columns:repeat(3,1fr); }
}

@media (min-width:768px){
  :root{ --header-h:74px; }
  body{ font-size:18px; }
  .nav-desktop{ display:flex; align-items:center; gap:26px; }
  .hamburger{ display:none; }
  .mobile-nav{ display:none; }
  .brand__mark{ height:34px; }
  .section{ padding:96px 0; }
  .hero{ padding-top:74px; }
  .hero__inner{ padding-bottom:54px; }
  .negozi__head{ flex-direction:row; align-items:center; gap:34px; padding-bottom:64px; }
  .negozi__seven{ font-size:8rem; }
}

@media (min-width:1024px){
  .cards{ grid-template-columns:repeat(4,1fr); }
  .hero__stats{ max-width:640px; grid-template-columns:repeat(4,1fr); }
  .hero__title{ font-size:clamp(3.4rem,6vw,5rem); }
  .hero__shopfront img{ height:380px; }
}
