/* =========================================================
   Assi SRL - benci.it
   Stylesheet - design system v2 (glass / gradient / motion-ready)
   ========================================================= */

:root {
  --color-dark: #101b2d;
  --color-dark-2: #0c1524;
  --color-dark-3: #080f1a;
  --color-blue: #3498db;
  --color-blue-dark: #2980b9;
  --color-blue-light: #eaf4fc;
  --color-violet: #7c5cff;
  --color-cyan: #22d3ee;
  --color-text: #4a5560;
  --color-text-light: #7f8c9a;
  --color-bg: #ffffff;
  --color-bg-alt: #f4f7f9;
  --color-border: #e2e8ed;

  --gradient-brand: linear-gradient(135deg, #2f8fd1 0%, #7c5cff 100%);
  --gradient-brand-soft: linear-gradient(135deg, rgba(52, 152, 219, .14), rgba(124, 92, 255, .14));
  --gradient-ink: radial-gradient(120% 140% at 0% 0%, #18283f 0%, #0c1524 55%, #060b14 100%);

  --glass-bg: rgba(255, 255, 255, .06);
  --glass-bg-strong: rgba(255, 255, 255, .1);
  --glass-border: rgba(255, 255, 255, .14);

  --radius: 14px;
  --radius-sm: 9px;
  --radius-lg: 22px;
  --shadow-sm: 0 2px 10px rgba(8, 14, 26, .07);
  --shadow-md: 0 16px 44px rgba(8, 14, 26, .14);
  --shadow-glow: 0 14px 38px rgba(52, 152, 219, .32);
  --shadow-glow-violet: 0 14px 38px rgba(124, 92, 255, .28);

  --header-h: 70px;
  --transition: .3s cubic-bezier(.16, 1, .3, 1);
  --transition-fast: .18s cubic-bezier(.16, 1, .3, 1);
  --font-heading: 'Poppins', 'Inter', Arial, sans-serif;
  --font-body: 'Inter', 'Poppins', Arial, sans-serif;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  width: 100%;
  max-width: none;
  /* `hidden` (rather than `clip`) here would force overflow-y to compute as
     `auto` per spec, since it's left as `visible` - that breaks
     position:sticky for #site-header against the viewport. */
  overflow-x: clip;
}
body, h1, h2, h3, h4, p, ul, figure { margin: 0; }
ul { padding: 0; list-style: none; }
img, svg { max-width: 100%; display: block; }
main { width: 100%; display: block; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; border: none; background: none; cursor: pointer; padding: 0; color: inherit; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

body {
  width: 100%;
  max-width: none;
  overflow-x: clip;
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

/* Subtle sitewide backdrop - fixed so it reads as page texture rather than
   per-section noise. Dark sections (gradient-ink) simply paint over it. */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  background-image:
    radial-gradient(rgba(52, 152, 219, .09) 1.3px, transparent 1.3px),
    linear-gradient(180deg, rgba(124, 92, 255, .03), transparent 45%);
  background-size: 26px 26px, 100% 100%;
  pointer-events: none;
}

/* ---------- Sitewide animated geometric shapes backdrop ----------
   Fixed full-viewport layer, same stacking level as body::before, so it
   reads as one continuous page texture behind every section while scrolling.
   Dark sections (gradient-ink) paint over it just like body::before. */
.shapes-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
}

.shapes-bg__shape {
  position: absolute;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--shape-color, rgba(52, 152, 219, .28)), transparent);
  border: 1px solid var(--shape-border, rgba(16, 27, 45, .1));
  box-shadow: 0 16px 44px var(--shape-color, rgba(52, 152, 219, .28));
  backdrop-filter: blur(2px);
  opacity: 0;
  animation:
    shapeIn 1.6s cubic-bezier(.23, .86, .39, .96) forwards,
    shapeFloat 12s ease-in-out infinite;
  animation-delay: var(--shape-delay, 0s), calc(var(--shape-delay, 0s) + 1.6s);
}

.shapes-bg__shape--1 { width: 600px; height: 140px; left: -8%; top: 15%; --shape-color: rgba(99, 102, 241, .22); --shape-border: rgba(99, 102, 241, .16); --shape-rotate: 12deg; --shape-delay: .3s; }
.shapes-bg__shape--2 { width: 500px; height: 120px; right: -4%; top: 70%; --shape-color: rgba(244, 63, 94, .22); --shape-border: rgba(244, 63, 94, .16); --shape-rotate: -15deg; --shape-delay: .5s; }
.shapes-bg__shape--3 { width: 300px; height: 80px; left: 8%; bottom: 8%; --shape-color: rgba(124, 92, 255, .22); --shape-border: rgba(124, 92, 255, .16); --shape-rotate: -8deg; --shape-delay: .4s; }
.shapes-bg__shape--4 { width: 200px; height: 60px; right: 18%; top: 10%; --shape-color: rgba(245, 158, 11, .22); --shape-border: rgba(245, 158, 11, .16); --shape-rotate: 20deg; --shape-delay: .6s; }
.shapes-bg__shape--5 { width: 150px; height: 40px; left: 22%; top: 6%; --shape-color: rgba(34, 211, 238, .22); --shape-border: rgba(34, 211, 238, .16); --shape-rotate: -25deg; --shape-delay: .7s; }

@media (min-width: 768px) {
  .shapes-bg__shape--1 { left: -5%; top: 20%; }
  .shapes-bg__shape--2 { right: 0%; top: 75%; }
  .shapes-bg__shape--3 { left: 10%; bottom: 10%; }
  .shapes-bg__shape--4 { right: 20%; top: 15%; }
  .shapes-bg__shape--5 { left: 25%; top: 10%; }
}

@keyframes shapeIn {
  from { opacity: 0; transform: translateY(-80px) rotate(calc(var(--shape-rotate) - 15deg)); }
  to { opacity: 1; transform: translateY(0) rotate(var(--shape-rotate)); }
}

@keyframes shapeFloat {
  0%, 100% { transform: translateY(0) rotate(var(--shape-rotate)); }
  50% { transform: translateY(15px) rotate(var(--shape-rotate)); }
}

h1, h2, h3, h4 { font-family: var(--font-heading); color: var(--color-dark); font-weight: 700; line-height: 1.2; letter-spacing: -.01em; }

.icon { width: 1em; height: 1em; display: inline-block; vertical-align: middle; fill: none; }

.container {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

::selection { background: var(--color-blue); color: #fff; }

/* Slim premium scrollbar (webkit only - progressive enhancement) */
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: var(--color-bg-alt); }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--color-blue), var(--color-violet)); border-radius: 999px; border: 3px solid var(--color-bg-alt); }

/* Focus visibility for accessibility */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--color-blue);
  outline-offset: 2px;
  border-radius: 4px;
}

.text-gradient {
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ---------- Buttons ---------- */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 26px;
  min-height: 50px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 1rem;
  white-space: nowrap;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition), border-color var(--transition);
}
.btn .icon { width: 18px; height: 18px; transition: transform var(--transition); position: relative; z-index: 1; }
.btn span, .btn { z-index: auto; }
.btn:hover .icon { transform: translateX(3px); }

.btn-primary {
  background: var(--gradient-brand);
  color: #fff;
  box-shadow: var(--shadow-glow);
}
.btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255, 255, 255, .35) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform .65s ease;
  z-index: 0;
}
.btn-primary:hover::before { transform: translateX(120%); }
.btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(52, 152, 219, .42);
}
.btn-primary:active { transform: translateY(-1px) scale(.98); }

.btn-outline {
  background: rgba(16, 27, 45, .03);
  color: var(--color-dark);
  border: 2px solid rgba(16, 27, 45, .18);
}
.btn-outline:hover {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: #fff;
  transform: translateY(-3px);
}
.btn-outline--light {
  background: rgba(255, 255, 255, .06);
  color: #fff;
  border-color: rgba(255, 255, 255, .4);
  backdrop-filter: blur(6px);
}
.btn-outline--light:hover {
  background: #fff;
  color: var(--color-dark);
  border-color: #fff;
}

.btn[disabled] { opacity: .6; cursor: not-allowed; pointer-events: none; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header {
  width: 100%;
  position: sticky;
  top: 0;
  z-index: 1000;
}
/* Resting state: full width, only lightly rounded, full header height so the
   logo reads clearly. Scrolling shrinks it down into a narrower, more rounded
   floating pill with a deeper shadow - the corners are rounded either way,
   just much more so once scrolled. */
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
  position: relative;
  max-width: 100%;
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(16, 27, 45, .06);
  transition: max-width var(--transition), height var(--transition), border-radius var(--transition), box-shadow var(--transition);
}
.site-header.is-scrolled .site-header__inner {
  max-width: calc(100% - 24px);
  height: 58px;
  border-radius: 22px;
  box-shadow: 0 14px 36px rgba(8, 14, 26, .18), 0 0 0 1px rgba(16, 27, 45, .06);
}
/* backdrop-filter lives on a pseudo-element (not .site-header__inner itself)
   because #main-nav (position:fixed) is a real descendant of it -
   backdrop-filter on the element itself would confine #main-nav's fixed
   overlay to this pill instead of the full viewport. */
.site-header__inner::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
}

.logo { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.1; flex-shrink: 0; }
.logo__main { font-family: var(--font-heading); font-size: 1.6rem; font-weight: 800; color: var(--color-dark); letter-spacing: -.5px; }
.logo__dot { color: var(--color-blue); }
.logo__sub { font-size: .65rem; color: var(--color-text-light); text-transform: uppercase; letter-spacing: .5px; }
.logo--footer { margin-bottom: 22px; }
.logo--footer .logo__main { color: #fff; }
.logo__img { height: 44px; width: auto; max-width: 100%; display: block; object-fit: contain; align-self: flex-start; transition: transform var(--transition); }
.logo:hover .logo__img { transform: scale(1.04); }
.logo__img--footer {
  height: 68px;
  padding: 13px 20px;
  background: #fff;
  border-radius: var(--radius-sm);
}

/* Right-hand cluster: hamburger (mobile) / nav (desktop) + language switch,
   grouped in one flex item so .site-header__inner keeps a simple two-item
   space-between layout (logo | header-actions) at every breakpoint. */
.header-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.lang-switch {
  display: flex;
  flex-shrink: 0;
  border: 2px solid var(--color-border);
  border-radius: 999px;
  overflow: hidden;
}
.lang-switch__btn {
  padding: 8px 13px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .3px;
  color: var(--color-text-light);
  background: #fff;
  transition: background var(--transition), color var(--transition);
}
.lang-switch__btn + .lang-switch__btn { border-left: 2px solid var(--color-border); }
.lang-switch__btn:hover { background: var(--color-blue-light); color: var(--color-blue-dark); }
.lang-switch__btn.is-active { background: var(--gradient-brand); color: #fff; }
.lang-switch__btn.is-active:hover { background: var(--gradient-brand); color: #fff; }

/* Hamburger */
.hamburger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  color: var(--color-dark);
  position: relative;
  z-index: 1100;
}
.hamburger:hover { background: var(--color-bg-alt); }
.hamburger .icon { width: 26px; height: 26px; position: absolute; transition: opacity var(--transition), transform var(--transition); }
.hamburger .icon-close { opacity: 0; transform: rotate(-90deg); }
.hamburger[aria-expanded="true"] .icon-open { opacity: 0; transform: rotate(90deg); }
.hamburger[aria-expanded="true"] .icon-close { opacity: 1; transform: rotate(0); color: var(--color-blue); }

/* ---- Mobile nav (default / base styles) ---- */
.main-nav__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(6, 11, 20, .6);
  backdrop-filter: blur(2px);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition);
  z-index: 1040;
}

.main-nav {
  position: fixed;
  top: 0;
  right: 0;
  height: 100%;
  width: min(86vw, 360px);
  background: var(--gradient-ink);
  transform: translateX(100%);
  transition: transform var(--transition);
  z-index: 1050;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: -20px 0 60px rgba(0, 0, 0, .35);
}
.main-nav.is-open { transform: translateX(0); }
.main-nav__backdrop.is-visible { opacity: 1; visibility: visible; }

.main-nav__list { padding: calc(var(--header-h) + 12px) 0 30px; }

.main-nav__item { border-bottom: 1px solid rgba(255, 255, 255, .08); }

.main-nav__link-row {
  display: flex;
  align-items: stretch;
}

.main-nav__link {
  display: flex;
  align-items: center;
  flex: 1;
  gap: 10px;
  padding: 16px 24px;
  min-height: 52px;
  color: #fff;
  font-weight: 600;
  font-size: 1.02rem;
  transition: color var(--transition), background var(--transition);
}
.main-nav__link:hover { color: var(--color-cyan); }

.submenu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  min-height: 52px;
  color: #cfd8e0;
  flex-shrink: 0;
}
.submenu-toggle .icon { width: 20px; height: 20px; transition: transform var(--transition); }
.has-submenu.is-open .submenu-toggle .icon { transform: rotate(180deg); color: var(--color-cyan); }

.submenu {
  max-height: 0;
  overflow: hidden;
  background: rgba(0, 0, 0, .22);
  transition: max-height var(--transition);
}
.has-submenu.is-open > .submenu { max-height: 1200px; }

.submenu li a, .submenu li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px 14px 40px;
  min-height: 48px;
  color: #b8c4cf;
  font-size: .95rem;
  transition: color var(--transition), background var(--transition);
}
.submenu li a:hover { color: #fff; background: rgba(52, 152, 219, .18); }
.submenu .icon { width: 16px; height: 16px; color: var(--color-blue); }

/* =========================================================
   DESKTOP NAV  (>= 992px)
   ========================================================= */
@media (min-width: 992px) {
  .hamburger { display: none; }

  .main-nav__backdrop { display: none; }

  .site-header.is-scrolled .site-header__inner {
    max-width: 1180px;
    border-radius: 999px;
  }

  .main-nav {
    position: static;
    width: auto;
    height: auto;
    background: none;
    transform: none;
    overflow: visible;
    box-shadow: none;
    flex-shrink: 0;
  }

  .main-nav__list {
    display: flex;
    align-items: center;
    padding: 0;
    gap: 4px;
    position: relative;
  }

  /* Shared sliding highlight - script.js moves this behind whichever
     top-level link is hovered, instead of each link fading its own bg. */
  .nav-hover-pill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0;
    border-radius: 999px;
    background: var(--color-blue-light);
    opacity: 0;
    pointer-events: none;
    z-index: 0;
    transition: transform var(--transition), width var(--transition), opacity var(--transition-fast);
  }

  .main-nav__item { border-bottom: none; position: relative; z-index: 1; }

  .main-nav__link {
    padding: 10px 16px;
    min-height: auto;
    color: var(--color-dark);
    font-size: .95rem;
    border-radius: 999px;
    white-space: nowrap;
  }
  .main-nav__link:hover { color: var(--color-blue-dark); }

  .submenu-toggle { display: none; }

  /* dropdown panel sits 8px below the trigger - that gap used to be a dead
     zone where the cursor lost :hover mid-transit. ::after is an invisible
     bridge filling exactly that 8px gap (it's a descendant of .submenu, so
     hovering it keeps .has-submenu:hover true with zero geometric gap). */
  .has-submenu .submenu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 250px;
    max-height: none;
    overflow: visible;
    background:
      radial-gradient(circle at 14% 0%, rgba(124, 92, 255, .06), transparent 55%),
      linear-gradient(165deg, #fff 0%, #f6f9ff 100%);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    padding: 14px 8px 8px;
    margin-top: 8px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  }
  .has-submenu .submenu::before {
    content: '';
    position: absolute;
    top: 0;
    left: 14px;
    right: 14px;
    height: 2px;
    border-radius: 2px;
    background: var(--gradient-brand);
    opacity: .55;
  }
  .has-submenu .submenu::after {
    content: '';
    position: absolute;
    top: -10px;
    left: 0;
    right: 0;
    height: 12px;
  }
  .has-submenu:hover .submenu,
  .has-submenu:focus-within .submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  /* Servizi has 8 entries: lay them out in two columns side by side so
     every item is visible without the panel growing too tall. Columns
     size to their own content (not a fixed width) and items never wrap,
     so row height stays identical to the single-column Microsoft/Hosting
     dropdowns - no extra stretch-induced spacing. */
  .submenu--columns {
    display: grid;
    grid-template-rows: repeat(4, auto);
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    column-gap: 28px;
    align-items: start;
  }
  .submenu--columns li a { white-space: nowrap; }

  .submenu li a, .submenu li {
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    color: var(--color-text);
    min-height: auto;
  }
  .submenu li a:hover { color: var(--color-blue); background: var(--color-blue-light); }

  .has-submenu:hover .main-nav__link, .has-submenu:focus-within .main-nav__link { color: var(--color-blue-dark); }
  .main-nav__link-row { display: inline-flex; }

  .has-submenu .main-nav__link::after {
    content: '';
    width: 7px;
    height: 7px;
    margin-left: 2px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    transition: transform var(--transition);
  }
  .has-submenu:hover .main-nav__link::after { transform: rotate(225deg); }
}

/* Small-laptop/tablet desktop range: the nav links already nearly fill the
   header at this width, so the added language switch needs the links and
   switch itself tightened up a bit to avoid overflowing past the viewport
   edge (verified to overflow ~60-170px without this between 992-1180px). */
@media (min-width: 992px) and (max-width: 1239px) {
  .main-nav__list { gap: 0; }
  .main-nav__link { padding: 8px 9px; font-size: .88rem; }
  .lang-switch__btn { padding: 7px 9px; font-size: .74rem; }
}

/* =========================================================
   HERO SLIDER
   ========================================================= */
.hero { position: relative; overflow: hidden; width: 100%; background: var(--color-dark-3); }
.hero__slider { position: relative; height: 72vh; min-height: 460px; max-height: 640px; }

.hero-canvas {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.hero__slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 1.1s ease, visibility 1.1s ease;
  z-index: 1;
}
.hero__slide.is-active { opacity: 1; visibility: visible; z-index: 2; }

.hero__slide .hero__content { transition: transform 1.1s cubic-bezier(.16,1,.3,1), opacity 1.1s ease; transform: translateY(34px); opacity: 0; }
.hero__slide.is-active .hero__content { transform: translateY(0); opacity: 1; }

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  mix-blend-mode: normal;
}
.hero__bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, .1) 1.5px, transparent 1.5px);
  background-size: 30px 30px;
  opacity: .5;
}
.hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(6, 11, 20, .25), rgba(6, 11, 20, .82));
}
.hero__bg--1 { background: linear-gradient(135deg, rgba(16,27,45,.92) 0%, rgba(41,77,118,.85) 45%, rgba(124,92,255,.6) 130%); }
.hero__bg--2 { background: linear-gradient(135deg, rgba(12,21,36,.92) 0%, rgba(41,128,185,.82) 55%, rgba(34,211,238,.55) 130%); }
.hero__bg--3 { background: linear-gradient(135deg, rgba(16,27,45,.92) 0%, rgba(52,73,94,.82) 50%, rgba(124,92,255,.55) 130%); }

/* Pure product photo on the right of each hero slide - no badge, no
   background, no border, no box. Just the raw PNG. */
.hero__image {
  display: none;
  position: absolute;
  top: 50%;
  right: 4%;
  transform: translateY(-50%);
  width: min(34vw, 480px);
  max-height: 78%;
  object-fit: contain;
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
  z-index: 0;
  pointer-events: none;
  filter: drop-shadow(0 30px 60px rgba(0, 0, 0, .35));
}
@media (min-width: 768px) {
  .hero__image { display: block; }
}

.hero__content { position: relative; z-index: 2; color: #fff; max-width: 660px; }
/* From 768px up, .hero__arrow--prev sits at left:22px/width:48px and
   .hero__image sits absolutely on the right (see below) - push the text
   column clear of the arrow and cap its width to a share of the viewport so
   it never reaches the arrow on one side or the photo on the other, instead
   of a fixed px width that only worked at very wide viewports. Also override
   .container's inherited `margin: 0 auto`: centering a box that's narrower
   than the available width would push it toward the middle (into the photo),
   not away from it - pin it to the left edge instead. */
@media (min-width: 768px) {
  .hero__content { max-width: min(660px, 44vw); margin-left: 96px; margin-right: auto; }
}
.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: .78rem;
  font-weight: 700;
  color: #fff;
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .2);
  backdrop-filter: blur(6px);
  padding: 7px 16px;
  border-radius: 999px;
  margin-bottom: 18px;
}
.hero__content h2 { font-size: clamp(2rem, 5.4vw, 3.4rem); color: #fff; margin-bottom: 18px; letter-spacing: -.02em; }
.hero__text { font-size: 1.08rem; color: #d7e3ec; margin-bottom: 30px; max-width: 540px; }

.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; }

.hero__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .18);
  backdrop-filter: blur(6px);
  color: #fff;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 3;
  transition: background var(--transition), transform var(--transition);
}
.hero__arrow:hover { background: rgba(255, 255, 255, .22); transform: translateY(-50%) scale(1.07); }
.hero__arrow--prev { left: 22px; }
.hero__arrow--prev .icon { transform: rotate(180deg); }
.hero__arrow--next { right: 22px; }
.hero__arrow .icon { width: 22px; height: 22px; }

.hero__dots {
  position: absolute;
  bottom: 26px;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  gap: 10px;
  z-index: 3;
}
.hero__dot {
  width: 44px;
  height: 44px;
  min-width: 44px;
  padding: 16px;
  background: transparent;
  background-image: radial-gradient(rgba(255, 255, 255, .45) 6px, transparent 7px);
  background-position: center;
  background-repeat: no-repeat;
  transition: background-image var(--transition), transform var(--transition);
}
.hero__dot.is-active {
  background-image: radial-gradient(var(--color-cyan) 7px, transparent 8px);
  transform: scale(1.1);
}

@media (min-width: 768px) {
  .hero__arrow { display: flex; }
}

/* =========================================================
   GENERIC SECTIONS
   ========================================================= */
.section { width: 100%; padding: 64px 0; position: relative; }
.section--hosting { background: var(--gradient-ink); color: #dfe6ec; }
.section--hosting h2, .section--hosting .hero__eyebrow { color: #fff; }
.section--hosting p { color: #c3ced8; }
.section--partner { background: var(--color-bg-alt); overflow: hidden; }

.section__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--color-blue-dark);
  background: rgba(52, 152, 219, .1);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-size: .78rem;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 14px;
}
.section--hosting .section__eyebrow, .hero__eyebrow.section__eyebrow { color: #fff; background: rgba(255, 255, 255, .12); border: 1px solid rgba(255, 255, 255, .18); }
.section__head h2 { font-size: clamp(1.7rem, 4vw, 2.4rem); margin-bottom: 16px; }
.section__head p { max-width: 640px; color: var(--color-text-light); font-size: 1.05rem; }
.section__head--center { text-align: center; margin: 0 auto 44px; display: flex; flex-direction: column; align-items: center; }
.section__head--center p { margin: 0 auto; }

.section__grid {
  display: grid;
  gap: 40px;
  align-items: center;
}
.section__copy h2 { margin-bottom: 18px; }
.section__copy p { margin-bottom: 24px; color: var(--color-text-light); font-size: 1.05rem; }
.section--hosting .section__copy p { color: #c3ced8; }

.section__media { display: flex; justify-content: center; position: relative; }
.section__media-img {
  width: 100%;
  max-width: 420px;
  height: auto;
  object-fit: contain;
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
  filter: drop-shadow(0 24px 50px rgba(16, 27, 45, .18));
}
.section--hosting .section__media-img { filter: drop-shadow(0 24px 50px rgba(0, 0, 0, .45)); }

@media (min-width: 768px) {
  .section { padding: 100px 0; }
  .section__grid { grid-template-columns: 1fr 1fr; }
  .section__grid--reverse .section__media { order: 2; }
}

/* Feature list (Server fisici e cloud) */
.feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 20px;
  margin-top: 30px;
}
.feature-list__item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  color: var(--color-dark);
  background: #fff;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.feature-list__item:hover { background: var(--color-blue-light); border-color: var(--color-blue); transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.feature-list__emoji { font-size: 1.3rem; line-height: 1; flex-shrink: 0; }
.feature-list__icon { width: 1.3rem; height: 1.3rem; color: var(--color-blue); flex-shrink: 0; }

/* Card grid (servizi) */
.card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.card {
  position: relative;
  display: block;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;
  background: var(--gradient-brand);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--transition);
  pointer-events: none;
  z-index: 0;
}
.card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-md);
  border-color: transparent;
}
.card:hover::before { opacity: 1; }
.card__icon {
  position: relative;
  width: 58px;
  height: 58px;
  color: #fff;
  background: var(--gradient-brand);
  border-radius: var(--radius-sm);
  padding: 13px;
  margin-bottom: 20px;
  box-shadow: var(--shadow-glow);
  z-index: 1;
}
.card h3 { position: relative; z-index: 1; font-size: 1.12rem; margin-bottom: 10px; }
.card p { position: relative; z-index: 1; color: var(--color-text-light); margin-bottom: 18px; font-size: .95rem; }
.card__link {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-blue-dark);
  font-weight: 600;
  font-size: .9rem;
  transition: gap var(--transition), color var(--transition);
}
.card__link .icon { width: 16px; height: 16px; transition: transform var(--transition); }
.card:hover .card__link { color: var(--color-violet); }
.card:hover .card__link .icon { transform: translateX(4px); }

@media (min-width: 576px) {
  .card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 992px) {
  .card-grid { grid-template-columns: repeat(4, 1fr); }
}

/* Support band */
.support-band {
  position: relative;
  background: var(--gradient-brand);
  color: #fff;
  padding: 56px 0;
  overflow: hidden;
}
.support-band::before {
  content: '';
  position: absolute;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, .18), transparent 70%);
  top: -160px;
  right: -80px;
  pointer-events: none;
}
.support-band__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 22px;
}
.support-band__icon {
  width: 52px;
  height: 52px;
  flex-shrink: 0;
  color: #fff;
  background: rgba(255, 255, 255, .15);
  border: 1px solid rgba(255, 255, 255, .25);
  border-radius: 50%;
  padding: 12px;
}
.support-band__text h2 { color: #fff; font-size: 1.55rem; margin-bottom: 8px; }
.support-band__text p { color: #eef6fc; }

.support-band__actions { width: 100%; }
.support-band__cta { width: 100%; justify-content: center; }

@media (min-width: 768px) {
  .support-band__inner { flex-direction: row; align-items: center; justify-content: space-between; }
  .support-band__text { flex: 1; margin: 0 24px; }
  .support-band__actions { width: auto; min-width: 280px; }
  .support-band__cta { width: 100%; padding: 16px 32px; font-size: 1.05rem; }
}

/* =========================================================
   PARTNER MARQUEE
   ========================================================= */
.partner-marquee {
  overflow: hidden;
  padding: 10px 0;
  margin: -10px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.partner-marquee__inner {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: partner-scroll 38s linear infinite;
}
.partner-marquee:hover .partner-marquee__inner { animation-play-state: paused; }
.partner-track { display: flex; gap: 16px; flex-shrink: 0; }
.partner-track li {
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  height: 76px;
  min-width: 150px;
  padding: 14px 28px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-weight: 700;
  color: var(--color-dark);
  font-size: .95rem;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.partner-track li:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-glow);
  border-color: var(--color-blue);
}
.partner-track li img {
  max-height: 32px;
  max-width: 120px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(1) opacity(.55);
  transition: filter var(--transition);
}
.partner-track li:hover img { filter: grayscale(0) opacity(1); }
.partner-track li img.is-broken { display: none; }
.partner-track li span { display: none; transition: color var(--transition); }
.partner-track li img.is-broken + span { display: block; }
.partner-track li:hover span { color: var(--color-blue-dark); }
@keyframes partner-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .partner-marquee__inner { animation: none; }
}

/* Legacy grid fallback (still used if marquee markup absent) */
.partner-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.partner-grid li {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 18px 12px;
  text-align: center;
  font-weight: 600;
  color: var(--color-dark);
  font-size: .9rem;
  transition: transform var(--transition), box-shadow var(--transition), color var(--transition);
}
.partner-grid li:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); color: var(--color-blue); }

@media (min-width: 576px) { .partner-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 768px) { .partner-grid { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 992px) { .partner-grid { grid-template-columns: repeat(6, 1fr); } }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer { width: 100%; background: var(--gradient-ink); color: #b8c4cf; padding: 20px; position: relative; }
.site-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient-brand);
}
@media (min-width: 768px) {
  .site-footer { padding: 40px 40px 20px 40px; }
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  padding: 60px 0 40px;
}
.footer-col h4 { color: #fff; font-size: 1rem; margin-bottom: 18px; }
.footer-col p { font-size: .92rem; margin-bottom: 18px; color: #9fb0bf; }
.footer-col ul li { margin-bottom: 12px; }
.footer-col ul li a, .footer-col ul li {
  font-size: .92rem;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-height: 24px;
  transition: color var(--transition), transform var(--transition);
}
.footer-col ul li a:hover { color: var(--color-cyan); transform: translateX(3px); }
.footer-contacts .icon { width: 16px; height: 16px; color: var(--color-blue); margin-top: 2px; flex-shrink: 0; }

.footer-bottom { border-top: 1px solid rgba(255, 255, 255, .08); }
.footer-bottom__inner {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px 0;
  font-size: .85rem;
  color: #8a98a5;
}
.footer-bottom__inner a { transition: color var(--transition); }
.footer-bottom__inner a:hover { color: var(--color-cyan); }
.footer-bottom__legal { display: flex; flex-wrap: wrap; gap: 16px; }

@media (min-width: 768px) {
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 992px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; }
  .footer-bottom__inner { flex-direction: row; align-items: center; justify-content: space-between; }
}

/* =========================================================
   INNER PAGES (page-hero / breadcrumb / page-content)
   ========================================================= */
.page-hero {
  width: 100%;
  position: relative;
  overflow: hidden;
  background: var(--gradient-ink);
  color: #fff;
  padding: 50px 0 42px;
}
.page-hero::before {
  content: '';
  position: absolute;
  width: 460px;
  height: 460px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(52, 152, 219, .4), transparent 70%);
  top: -200px;
  right: -120px;
  pointer-events: none;
  animation: blob-float 16s ease-in-out infinite;
}
.page-hero::after {
  content: '';
  position: absolute;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(124, 92, 255, .25), transparent 70%);
  bottom: -160px;
  left: 6%;
  pointer-events: none;
  animation: blob-float 20s ease-in-out infinite reverse;
}
@keyframes blob-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(24px, -18px) scale(1.08); }
}
@media (prefers-reduced-motion: reduce) {
  .page-hero::before, .page-hero::after { animation: none; }
}
.page-hero__canvas { position: absolute; inset: 0; z-index: 0; display: block; width: 100%; height: 100%; pointer-events: none; }
.page-hero h1 { color: #fff; font-size: clamp(1.7rem, 4.5vw, 2.5rem); margin-bottom: 10px; }
.page-hero__inner { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.page-hero__text { flex: 1; min-width: 0; }
.page-hero__icon-wrap {
  display: none;
  align-items: center;
  justify-content: center;
  width: 110px;
  height: 110px;
  min-width: 110px;
  border-radius: 50%;
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border);
  box-shadow: 0 0 0 14px rgba(255, 255, 255, .04), 0 0 0 28px rgba(255, 255, 255, .02);
  flex-shrink: 0;
}
.page-hero__icon { width: 52px; height: 52px; color: #fff; }
@media (min-width: 576px) {
  .page-hero__icon-wrap { display: flex; }
}
.page-hero__watermark {
  display: none;
  position: absolute;
  top: 50%;
  right: -50px;
  transform: translateY(-50%);
  width: 320px;
  height: 320px;
  color: #fff;
  opacity: .06;
  pointer-events: none;
  z-index: 0;
}
@media (min-width: 768px) {
  .page-hero__watermark { display: block; }
}
.breadcrumb { display: flex; flex-wrap: wrap; gap: 8px; font-size: .85rem; color: #b8c4cf; }
.breadcrumb a { color: #b8c4cf; transition: color var(--transition); }
.breadcrumb a:hover { color: #fff; }
.breadcrumb span[aria-hidden] { color: #6c7a87; }
.breadcrumb .is-current { color: var(--color-cyan); font-weight: 600; }

.page-content { width: 100%; padding: 60px 0 76px; position: relative; overflow: hidden; }
/* Faint brand-colored glow in the page-content corners - echoes the
   page-hero gradient mesh further down the page, on every inner page
   (homepage doesn't use .page-content so it's untouched). Static, no
   animation: this area is for reading, not for catching the eye. */
.page-content::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(560px circle at 6% -4%, rgba(52, 152, 219, .07), transparent 60%),
    radial-gradient(620px circle at 98% 104%, rgba(124, 92, 255, .06), transparent 60%);
  pointer-events: none;
}
.page-content__inner { max-width: 820px; margin: 0 auto; position: relative; }
.page-content h2 { font-size: 1.5rem; margin: 40px 0 18px; }
.page-content h2:first-child { margin-top: 0; }
.page-content h3 { font-size: 1.15rem; margin: 26px 0 12px; }
.page-content p { margin-bottom: 18px; color: var(--color-text); font-size: 1.04rem; }
/* No icon-in-a-shape bullet at all (a previous version used a colored
   square/circle with a check/chevron glyph in it - kept reading as a
   checkbox no matter how it was styled). Just a clean white card with a
   thin gradient accent bar along the left edge. */
.page-content ul.bullet-list { list-style: none; margin-bottom: 18px; }
.page-content ul.bullet-list li {
  position: relative;
  padding: 16px 18px 16px 28px;
  margin-bottom: 10px;
  color: var(--color-text);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.page-content ul.bullet-list li:hover { border-color: var(--color-blue); box-shadow: var(--shadow-glow); transform: translateX(4px); }
.page-content ul.bullet-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  bottom: 10px;
  width: 4px;
  border-radius: 4px;
  background: var(--gradient-brand);
}
.page-content img { border-radius: var(--radius); margin: 8px 0 24px; }
.page-content .page-cta {
  position: relative;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 32px;
  margin-top: 40px;
  text-align: center;
  overflow: hidden;
}
.page-content .page-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-brand-soft);
  z-index: 0;
}
.page-content .page-cta > * { position: relative; z-index: 1; }
.page-content .page-cta p { margin-bottom: 18px; }
.page-content .page-cta:last-child p:last-child { margin-bottom: 0; }
.page-content .page-cta .cta-note {
  margin: 14px 0 0;
  font-size: .85rem;
  color: var(--color-text-light);
}

/* =========================================================
   AI WORKFLOW ILLUSTRATION + STEPS (progettazione-web.html)
   ========================================================= */
.heading-icon { margin-right: 8px; color: var(--color-violet); }

.ai-illustration { max-width: 460px; margin: 32px auto 0; }
.ai-illustration svg { width: 100%; height: auto; filter: drop-shadow(0 24px 50px rgba(16, 27, 45, .16)); }
.ai-illustration__caption { text-align: center; font-size: .82rem; color: var(--color-text-light); margin: 14px 0 32px; }

.page-content .card-grid { grid-template-columns: 1fr; gap: 20px; margin: 28px 0 36px; }
@media (min-width: 560px) {
  .page-content .card-grid { grid-template-columns: repeat(2, 1fr); }
}
.page-content .fact-strip { margin: 28px 0 36px; }

/* =========================================================
   LOCATION CARDS + MAP EMBED (dove-siamo.html)
   ========================================================= */
.location-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .location-grid { grid-template-columns: 1fr 1fr; align-items: start; }
}
.location-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: var(--shadow-sm);
}
.location-card__head { display: flex; gap: 16px; align-items: flex-start; margin-bottom: 18px; }
.location-card__icon {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  border-radius: var(--radius-sm);
  background: var(--gradient-brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-glow);
}
.location-card__icon .icon { width: 24px; height: 24px; }
.page-content .location-card h2 { margin: 0 0 6px; font-size: 1.15rem; }
.location-card__address { margin: 0; color: var(--color-text); }
.location-card__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  color: var(--color-blue-dark);
  margin-bottom: 18px;
  transition: gap var(--transition), color var(--transition);
}
.location-card__link .icon { width: 16px; height: 16px; }
.location-card__link:hover { color: var(--color-violet); gap: 9px; }

.map-embed {
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--color-bg-alt);
  min-height: 240px;
}
.map-embed__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 12px;
  padding: 32px 20px;
  min-height: 240px;
}
.map-embed__icon { width: 40px; height: 40px; color: var(--color-blue); }
.map-embed__placeholder p { margin: 0; color: var(--color-text-light); font-size: .92rem; max-width: 280px; }
.map-embed__iframe { width: 100%; height: 280px; border: 0; display: block; }

/* =========================================================
   CLIENT BADGES + LINK CARDS (referenze.html)
   ========================================================= */
.client-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 18px;
  list-style: none;
  padding: 0;
}
.client-grid li {
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 600;
  font-size: .9rem;
  color: var(--color-dark);
  transition: transform var(--transition), background var(--transition), color var(--transition), border-color var(--transition);
}
.client-grid li:hover {
  background: var(--color-blue-light);
  color: var(--color-blue-dark);
  border-color: var(--color-blue);
  transform: translateY(-2px);
}

.link-cards { display: grid; grid-template-columns: 1fr; gap: 14px; list-style: none; padding: 0; margin-bottom: 18px; }
@media (min-width: 600px) { .link-cards { grid-template-columns: repeat(2, 1fr); } }
.link-cards a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-weight: 600;
  color: var(--color-dark);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.link-cards a:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: transparent; }
.link-cards__icon {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--gradient-brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.link-cards__icon .icon { width: 18px; height: 18px; }
.link-cards__arrow { margin-left: auto; width: 16px; height: 16px; color: var(--color-text-light); transition: transform var(--transition), color var(--transition); }
.link-cards a:hover .link-cards__arrow { transform: translateX(4px); color: var(--color-blue); }

/* =========================================================
   INFO CARD GRID (contatti.html)
   ========================================================= */
.info-card-grid { display: grid; grid-template-columns: 1fr; gap: 12px; margin-bottom: 18px; list-style: none; padding: 0; }
@media (min-width: 600px) { .info-card-grid { grid-template-columns: repeat(2, 1fr); } }
.info-card-grid li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  transition: transform var(--transition), box-shadow var(--transition);
}
.info-card-grid li:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.info-card-grid__icon {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--gradient-brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.info-card-grid__icon .icon { width: 18px; height: 18px; }
.info-card-grid__text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.info-card-grid__label { font-size: .76rem; text-transform: uppercase; letter-spacing: .5px; color: var(--color-text-light); font-weight: 600; }
.info-card-grid__value { font-weight: 600; color: var(--color-dark); }
a.info-card-grid__value { transition: color var(--transition); }
a.info-card-grid__value:hover { color: var(--color-blue); }

/* =========================================================
   FACT CHIPS (about-us.html)
   ========================================================= */
.fact-strip { display: flex; flex-wrap: wrap; gap: 14px; margin: 4px 0 32px; }
.fact-chip {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
}
.fact-chip:hover { transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.fact-chip__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--gradient-brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fact-chip__icon .icon { width: 17px; height: 17px; }
.fact-chip strong { display: block; font-size: .95rem; color: var(--color-dark); }
.fact-chip > div > span { display: block; font-size: .75rem; color: var(--color-text-light); }

/* =========================================================
   DOWNLOAD CARD (PDF/document links inside page-content)
   ========================================================= */
.download-card {
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 8px 0 28px;
  padding: 18px 22px;
  background: linear-gradient(135deg, rgba(52, 152, 219, .07), rgba(124, 92, 255, .07));
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.download-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-glow);
  border-color: var(--color-blue);
}
.download-card__icon {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: var(--gradient-brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-glow);
}
.download-card__icon .icon { width: 24px; height: 24px; }
.download-card__text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.download-card__text strong { font-size: 1.05rem; color: var(--color-dark); }
.download-card__text span { font-size: .88rem; color: var(--color-text-light); }
.download-card__btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 20px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--color-blue);
  color: var(--color-blue);
  font-weight: 600;
  font-size: .92rem;
  white-space: nowrap;
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.download-card__btn .icon { width: 16px; height: 16px; transition: transform var(--transition); }
.download-card:hover .download-card__btn { background: var(--gradient-brand); color: #fff; border-color: transparent; }
.download-card:hover .download-card__btn .icon { transform: translateX(3px); }
@media (max-width: 560px) {
  .download-card { flex-wrap: wrap; }
  .download-card__btn { width: 100%; justify-content: center; }
}

/* =========================================================
   TICKET FORM (apri-un-ticket.html)
   ========================================================= */
.ticket-steps { max-width: 560px; }

.ticket-progress {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 36px;
}
.ticket-progress__step {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-alt);
  color: var(--color-text-light);
  font-weight: 700;
  font-size: .9rem;
  border: 2px solid var(--color-border);
  transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
}
.ticket-progress__step.is-active { background: var(--gradient-brand); color: #fff; border-color: transparent; box-shadow: var(--shadow-glow); transform: scale(1.08); }
.ticket-progress__step.is-done { background: var(--color-blue-light); color: var(--color-blue-dark); border-color: var(--color-blue); }

.ticket-step > p { color: var(--color-text-light); margin-bottom: 26px; }

.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-weight: 600; margin-bottom: 8px; font-size: .95rem; color: var(--color-dark); }
.form-group input, .form-group textarea {
  width: 100%;
  padding: 14px 16px;
  min-height: 50px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 1rem;
  font-family: var(--font-body);
  color: var(--color-text);
  background: #fff;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.form-group input:focus, .form-group textarea:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 4px rgba(52, 152, 219, .14);
}
.form-group textarea { resize: vertical; min-height: 140px; }

.form-msg { min-height: 22px; font-size: .92rem; margin-bottom: 16px; font-weight: 600; }
.form-msg.is-error { color: #c0392b; }
.form-msg.is-success { color: #1f8a4c; }

/* File upload dropzone (ticket attachments) */
.file-dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 150px;
  padding: 24px;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-alt);
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition);
}
.file-dropzone:hover, .file-dropzone.is-dragover {
  border-color: var(--color-blue);
  background: var(--color-blue-light);
}
.file-dropzone__icon { width: 36px; height: 36px; margin-bottom: 10px; color: var(--color-text-light); transition: color var(--transition); }
.file-dropzone.is-dragover .file-dropzone__icon { color: var(--color-blue); }
.file-dropzone__text { font-size: .95rem; font-weight: 500; color: var(--color-dark); }
.file-dropzone__text span { color: var(--color-blue-dark); font-weight: 700; text-decoration: underline; }
.file-dropzone__hint { font-size: .8rem; color: var(--color-text-light); margin-top: 6px; }

.file-list { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.file-list:empty { margin-top: 0; }
.file-list__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.file-list__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-blue-light);
  color: var(--color-blue-dark);
  border-radius: var(--radius-sm);
}
.file-list__icon .icon { width: 18px; height: 18px; }
.file-list__info { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.file-list__name { font-size: .9rem; font-weight: 600; color: var(--color-dark); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.file-list__size { font-size: .78rem; color: var(--color-text-light); }
.file-list__remove {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: var(--color-text-light);
  transition: background var(--transition), color var(--transition);
}
.file-list__remove:hover { background: rgba(192, 57, 43, .1); color: #c0392b; }
.file-list__remove .icon { width: 16px; height: 16px; }

.ticket-step--done { text-align: center; padding: 10px 0 0; }
.ticket-success-icon {
  width: 68px;
  height: 68px;
  color: #fff;
  background: var(--gradient-brand);
  border-radius: 50%;
  padding: 16px;
  margin: 0 auto 20px;
  box-shadow: var(--shadow-glow);
}

/* =========================================================
   COOKIE CONSENT
   ========================================================= */
.cookie-consent {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1200;
  padding: 16px;
  transform: translateY(110%);
  transition: transform .45s cubic-bezier(.16, 1, .3, 1);
}
.cookie-consent.is-visible { transform: translateY(0); }

.cookie-consent__inner {
  max-width: 1100px;
  margin: 0 auto;
  background: rgba(12, 21, 36, .88);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  color: #e7ecf0;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 24px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
}
.cookie-consent__icon {
  flex-shrink: 0;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: var(--gradient-brand);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-glow);
}
.cookie-consent__icon .icon { width: 22px; height: 22px; }
.cookie-consent__text { flex: 1 1 320px; min-width: 0; }
.cookie-consent__text h2 { color: #fff; font-size: 1.05rem; margin-bottom: 6px; }
.cookie-consent__text p { color: #b8c4cf; font-size: .92rem; margin: 0; }
.cookie-consent__text a { color: var(--color-cyan); text-decoration: underline; }
.cookie-consent__actions {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-left: auto;
}
.cookie-consent__actions .btn { padding: 12px 20px; min-height: 44px; font-size: .92rem; white-space: nowrap; }
.cookie-consent__actions .btn-outline { border-color: rgba(255, 255, 255, .35); color: #fff; background: rgba(255, 255, 255, .04); }
.cookie-consent__actions .btn-outline:hover { background: rgba(255, 255, 255, .14); color: #fff; }

@media (max-width: 560px) {
  .cookie-consent__inner { padding: 20px; }
  .cookie-consent__actions { width: 100%; margin-left: 0; }
  .cookie-consent__actions .btn { flex: 1 1 auto; justify-content: center; }
}

/* ---- Preferences modal ---- */
.cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.cookie-modal[hidden] { display: none; }
.cookie-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6, 11, 20, .68);
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity .3s ease;
}
.cookie-modal.is-visible .cookie-modal__backdrop { opacity: 1; }

.cookie-modal__panel {
  position: relative;
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  max-width: 560px;
  width: 100%;
  max-height: 86vh;
  overflow-y: auto;
  padding: 32px;
  opacity: 0;
  transform: translateY(16px) scale(.98);
  transition: opacity .3s ease, transform .3s ease;
}
.cookie-modal.is-visible .cookie-modal__panel { opacity: 1; transform: translateY(0) scale(1); }

.cookie-modal__panel h2 { font-size: 1.3rem; margin-bottom: 10px; padding-right: 28px; }
.cookie-modal__panel > p { color: var(--color-text); font-size: .95rem; margin-bottom: 22px; }

.cookie-modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-light);
  border-radius: 50%;
  transition: background var(--transition), color var(--transition);
}
.cookie-modal__close:hover { background: var(--color-bg-alt); color: var(--color-dark); }
.cookie-modal__close .icon { width: 18px; height: 18px; }

.cookie-category {
  padding: 16px 0;
  border-bottom: 1px solid var(--color-border);
}
.cookie-category:last-of-type { border-bottom: none; }
.cookie-category__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}
.cookie-category__head h3 { font-size: 1rem; margin: 0; }
.cookie-category p { font-size: .88rem; color: var(--color-text-light); margin: 0; }

.cookie-badge {
  flex-shrink: 0;
  font-size: .75rem;
  font-weight: 600;
  color: var(--color-blue-dark);
  background: var(--color-blue-light);
  padding: 4px 10px;
  border-radius: 999px;
}

.cookie-toggle {
  flex-shrink: 0;
  width: 46px;
  height: 26px;
  border-radius: 999px;
  background: #d7dde2;
  position: relative;
  transition: background var(--transition);
}
.cookie-toggle__dot {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .25);
  transition: transform var(--transition);
}
.cookie-toggle.is-on { background: var(--gradient-brand); }
.cookie-toggle.is-on .cookie-toggle__dot { transform: translateX(20px); }

.cookie-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}
.cookie-modal__actions .btn { flex: 1 1 auto; justify-content: center; padding: 12px 18px; min-height: 44px; font-size: .92rem; }

/* ---- Reopen preferences floating button ---- */
.cookie-fab {
  position: fixed;
  left: 18px;
  bottom: 18px;
  z-index: 1150;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--gradient-ink);
  border: 1px solid var(--glass-border);
  color: var(--color-cyan);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition), box-shadow var(--transition);
}
.cookie-fab:hover { transform: translateY(-3px); box-shadow: var(--shadow-glow); }
.cookie-fab .icon { width: 22px; height: 22px; }

/* =========================================================
   ANTEPRIMA ANYDESK (teleassistenza.html)
   ========================================================= */
.cta-download-row { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; }

.info-btn {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 2px solid var(--color-border);
  color: var(--color-blue-dark);
  transition: border-color var(--transition), background var(--transition), transform var(--transition);
}
.info-btn:hover { border-color: var(--color-blue); background: var(--color-blue-light); transform: translateY(-2px); }
.info-btn .icon { width: 22px; height: 22px; }

.anydesk-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.anydesk-modal[hidden] { display: none; }
.anydesk-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6, 11, 20, .68);
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity .3s ease;
}
.anydesk-modal.is-visible .anydesk-modal__backdrop { opacity: 1; }

.anydesk-modal__panel {
  position: relative;
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  max-width: 560px;
  width: 100%;
  max-height: 86vh;
  overflow-y: auto;
  padding: 32px;
  opacity: 0;
  transform: translateY(16px) scale(.98);
  transition: opacity .3s ease, transform .3s ease;
}
.anydesk-modal.is-visible .anydesk-modal__panel { opacity: 1; transform: translateY(0) scale(1); }
.anydesk-modal__panel h2 { font-size: 1.3rem; margin-bottom: 10px; padding-right: 28px; }
.anydesk-modal__panel > p { color: var(--color-text); font-size: .95rem; margin-bottom: 20px; }

.anydesk-modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-light);
  border-radius: 50%;
  transition: background var(--transition), color var(--transition);
}
.anydesk-modal__close:hover { background: var(--color-bg-alt); color: var(--color-dark); }
.anydesk-modal__close .icon { width: 18px; height: 18px; }

.anydesk-modal__actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 4px; }

/* Mockup illustrativo dell'interfaccia AnyDesk (non uno screenshot reale) */
.anydesk-mock {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  margin: 4px 0 10px;
}
.anydesk-mock__titlebar {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 10px 14px;
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-border);
}
.anydesk-mock__dot { width: 9px; height: 9px; border-radius: 50%; background: var(--color-border); }
.anydesk-mock__title { margin-left: auto; font-size: .8rem; font-weight: 700; color: var(--color-text-light); letter-spacing: .3px; }
.anydesk-mock__body { display: grid; grid-template-columns: 1fr; }
.anydesk-mock__panel { padding: 18px 20px; }
.anydesk-mock__panel + .anydesk-mock__panel { border-top: 1px solid var(--color-border); }
.anydesk-mock__label { font-size: .72rem; text-transform: uppercase; letter-spacing: .5px; color: var(--color-text-light); font-weight: 700; margin-bottom: 8px; }
.anydesk-mock__id { font-family: 'Courier New', monospace; font-size: 1.35rem; font-weight: 700; color: var(--color-dark); letter-spacing: 1px; margin-bottom: 6px; }
.anydesk-mock__hint { font-size: .78rem; color: var(--color-text-light); }
.anydesk-mock__input { border: 2px solid var(--color-border); border-radius: var(--radius-sm); padding: 10px 12px; font-size: .85rem; color: var(--color-text-light); background: #fff; margin-bottom: 12px; }
.anydesk-mock__btn { display: inline-flex; align-items: center; justify-content: center; padding: 8px 18px; border-radius: 999px; background: var(--gradient-brand); color: #fff; font-size: .82rem; font-weight: 700; }
.anydesk-mock__caption { text-align: center; font-size: .78rem; color: var(--color-text-light); font-style: italic; margin: 0 0 22px; }

@media (min-width: 480px) {
  .anydesk-mock__body { grid-template-columns: 1fr 1fr; }
  .anydesk-mock__panel + .anydesk-mock__panel { border-top: none; border-left: 1px solid var(--color-border); }
}

/* =========================================================
   SCROLL-REVEAL (motion.js sets/clears opacity itself via GSAP -
   intentionally no CSS opacity:0 here so content stays visible
   if the CDN script ever fails to load)
   ========================================================= */
[data-magnetic], [data-tilt] { will-change: transform; }

/* =========================================================
   Small screens fine-tuning
   ========================================================= */
@media (max-width: 380px) {
  .hero__content h2 { font-size: 1.8rem; }
  .btn { padding: 12px 18px; font-size: .92rem; }
}
