/*FONT*/
@font-face {
  font-family: 'Garet';
  src: url('../../../fonts/Garet-Book.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Swissmade';
  src: url('../../../fonts/SWISSMADE.TTF') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Swiss 721';
  src: url('../../../fonts/Swiss721BT-LightExtended.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
/*----------------*/

/*STANDARD*/
:root{
  --bg: #ffffff;
  --text: #121a2b;
  --muted: #9fb0d2;
  --accent: #5aa3ff;
  --ring: rgba(90,163,255,.45);
  --wrap: 1280px;              /* non più usato come limite, lo lascio se ti serve altrove */
  --gap: 8px;                  /* spazio tra i box */
  --radius: 0px;               /* bordi squadrati */
  --page-gray: #f5f5f7;
  --ink: #1d1d1f;
  --sub: #6e6e73;
  --blue: #0071e3;
  --blue-hover: #0a84ff;
  --blue-outline: rgba(0,113,227,.35);
  --logo-c1: #22d3ee; /* ciano */
  --logo-c2: #8b5cf6; /* viola */
  --cta-blue: #1063e0;
  --cta-blue-hover: #0f58c9;
  --text-dark: #0f1a2b;
}

* {
  box-sizing: border-box;
  scrollbar-width: thin;
}
html, body {
  margin: 0;
  min-height: 100%;
  height: auto;
}
body {
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  position: relative;
  overflow-x: hidden;
}
/*----------------*/

/*BACKGORUND DEL SITO WEB*/
body::before {
  content: "";
  position: fixed;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle at 20% 30%, var(--muted) 0%, transparent 50%),
              radial-gradient(circle at 80% 40%, var(--ring) 0%, transparent 50%),
              radial-gradient(circle at 40% 70%, var(--bg) 0%, transparent 50%);
  filter: blur(100px);
  animation: floatGradient 25s ease-in-out infinite alternate;
  opacity: 0.5;
  z-index: -1;
}

@keyframes floatGradient {
  0% {
    transform: translate(0%, 0%) scale(1);
  }
  50% {
    transform: translate(10%, -5%) scale(1.1);
  }
  100% {
    transform: translate(-10%, 5%) scale(1);
  }
}
/*----------------*/

/*GESTIONE BOTTONI*/
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 18px;
  border-radius:9999px;
  border:none;
  font:600 14px/1 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  cursor:pointer;
  text-decoration:none;
  white-space:nowrap;
  -webkit-tap-highlight-color: transparent;
  overflow:hidden;
  z-index:0;
  transition: transform .35s ease, box-shadow .35s ease;
}

.btn::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,var(--logo-c1),var(--logo-c2));
  opacity:0;
  z-index:-1; /* resta dietro il testo */
  transition:opacity .45s ease;
}

.btn:hover::before{ opacity:1; }
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(-1px); }
.btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px color-mix(in oklab,var(--logo-c1),transparent 60%);
}
.btn[disabled]{ opacity:.6; cursor:not-allowed; transform:none; }

/* ===== WHITE VARIANT ===== */
.btn--white{
  background:#fff;
  color:var(--text-dark);
  box-shadow:0 1px 3px rgba(0,0,0,.08);
}
.btn--white:hover{
  color:#fff;
  box-shadow:0 4px 14px color-mix(in oklab,var(--logo-c2),transparent 75%);
}

/* ===== CTA (PREVENTIVO) ===== */
.btn--cta{
  background:var(--cta-blue);
  color:#fff;
  box-shadow:0 1px 4px rgba(16,99,224,.25);
}
.btn--cta:hover{
  box-shadow:0 4px 16px color-mix(in oklab,var(--logo-c2),transparent 70%);
}
.btn--cta:active{ background:var(--cta-blue-hover); }

/* ===== Riduzione movimento ===== */
@media (prefers-reduced-motion: reduce){
  .btn, .btn::before{ transition:none; }
  .btn:hover, .btn:active{ transform:none; }
}
/*----------------*/