/* Firmamento — Home page only */

/* Offset content under fixed header */
.page-pad{ padding-top: var(--header-h); }
body.has-hero-done .page-pad{ padding-top: var(--header-h); }

/* ===== HERO ===== */
.hero{
  position: relative;
  min-height: calc(100vh - var(--header-h));
  display:grid;
  place-items:center;
  overflow:hidden;
}
.hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 700px at 70% 15%, rgba(45,107,255,.18), transparent 55%),
    radial-gradient(900px 650px at 20% 70%, rgba(244,197,66,.12), transparent 60%),
    linear-gradient(180deg, rgba(11,16,32,.15), rgba(11,16,32,.88) 75%, rgba(11,16,32,.98)),
    url("/assets/img/sfondo.jpeg") center/cover no-repeat;
  filter: contrast(1.06) saturate(1.05);
  transform: scale(1.02);
}
.hero__stars{
  position:absolute;
  inset:0;
  opacity: .10;
  pointer-events:none;
  background:
    radial-gradient(1px 1px at 10% 20%, rgba(255,255,255,.9), transparent 2px),
    radial-gradient(1px 1px at 30% 80%, rgba(255,255,255,.7), transparent 2px),
    radial-gradient(1px 1px at 70% 30%, rgba(255,255,255,.8), transparent 2px),
    radial-gradient(1px 1px at 90% 60%, rgba(255,255,255,.6), transparent 2px),
    radial-gradient(1px 1px at 55% 50%, rgba(255,255,255,.7), transparent 2px);
  background-size: 520px 520px;
  animation: starDrift 22s linear infinite;
}
@keyframes starDrift{
  from{ transform: translateY(0); }
  to{ transform: translateY(22px); }
}

.hero__watermark{
  position:absolute;
  right: -120px;
  top: 8%;
  width: min(860px, 70vw);
  opacity: .10;
  transform: rotate(-8deg);
  pointer-events:none;
  filter: saturate(0.9) contrast(1.05);
}

.hero__content{
  position: relative;
  z-index: 2;
  color: var(--text-dark);
  padding: 56px 0 44px;
}
.hero__kicker{
  margin: 0 0 14px;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text-dark) 72%, transparent);
}
.hero h1{
  margin:0;
  max-width: 15ch;
}
.hero__sub{
  margin: 14px 0 0;
  font-size: 18px;
  line-height: 1.6;
  color: color-mix(in srgb, var(--text-dark) 78%, transparent);
  max-width: 70ch;
}
.hero__actions{
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 22px;
}

.trinity{
  margin-top: 26px;
  display:grid;
  gap: 12px;
  max-width: 860px;
}
@media (min-width: 768px){
  .trinity{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}
.trinity__item{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 14px 16px;
  border-radius: var(--r-18);
  border: 1px solid color-mix(in srgb, var(--text-dark) 14%, transparent);
  background: color-mix(in srgb, var(--bg-dark-2) 62%, transparent);
  box-shadow: var(--shadow-dark);
}
.trinity__item svg{
  width: 20px; height: 20px;
  color: var(--c-gold);
  flex: 0 0 auto;
  margin-top: 2px;
}
.trinity__item p{
  margin:0;
  color: color-mix(in srgb, var(--text-dark) 78%, transparent);
  font-size: 14px;
  line-height: 1.5;
}

/* scroll indicator */
.scroll-indicator{
  margin-top: 24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 44px; height: 62px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text-dark) 18%, transparent);
  background: color-mix(in srgb, var(--text-dark) 8%, transparent);
}
.scroll-indicator span{
  width: 6px; height: 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-dark) 88%, transparent);
  animation: scrollDot 1.5s var(--ease) infinite;
}
@keyframes scrollDot{
  0%{ transform: translateY(-10px); opacity:0; }
  35%{ opacity: 1; }
  70%{ transform: translateY(10px); opacity: 1; }
  100%{ transform: translateY(12px); opacity: 0; }
}
body.has-scrolled .scroll-indicator{ opacity: 0; pointer-events:none; transition: opacity var(--speed-2) var(--ease); }

/* ===== Hero logo sequence overlay ===== */
.hero-seq{
  position: absolute;
  inset: 0;
  display:grid;
  place-items:center;
  z-index: 5;
  pointer-events:none;
}
.hero-seq__wrap{
  display:grid;
  place-items:center;
  gap: 14px;
  transform: translateY(-10px);
}
.hero-seq__word{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text-dark) 72%, transparent);
  opacity: 0;
  animation: wordFade 700ms var(--ease) 1150ms forwards;
}
@keyframes wordFade{
  to{ opacity: 1; transform: translateY(0); }
}

.hero-seq svg{
  width: 120px;
  height: 120px;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.35));
}
.seq-circle{
  fill: none;
  stroke: rgba(255,255,255,.88);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-dasharray: 260;
  stroke-dashoffset: 260;
  animation: circleDraw 900ms var(--ease) 120ms forwards;
}
@keyframes circleDraw{ to{ stroke-dashoffset: 0; } }

.seq-star{
  fill: var(--c-gold);
  opacity: 0;
  transform-origin: center;
}
.seq-star.s1{ animation: starIn 520ms var(--ease) 520ms forwards; }
.seq-star.s2{ animation: starIn 520ms var(--ease) 720ms forwards; }
.seq-star.s3{ animation: starIn 520ms var(--ease) 920ms forwards; }
@keyframes starIn{
  0%{ opacity:0; transform: scale(.2); }
  60%{ opacity:1; transform: scale(1.12); }
  100%{ opacity:1; transform: scale(1); }
}

/* When done, remove overlay */
body.has-hero-done .hero-seq{ display:none; }

/* ===== TRUST BADGES (dark) ===== */
.trust{
  padding: 36px 0;
  border-top: 1px solid var(--line-dark);
  border-bottom: 1px solid var(--line-dark);
}
.trust__row{
  display: grid;
  gap: 16px;
  align-items:start;
}
@media (min-width: 1024px){
  .trust__row{ grid-template-columns: 1.2fr 1.6fr 1.2fr; }
}

.metrics{
  display: grid;
  grid-template-columns: auto;
  gap: 12px;
}
.metric{
  padding: 14px;
  border-radius: var(--r-18);
  border: 1px solid var(--line-dark);
  background: color-mix(in srgb, var(--bg-dark-2) 70%, transparent);
}
.metric__num{
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: 20px;
  color: var(--text-dark);
}
.metric__label{
  margin-top: 6px;
  font-size: 12px;
  color: color-mix(in srgb, var(--text-dark) 72%, transparent);
  line-height: 1.4;
}

.logo-wall{
  display:grid;
  gap: 10px;
}
.logo-wall__grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 10px;
}
.logo-pill{
  display:grid;
  place-items:center;
  min-height: 44px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text-dark) 14%, transparent);
  background: color-mix(in srgb, var(--text-dark) 6%, transparent);
  color: color-mix(in srgb, var(--text-dark) 78%, transparent);
  font-size: 12px;
  letter-spacing: .06em;
}
.logo-pill:hover{
  background: color-mix(in srgb, var(--text-dark) 10%, transparent);
  color: var(--text-dark);
}

.partner-wall__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
}

/* ===== SPLIT VALUE PROPOSITION ===== */
.split{
  padding: 0;
}
.split__grid{
  display:grid;
}
@media (min-width: 1024px){
  .split__grid{ grid-template-columns: 1fr 1fr; }
}
.split__pane{
  padding: clamp(56px, 6vw, 88px) 0;
}
.split__pane--light{
  background: var(--c-white);
  color: var(--text);
}
.split__pane--dark{
  background: var(--bg-dark);
  color: var(--text-dark);
  position:relative;
  overflow:hidden;
}
.split__pane--dark::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.10;
  background: url("/assets/img/costellazioni.png") center/cover no-repeat;
  pointer-events:none;
}
.split__inner{
  position:relative;
  z-index: 1;
}
.split__desc{ max-width: 68ch; }
.split__desc--dark{ 
    color: var(--text);
    max-width: 68ch; }
.split__desc--light{ 
    color: var(--text-light);
  max-width: 68ch; }
.value-cards{
  margin-top: 18px;
}

.value-props{
  margin-top: 16px;
  display:grid;
  gap: 14px;
}
@media (min-width: 768px){
  .value-props{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

.testimonial{
  margin-top: 16px;
  padding: 16px 18px;
  border-radius: var(--r-18);
  border: 1px solid var(--line-dark);
  background: color-mix(in srgb, var(--bg-dark-2) 74%, transparent);
}
.testimonial blockquote{
  margin:0;
  color: color-mix(in srgb, var(--text-dark) 80%, transparent);
  font-size: 14px;
  line-height: 1.65;
}
.testimonial figcaption{
  margin-top: 10px;
  font-size: 12px;
  color: color-mix(in srgb, var(--text-dark) 68%, transparent);
}

/* ===== SERVICES ===== */
.services__head{
  max-width: 78ch;
}
.service-card{
  border-top: 4px solid transparent;
}
.service-card[data-accent="azure"]{ border-top-color: var(--c-azure); }
.service-card[data-accent="gold"]{ border-top-color: var(--c-gold); }

.service-card__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
}
.service-card__icon{
  width: 44px; height: 44px;
  border-radius: var(--r-14);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--c-azure) 10%, transparent);
  display:grid;
  place-items:center;
}
.service-card__icon svg{ width: 22px; height: 22px; color: var(--c-navy); }

.service-bullets{
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display:grid;
  gap: 8px;
}
.service-bullets li{
  padding: 10px 12px;
  border-radius: var(--r-14);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--c-gray-900) 2%, transparent);
  font-size: 13px;
  color: color-mix(in srgb, var(--c-gray-900) 72%, transparent);
}

/* ===== FEATURED PROJECT ===== */
.featured{
  overflow:hidden;
}
.featured__grid{
  display:grid;
  gap: 18px;
  align-items:stretch;
}
@media (min-width: 1024px){
  .featured__grid{ grid-template-columns: 1.45fr 1fr; gap: 22px; }
}
.featured__media{
  border-radius: var(--r-24);
  border: 1px solid var(--line-dark);
  overflow:hidden;
  position:relative;
  min-height: 320px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.72)),
    url("/assets/img/sfondo.jpeg") center/cover no-repeat;
}
.featured__media::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(800px 520px at 70% 20%, rgba(45,107,255,.16), transparent 55%);
}

.featured__panel{
  border-radius: var(--r-24);
  border: 1px solid var(--line-dark);
  background: color-mix(in srgb, var(--bg-dark-2) 82%, transparent);
  box-shadow: var(--shadow-dark);
  padding: 18px;
}
.featured__panel h3{ margin-top: 0; }

.coverage{
  margin-top: 14px;
}
.coverage__grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 10px;
}

/* ===== PROJECT-BASED RECRUITING ===== */
.pbr__grid{
  display:grid;
  gap: 16px;
}
@media (min-width: 1024px){
  .pbr__grid{ grid-template-columns: 1fr 1.2fr; align-items:start; }
}
.timeline{
  display:grid;
  gap: 12px;
}
.step{
  display:flex;
  gap: 14px;
  padding: 16px;
  border-radius: var(--r-18);
  border: 1px solid var(--line-dark);
  background: color-mix(in srgb, var(--bg-dark-2) 74%, transparent);
}
.step__num{
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text-dark) 16%, transparent);
  background: color-mix(in srgb, var(--text-dark) 8%, transparent);
  display:grid;
  place-items:center;
  font-weight: 700;
  color: var(--text-dark);
  flex: 0 0 auto;
}
.step__body h3{
  margin: 0 0 6px;
  font-size: 16px;
  letter-spacing: -0.02em;
}
.step__body p{
  margin: 0;
  color: var(--muted-dark);
  font-size: 14px;
}

/* ===== PARTNERSHIPS ===== */
.partner-cats{
  display:grid;
  gap: 14px;
}
@media (min-width: 1024px){
  .partner-cats{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}
.partner-cat{
  padding: 18px;
  border-radius: var(--r-18);
  border: 1px solid var(--line);
  background: var(--c-white);
}
.partner-cat h3{
  margin: 0 0 10px;
  font-size: 14px;
  letter-spacing: .10em;
  text-transform: uppercase;
}
.partner-cat .logos{
  display:grid;
  gap: 10px;
}
.partner-cat .logos .logo-pill{
  border-color: var(--line);
  background: color-mix(in srgb, var(--c-gray-900) 2%, transparent);
  color: color-mix(in srgb, var(--c-gray-900) 76%, transparent);
}

/* ===== FINAL CTA ===== */
.dual-cta{
  display:grid;
  gap: 16px;
}
@media (min-width: 1024px){
  .dual-cta{ grid-template-columns: 1fr 1fr; gap: 32px; }
}
.cta-card{
  border-radius: var(--r-24);
  padding: 22px;
  border: 1px solid var(--line);
  background: var(--c-white);
  box-shadow: var(--shadow);
}
.cta-card--biz{
  background: var(--c-navy);
  color: var(--text-dark);
  border-color: var(--line-dark);
  box-shadow: var(--shadow-dark);
}
.cta-card__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
}
.cta-card__icon{
  width: 52px; height: 52px;
  border-radius: var(--r-18);
  display:grid;
  place-items:center;
  border: 1px solid color-mix(in srgb, currentColor 16%, transparent);
  background: color-mix(in srgb, currentColor 8%, transparent);
}
.cta-card p{ max-width: 68ch; }
.cta-reassure{
  margin-top: 14px;
  font-size: 12px;
  color: color-mix(in srgb, currentColor 70%, transparent);
}

/* ===== Links ===== */
.text-link{
  color: color-mix(in srgb, var(--c-azure) 85%, var(--c-gray-900));
  text-decoration: underline;
  text-underline-offset: 3px;
}
.section--dark .text-link{
  color: color-mix(in srgb, var(--c-azure-bright) 90%, var(--text-dark));
}
