:root{
  --bg:#2F4059;
  --fg:#EAF0FF;
  --muted:rgba(234,240,255,.72);
  --muted2:rgba(234,240,255,.55);
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.10);
  --stroke:rgba(255,255,255,.14);
  --shadow:0 18px 60px rgba(0,0,0,.35);
  --radius:18px;
  --max:1100px;
  /* Logo palette (teal + white) */
  --a1:rgba(42,209,175,.28);
  --a2:rgba(234,240,255,.16);
  --a3:rgba(42,209,175,.14);
  --accent:#65CEB0;
  --scroll-offset: 120px;
}

.tillit-word{ color:var(--accent); font-weight:700; }

/* Override base.css (index is "fixed", tillit pages must scroll) */
html{ scroll-behavior: smooth; scroll-padding-top: var(--scroll-offset); }
body{ scroll-behavior: smooth; }
html, body{ height:auto; min-height:100%; }

/* Ensure in-page anchors account for sticky header */
section[id], [id].anchor, .anchor[id]{ scroll-margin-top: var(--scroll-offset); }
body{
  background:var(--bg);
  color:var(--fg);
  overflow:auto;
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:underline; }

.page{
  position:relative;
  min-height:100vh;
  isolation:isolate;
}

/* Tech texture / moving background */
.page::before,
.page::after{
  content:"";
  position:fixed;
  inset:-40vh -40vw;
  z-index:-1;
  pointer-events:none;
  will-change: transform, opacity;
}

.page::before{
  background:
    /* soft base lighting */
    radial-gradient(1200px 900px at 18% 12%, rgba(255,255,255,.10), transparent 60%),
    radial-gradient(1100px 900px at 82% 18%, rgba(255,255,255,.07), transparent 62%),
    /* abstract motion graphics (conic ribbons) */
    conic-gradient(from 0deg at 50% 50%,
      transparent 0 10%,
      var(--a1) 12% 18%,
      transparent 20% 35%,
      var(--a2) 36% 44%,
      transparent 46% 62%,
      var(--a3) 64% 72%,
      transparent 74% 100%),
    conic-gradient(from 180deg at 50% 50%,
      transparent 0 22%,
      rgba(255,255,255,.06) 24% 28%,
      transparent 30% 55%,
      rgba(255,255,255,.05) 57% 60%,
      transparent 62% 100%);
  background-size: 180% 180%, 180% 180%, 220% 220%, 220% 220%;
  background-position: 50% 50%, 50% 50%, 50% 50%, 50% 50%;
  /* Performance note: avoid mix-blend-mode/filter animations; keep simple transforms */
  transform: translate3d(0,0,0);
  animation: tillit-spin 90s linear infinite;
  opacity:.75;
}

.page::after{
  background:
    /* drifting blobs */
    radial-gradient(520px 520px at 22% 35%, var(--a1), transparent 60%),
    radial-gradient(620px 620px at 78% 42%, var(--a2), transparent 62%),
    radial-gradient(540px 540px at 58% 78%, var(--a3), transparent 64%),
    radial-gradient(900px 700px at 50% 55%, rgba(0,0,0,.24), transparent 60%);
  background-size: 200% 200%, 200% 200%, 220% 220%, 180% 180%;
  background-position: 30% 40%, 70% 50%, 55% 75%, 50% 55%;
  filter: blur(22px);
  opacity:.55;
  animation: tillit-drift 70s ease-in-out infinite;
}

@keyframes tillit-spin{
  0%{ transform: translate3d(0,0,0) rotate(0deg) scale(1); }
  50%{ transform: translate3d(0,0,0) rotate(180deg) scale(1.02); }
  100%{ transform: translate3d(0,0,0) rotate(360deg) scale(1); }
}

@keyframes tillit-drift{
  0%,100%{ transform: translate3d(-1.25%, -0.9%, 0) scale(1.02); }
  50%{ transform: translate3d(1.25%, 0.9%, 0) scale(1.06); }
}

@media (prefers-reduced-motion: reduce){
  /* Keep motion (as requested), but make it very slow */
  .page::before{
    animation-duration: 220s;
    animation-timing-function: linear;
  }
  .page::after{
    animation-duration: 200s;
    animation-timing-function: ease-in-out;
  }
}

.container{
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto;
}

.header{
  padding:26px 0;
  position:sticky;
  top:0;
  backdrop-filter: blur(12px);
  background:linear-gradient(to bottom, rgba(47,64,89,.92), rgba(47,64,89,.58));
  border-bottom:1px solid rgba(255,255,255,.08);
  z-index:5;
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand img{ display:block; width:86px; height:auto; }

@media (max-width: 520px){
  .brand img{ width:72px; }
}

@media (max-width: 520px){
  :root{ --scroll-offset: 104px; }
}

.navlinks{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.navToggle{
  display:none;
  align-items:center;
  justify-content:center;
  padding:9px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:var(--fg);
  font-size:13px;
  cursor:pointer;
}

.navToggle:hover{ background:rgba(255,255,255,.08); }
.navToggle:focus-visible{ outline:2px solid rgba(101,206,176,.55); outline-offset:2px; }

@media (max-width: 820px){
  .nav{ flex-wrap:wrap; }
  .navToggle{ display:inline-flex; }

  .navlinks{
    width:100%;
    display:none;
    margin-top:12px;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:8px;
  }

  .nav[data-open="true"] .navlinks{ display:flex; }

  .pill{ justify-content:flex-start; }
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid transparent;
  background:transparent;
  box-shadow:none;
  color:var(--muted);
  letter-spacing:-0.01em;
}

.pill:hover{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.14);
  color:var(--fg);
  text-decoration:none;
}

.pill:focus-visible{
  outline:2px solid rgba(101,206,176,.55);
  outline-offset:2px;
}

.pill[aria-current="page"]{
  background:rgba(101,206,176,.14);
  border-color:rgba(101,206,176,.36);
  color:var(--fg);
}

.hero{
  padding:clamp(100px, 12vh, 140px) 0 clamp(22px, 3.2vh, 36px);
}

.heroGrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:clamp(26px, 3.2vw, 44px);
  align-items:start;
}

@media (max-width: 900px){
  .heroGrid{ grid-template-columns: 1fr; }
}

.h1{
  margin:0 0 14px;
  font-weight:700;
  letter-spacing:-0.02em;
  line-height:1.08;
  font-size:clamp(34px, 3.6vw, 48px) !important;
}

.sub{
  margin:0 0 18px;
  color:var(--muted);
  font-size:clamp(16px, 1.5vw, 19px);
  line-height:1.55;
}

.ctaRow{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.10);
  text-decoration:none;
  position:relative;
  overflow:hidden;
  z-index:1;
}

.btn::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:0;
  height:100%;
  background:rgba(101,206,176,.25);
  transition:width .35s ease;
  z-index:-1;
}

.btn:hover::before{
  width:100%;
}

.btn:hover{
  border-color:rgba(101,206,176,.5);
  text-decoration:none;
}

.btnPrimary{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.22);
}

.btnPrimary::before{
  background:rgba(101,206,176,.35);
}

.btnPrimary:hover{
  border-color:var(--accent);
}

.card{
  border:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  transition:border-color .25s ease;
}

.card:hover{
  border-color:rgba(101,206,176,.35);
}

.heroCard{ padding:18px; }

.kpi{
  padding:14px 16px;
  border-top:1px solid rgba(255,255,255,.10);
  color:var(--muted);
  font-size:14px;
}

.kpi strong{ color:var(--fg); font-weight:650; }

.section{ padding:clamp(56px, 7vh, 90px) 0; }

.sectionAlt{
  position:relative;
}

.sectionAlt::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.03);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  pointer-events:none;
}

.sectionAlt > .container{ position:relative; }

.h2{
  margin:0 0 10px;
  font-size:clamp(22px, 2.2vw, 30px);
  letter-spacing:-0.01em;
}

.lead{ margin:0 0 18px; color:var(--muted); line-height:1.65; }

.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:clamp(14px, 1.4vw, 20px);
}

.feature{
  grid-column: span 4;
  padding:16px;
  transition:background .25s ease, border-color .25s ease;
}

.feature:hover{
  background:rgba(255,255,255,.04);
  border-color:rgba(101,206,176,.2);
}

@media (max-width: 950px){
  .feature{ grid-column: span 6; }
}

@media (max-width: 640px){
  .feature{ grid-column: span 12; }
}

.feature h3{ margin:0 0 8px; font-size:16px; letter-spacing:-0.01em; }
.feature p{ margin:0; color:var(--muted); line-height:1.55; font-size:14.5px; }

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:clamp(14px, 1.4vw, 20px);
}

/* More breathing room in the Security section */
#sicurezza .split{ gap: clamp(18px, 2.2vw, 30px); }
#sicurezza .grid{ gap: clamp(18px, 2.2vw, 26px); }

@media (max-width: 900px){
  .split{ grid-template-columns: 1fr; }
}

.panel{
  padding:18px;
  transition:border-color .25s ease, background .25s ease;
}

.panel:hover{
  border-color:rgba(101,206,176,.25);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.06));
}

.callout{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  border-radius:var(--radius);
  padding:16px 18px;
}

.calloutTitle{ margin:0 0 8px; font-size:16px; letter-spacing:-0.01em; }
.calloutBody{ margin:0; color:var(--muted); line-height:1.6; }

.steps{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.step{ display:flex; gap:12px; align-items:flex-start; }
.stepNum{
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:13px;
  color:rgba(234,240,255,.95);
  background:rgba(101,206,176,.20);
  border:1px solid rgba(101,206,176,.35);
  flex:0 0 auto;
  margin-top:2px;
}
.stepTitle{ margin:0 0 6px; font-size:15px; letter-spacing:-0.01em; }
.stepText{ margin:0; color:var(--muted); font-size:14px; line-height:1.55; }

.faq{ display:grid; gap:10px; }
.faqItem{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  border-radius:14px;
  overflow:hidden;
}
.faqItem summary{
  cursor:pointer;
  list-style:none;
  padding:14px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--fg);
  font-weight:650;
  letter-spacing:-0.01em;
}
.faqItem summary::-webkit-details-marker{ display:none; }
.faqChevron{ opacity:.8; transition: transform .18s ease; }
.faqItem[open] .faqChevron{ transform: rotate(180deg); }
.faqBody{ padding:0 14px 14px; color:var(--muted); font-size:14px; line-height:1.6; }

.small{ color:var(--muted2); font-size:13px; line-height:1.55; }

.hr{ height:1px; background:rgba(255,255,255,.10); margin:22px 0; border:0; }

.footer{
  padding:clamp(34px, 5vh, 60px) 0 clamp(40px, 6vh, 72px);
  color:var(--muted2);
  font-size:13px;
  text-align:left;
}

.footer a{ color:var(--fg); }

.footerBrand{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}

.footerLeft{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.footerBrand img{
  display:block;
  height:22px;
  width:auto;
  opacity:.9;
}

.footerLegal{
  color:var(--muted2);
  line-height:1.6;
  text-align:left;
}

.footerLinks{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  align-items:center;
  flex-wrap:wrap;
  margin-top:0;
  font-size:12px;
  color:var(--muted2);
}

.footerLinks a{ color: rgba(234,240,255,.90); }
.footerLinks a:hover{ color: var(--fg); text-decoration: underline; }
.footerLinks .sep{ opacity:.7; }

/* Back to top button */
.backToTop{
  position:fixed;
  bottom:28px;
  right:28px;
  width:48px;
  height:48px;
  border-radius:50%;
  border:1px solid var(--stroke);
  background:rgba(47,64,89,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:var(--fg);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transform:translateY(20px);
  transition:opacity .3s ease, visibility .3s ease, transform .3s ease, background .2s ease;
  box-shadow:0 4px 20px rgba(0,0,0,.25);
  z-index:999;
}
.backToTop.visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.backToTop:hover{
  background:rgba(101,206,176,.2);
  border-color:var(--accent);
}
.backToTop:active{ transform:scale(.95); }

@media (max-width: 720px){
  .footer{ text-align:center; }
  .footerBrand{ justify-content:center; flex-direction:column; align-items:center; }
  .footerLeft{ justify-content:center; }
  .footerLegal{ text-align:center; }
  .footerLinks{ justify-content:center; }
}
