/* ------------------------------------
   Web vetrina
   Layout, sections, cards, buttons, forms, footer
   Richiede css/webstyle.css prima di questo file.
------------------------------------- */

/* Typography */
.h1{font-size:clamp(32px,5vw,56px);line-height:1.1;margin:0;font-weight:800;letter-spacing:-.02em}
.h2{font-size:clamp(26px,3.5vw,36px);line-height:1.2;margin:0;font-weight:800;letter-spacing:-.01em}
.h3{font-size:22px;line-height:1.25;margin:0;font-weight:700}
.lead{font-size:18px;color:var(--text-muted);max-width:60ch}
.body{font-size:16px}
.body-muted{color:var(--text-muted)}
.micro{font-size:12px;color:var(--text-muted)}
.center{text-align:center}
.right{text-align:right}
.gradient-text{background:linear-gradient(90deg,#0f172a,var(--brand));-webkit-background-clip:text;background-clip:text;color:transparent}

/* Layout primitives */
.section{padding:72px 0}
.section--tint{position:relative}
.section--tint::before{
  content:"";
  position:absolute;
  inset:-10% -5% auto -5%;
  height:70%;
  background:
    radial-gradient(600px 260px at 20% 0%, rgba(167,139,250,.18), transparent 60%),
    radial-gradient(600px 260px at 80% 20%, rgba(34,197,94,.10), transparent 60%);
  filter:saturate(1.1);
  pointer-events:none;
  z-index:-1;
}
.faint::before{opacity:.5}
.border-y{border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stack>*+*{margin-top:12px}
.stack-8>*+*{margin-top:8px}
.stack-24>*+*{margin-top:24px}
.stack-40>*+*{margin-top:40px}
.stack-64>*+*{margin-top:64px}
.row{display:flex;align-items:center}
.wrap{flex-wrap:wrap}
.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-40{gap:40px}
.mt-16{margin-top:16px}
.meta{color:var(--text-muted);font-size:14px}

/* Grid */
.grid{display:grid}
.grid--2{grid-template-columns:1fr}
.grid--3{grid-template-columns:1fr}
.grid--4{grid-template-columns:1fr 1fr}
.grid--6{grid-template-columns:repeat(2,1fr)}
@media (min-width:768px){
  .grid--2{grid-template-columns:repeat(2,1fr)}
  .grid--3{grid-template-columns:repeat(3,1fr)}
  .grid--4{grid-template-columns:repeat(4,1fr)}
  .grid--6{grid-template-columns:repeat(6,1fr)}
}
.feature-row .order-1{order:-1}
@media (min-width:768px){
  .feature-row .order-1{order:initial}
  .feature-row .order-2{order:initial}
}

/* Buttons */
.btn{
  --bg:transparent;
  --fg:var(--text);
  --bd:#e2e8f0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 18px;
  border:1px solid var(--bd);
  border-radius:14px;
  background:var(--bg);
  color:var(--fg);
  text-decoration:none;
  font-weight:700;
  letter-spacing:.2px;
  transition:transform .12s ease, background .2s ease, box-shadow .2s ease, filter .2s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn--brand{
  --bg:linear-gradient(135deg,var(--brand),var(--brand-3));
  --fg:#ffffff;
  --bd:transparent;
}
.btn--soft{
  --bg:#ffffff;
  --fg:var(--text);
  --bd:var(--border);
  background:#ffffff;
}
.btn--outline{
  --bg:transparent;
  --fg:var(--text);
  --bd:var(--text);
}
.btn.full{width:100%}

/* Pills & chips */
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:12px;font-weight:700}
.pill--brand{background:linear-gradient(135deg,#fff,#fafaff);border-color:#c7d2fe}
.pill--soft{padding:10px 14px;border-radius:14px;background:#fff;border:1px solid var(--border);color:var(--text)}
.chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:12px;background:var(--brand-soft);color:var(--brand);font-weight:700}
.chip--brand{background:var(--brand-soft);color:var(--brand)}
.chip--success{background:#dcfce7;color:#065f46}

.eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.18em;color:var(--text-muted)}

/* Lists */
.list{margin:0;padding-left:1.2rem;color:var(--text-muted)}
.list li+li{margin-top:8px}

/* Section-specific helpers */
.hero{overflow:hidden}
.logos{align-items:stretch}
.features-icons{align-items:stretch}

/* Cards / logos */
.card{border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);background:#fff}
.card__icon{display:inline-flex;min-width:48px;height:48px;align-items:center;justify-content:center;border-radius:12px;background:#f3f4f6;margin-bottom:12px;font-size:22px}
.logo{display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:12px;background:#fff;padding:12px;color:var(--text-muted)}

/* Shots / screenshots */
.shot-frame{position:relative;margin:0}
.shot-inner{
  position:relative;
  border:1px solid var(--border);
  border-radius:24px;
  padding:0;
  box-shadow:var(--shadow);
  background:transparent;
  overflow:hidden;
  aspect-ratio:var(--media-ratio, 4 / 3);
}
.shot-inner::before{content:none}
.shot-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  object-position:center center;
  border-radius:inherit;
  background:transparent;
  z-index:1;
}

/* Video in card grande (hero) */
.shot-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  object-position:center center;
  border-radius:inherit;
  background:transparent;
  z-index:2;
}
.no-video .shot-video{display:none}

.caption{
  position:absolute;
  left:12px;
  bottom:12px;
  font-size:12px;
  color:var(--text-muted);
  background:rgba(255,255,255,.78);
  padding:4px 8px;
  border-radius:8px;
  border:1px solid var(--border);
  backdrop-filter:blur(6px);
}
.glow{filter:drop-shadow(0 30px 35px rgba(79,70,229,.15))}

/* Hero media */
.hero-grid{align-items:start}
.hero-media{display:flex;flex-direction:column;gap:12px}
.hero-shot .caption{background:rgba(255,255,255,.80)}

@media (min-width:768px){
  .hero-grid > .badges{grid-column:1 / -1}
}

/* Badge cards */
.badges{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  margin-top:4px;
  align-items:stretch;
}
.badge-card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow);
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:16px;
  min-height:100%;
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease, filter .2s ease;
}
.badge-card--tint{
  background:#fff;
  border-color:var(--border);
}
.badge-card:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 36px -28px rgba(15,23,42,.42);
  border-color:rgba(79,70,229,.22);
}
.badge-card__media{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.22);
  background:transparent;
  aspect-ratio:var(--media-ratio, 3 / 2);
}
.badge-card__media::before{content:none}
.badge-card__media img,
.badge-card__media video{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:contain;object-position:center center;border-radius:inherit;background:transparent}
.badge-card__meta{
  line-height:1.25;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:8px;
}
.badge-card__title{
  font-weight:800;
  font-size:24px;
  letter-spacing:-.02em;
}
.badge-card__sub{
  font-size:15px;
  color:var(--text-muted);
  margin:0;
}

@media (min-width:768px){
  .badges{
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:22px;
  }
  .badge-card{
    padding:22px;
    min-height:260px;
  }
  .badge-card__title{font-size:22px}
}

@media (min-width:1200px){
  .badges{gap:24px}
  .badge-card{padding:24px; min-height:276px}
  .badge-card__title{font-size:24px}
}

/* Ribbon */
.ribbon{position:relative;border:1px solid var(--border);border-radius:24px;padding:24px;overflow:hidden;background:#fff}
.ribbon__bg{position:absolute;inset:-20%;background:
  radial-gradient(60% 60% at 80% 0%, rgba(34,197,94,.15), transparent 60%),
  radial-gradient(60% 60% at 20% 0%, rgba(79,70,229,.15), transparent 60%)}
.ribbon__content{position:relative}

/* Pricing */
.price{border:1px solid var(--border);border-radius:24px;padding:24px;background:#fff;box-shadow:var(--shadow);position:relative}
.price--highlight{border-color:#c7d2fe;background:linear-gradient(180deg,#fff 0%,#eef2ff 100%)}
.price__value{font-size:28px;font-weight:800;margin-top:8px}
.muted{color:var(--text-muted)}

/* Quotes */
.quote{border:1px solid var(--border);border-radius:16px;background:#fff;padding:24px;box-shadow:var(--shadow)}
.quote p{margin:0}
.quote .micro{display:block;margin-top:12px}

/* FAQ */
.faq{border:1px solid var(--border);border-radius:16px;background:#fff;padding:16px 18px}
.faq summary{cursor:pointer;font-weight:700}
.faq p{margin:8px 0 0;color:var(--text-muted)}

/* Forms - light */
.form .input{
  width:100%;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
}
.input::placeholder{color:#94a3b8}

/* Dark contact section */
.section--dark{
  background:linear-gradient(180deg,#0b0f1a,#0b1020);
  color:#eef2ff;
  border-top:1px solid #0f172a;
  border-bottom:1px solid #0f172a;
}
.contact{align-items:start}
.contact__info .body-muted{color:#c7c9d1}
.contact__meta a{color:#e5e7eb;text-decoration:none}
.contact__meta a:hover{text-decoration:underline}

/* Grid span helper */
.col-span-2{grid-column:span 2}
@media (max-width:767px){
  .col-span-2{grid-column:auto}
}

.form--dark{
  border-radius:24px;
  padding:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(148,163,184,.18);
  box-shadow:0 24px 50px -30px rgba(0,0,0,.70);
  backdrop-filter:blur(10px);
}
.form--dark .field{display:flex;flex-direction:column;gap:6px}
.form--dark .label{font-size:12px;letter-spacing:.02em;color:#d1d5db}
.form--dark .input{
  background:#0f172a;
  border:1px solid #1f2937;
  color:#e5e7eb;
  border-radius:14px;
  padding:12px 14px;
  transition:border-color .15s ease, box-shadow .15s ease, transform .12s ease;
}
.form--dark textarea.input{resize:vertical}
.form--dark select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none}
.form--dark .input::placeholder{color:#9aa3b2}
.form--dark .input:focus{
  outline:none;
  border-color:#6366f1;
  box-shadow:0 0 0 3px rgba(99,102,241,.22);
}
.form__head{margin-bottom:14px}
.form__head .body-muted{color:#c7c9d1}
.form__footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.form__note{margin:0;color:#c7c9d1;max-width:70ch}
.form--dark .btn--brand{box-shadow:0 10px 20px -10px rgba(99,102,241,.55)}

/* Sticky CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:16px;z-index:60}
.sticky-cta__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  border:1px solid var(--border);
  background:#ffffffeb;
  backdrop-filter:blur(8px);
  border-radius:16px;
  padding:12px 16px;
  box-shadow:var(--shadow);
}

/* Footer */
.footer{border-top:1px solid var(--border);margin-top:96px}
.footer__inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:16px;flex-wrap:wrap}
.link{color:var(--text-muted);text-decoration:none}
.link:hover{color:var(--text)}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease, transform .5s ease}
.reveal.is-visible{opacity:1;transform:none}

/* Anchor offset */
#iscrizione{scroll-margin-top:96px}
