/* Home — mega hero, hosting spotlight, bento (pairs with page-home) */

.page-home .site-shell{
  position:relative;
  z-index:10;
}

.page-home .vignette{
  box-shadow:inset 0 0 100px rgba(0,0,0,.38);
}

.page-home .home-mega{
  padding:clamp(72px,10vh,118px) 0 clamp(48px,8vh,88px);
}

.page-home .home-mega-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(22px,4vw,44px);
  align-items:stretch;
}

.page-home .home-mega-copy{
  padding:clamp(28px,4vw,46px);
  border-radius:var(--radius);
  background:linear-gradient(155deg, rgba(22,38,62,.88), rgba(12,24,44,.84));
  border:1px solid rgba(160,220,255,.32);
  box-shadow:var(--shadow), 0 0 80px rgba(100,180,255,.12), inset 0 1px 0 rgba(255,255,255,.08);
  position:relative;
  overflow:hidden;
}

.page-home .home-mega-copy::after{
  content:"";
  position:absolute;
  top:-40%;
  right:-20%;
  width:min(520px,90vw);
  height:min(520px,90vw);
  background:radial-gradient(circle, rgba(100,200,255,.16), transparent 62%);
  pointer-events:none;
}

.page-home .home-mega-visual{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:clamp(380px,56vh,620px);
  height:100%;
  border-radius:calc(var(--radius) + 4px);
  overflow:hidden;
  border:1px solid rgba(170,230,255,.38);
  box-shadow:0 28px 90px rgba(0,10,30,.45), 0 0 0 1px rgba(255,255,255,.06) inset;
}

.page-home .home-mega-visual img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:brightness(.58) saturate(1.1) contrast(1.02);
}

.page-home .home-mega-visual::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg, rgba(6,16,32,.2), rgba(4,12,28,.55) 45%, rgba(4,14,32,.88) 100%);
  pointer-events:none;
}

.page-home .home-mega-visual .mega-visual-inner{
  position:relative;
  z-index:2;
  flex:1;
  min-height:100%;
  padding:clamp(20px,3.5vw,32px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:clamp(14px,2vw,22px);
}
.page-home .mega-visual-top{
  margin-top:clamp(8px,2vh,20px);
}
.page-home .mega-visual-title{
  margin:12px 0 10px;
  font-size:clamp(1.35rem,2.5vw,1.85rem);
  line-height:1.15;
  color:#f4f9ff;
  text-shadow:0 2px 24px rgba(0,20,40,.5);
}
.page-home .mega-visual-lead{
  margin:0;
  color:rgba(235,245,255,.94);
  max-width:52ch;
  font-size:.98rem;
  line-height:1.55;
}
.page-home .mega-visual-points{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.page-home .mega-visual-points li{
  margin:0;
  padding:10px 12px 10px 14px;
  border-radius:14px;
  background:rgba(6,18,38,.72);
  border:1px solid rgba(130,200,255,.28);
  font-size:.9rem;
  line-height:1.45;
  color:rgba(220,235,255,.95);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.page-home .mega-visual-points li strong{
  color:#fff;
  font-weight:800;
}
.page-home .mega-visual-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  padding-top:4px;
}
.page-home .mega-visual-strip > div{
  text-align:center;
  padding:12px 8px;
  border-radius:14px;
  background:rgba(3,12,28,.75);
  border:1px solid rgba(150,210,255,.3);
}
.page-home .mega-visual-stat{
  display:block;
  font-size:1.35rem;
  font-weight:900;
  color:#b8e8ff;
  letter-spacing:-.02em;
  line-height:1.1;
}
.page-home .mega-visual-stat-label{
  display:block;
  font-size:.68rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:rgba(180,210,235,.85);
  margin-top:4px;
}

.page-home .home-hosting-spotlight{
  padding:clamp(44px,7vw,90px) 0;
}

.page-home .hosting-spotlight-card{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:clamp(20px,3vw,36px);
  align-items:center;
  padding:clamp(26px,4vw,42px);
  border-radius:var(--radius);
  background:
    linear-gradient(125deg, rgba(20,35,55,.88), rgba(8,18,36,.85)),
    radial-gradient(ellipse 80% 60% at 90% 20%, rgba(90,180,255,.15), transparent 50%);
  border:1px solid rgba(130,210,255,.35);
  box-shadow:0 24px 70px rgba(0,15,40,.45), inset 0 1px 0 rgba(255,255,255,.06);
}

.page-home .hosting-spotlight-card .spotlight-art{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  min-height:220px;
  border:1px solid rgba(120,200,255,.2);
}

.page-home .hosting-spotlight-card .spotlight-art img{
  width:100%;
  height:100%;
  object-fit:cover;
  min-height:220px;
  filter:brightness(.55) saturate(1.08);
}

.page-home .hosting-spotlight-card .spotlight-art::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(8,16,28,.75), transparent 55%);
  pointer-events:none;
}

.page-home .home-bento{
  padding-bottom:clamp(50px,10vh,100px);
}

.page-home .bento-grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:clamp(14px,2vw,22px);
}

.page-home .bento-card{
  grid-column:span 4;
  position:relative;
  min-height:280px;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--panel);
}

.page-home .bento-card--wide{
  grid-column:span 8;
}

.page-home .bento-card .bg-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.55) saturate(1.06);
}

.page-home .bento-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(4,10,20,.05), rgba(4,10,20,.88) 68%);
  z-index:1;
}

.page-home .bento-card .overlay{
  position:relative;
  z-index:2;
  padding:26px;
  height:100%;
  min-height:280px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.page-home .bento-card h3{
  font-size:clamp(1.25rem,2.5vw,1.65rem);
}

@media (max-width:1100px){
  .page-home .home-mega-grid,
  .page-home .hosting-spotlight-card{
    grid-template-columns:1fr;
  }
  .page-home .bento-card,
  .page-home .bento-card--wide{
    grid-column:span 12;
  }
  .page-home .mega-visual-strip{
    grid-template-columns:1fr;
  }
}

/* Bottom revenue / pricing band — higher contrast on busy background */
.page-home .home-bottom-strip{
  position:relative;
  padding-bottom:clamp(70px,12vh,120px);
}
.page-home .home-bottom-strip::before{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:0;
  width:min(100%,var(--max));
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(130,200,255,.35), transparent);
  pointer-events:none;
}
.page-home .home-bottom-strip .feature-strip{
  padding:clamp(28px,4vw,40px);
  border-radius:var(--radius);
  background:linear-gradient(168deg, rgba(14,28,48,.94), rgba(6,14,30,.96));
  border:1px solid rgba(150,210,255,.4);
  box-shadow:0 24px 60px rgba(0,8,24,.5), inset 0 1px 0 rgba(255,255,255,.1);
  gap:clamp(24px,4vw,40px);
}
.page-home .home-bottom-strip .feature-card,
.page-home .home-bottom-strip .pricing-card{
  background:rgba(4,12,28,.55);
  border-color:rgba(140,200,255,.32);
}
.page-home .home-bottom-strip .feature-card p,
.page-home .home-bottom-strip .pricing-card ul.clean li{
  color:rgba(210,225,240,.95);
}
.page-home .home-bottom-strip .feature-card h2,
.page-home .home-bottom-strip .pricing-card h3{
  color:#f2f8ff;
}

@media (max-width:900px){
  .page-home .home-mega{
    padding:clamp(48px,8vh,80px) 0 clamp(32px,6vh,60px);
  }
  .page-home .home-mega-visual{
    min-height:clamp(260px,40vh,480px);
  }
}

@media (max-width:640px){
  .page-home .home-mega{
    padding:40px 0 32px;
  }
  .page-home .home-mega-copy{
    padding:20px 18px;
  }
  .page-home .home-mega-copy h1{
    font-size:clamp(1.5rem,6.5vw,2.05rem);
    line-height:1.1;
  }
  .page-home .home-mega-copy .lead{
    font-size:1rem;
  }
  .page-home .inline-pills{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .page-home .home-mega-visual{
    min-height:220px;
  }
  .page-home .hosting-spotlight-card{
    padding:20px 18px;
  }
  .page-home .hosting-spotlight-card .spotlight-art{
    min-height:160px;
  }
  .page-home .bento-card,
  .page-home .bento-card .overlay{
    min-height:220px;
  }
  .page-home .bento-card .overlay{
    padding:20px;
  }
  .page-home .home-bottom-strip .feature-strip{
    padding:20px 18px;
  }
  .page-home .home-bottom-strip{
    padding-bottom:48px;
  }
}
