/* =========================================================
   SECTIONS — Services / Devices / Showcase (Optimized)
========================================================= */

/* Generic section spacing harmony */
.on-the-go-section,
.breaking-news-section,
.movies-section,
.guides-section{
  padding: var(--section-padding) 0;
}

/* =============== On the go =============== */
.on-the-go-section{
  background: var(--dark-bg);
}

.on-the-go-content{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 3.5rem;
  align-items: center;
}

.on-the-go-text h2{ margin-bottom: 1rem; }
.on-the-go-text p{ font-size: 1.05rem; line-height: 1.8; }

.phone-mockups{
  position: relative;
  display: grid;
  place-items: center;
  min-height: 520px;
  isolation: isolate;
}

/* soft background glow behind devices */
.phone-mockups::before{
  content: "";
  position: absolute;
  inset: -10% -20%;
  background:
    radial-gradient(circle at 30% 20%, rgba(14,165,233,.18), transparent 55%),
    radial-gradient(circle at 70% 80%, rgba(139,92,246,.14), transparent 60%);
  filter: blur(18px);
  z-index: 0;
}

.phone-mockup{
  position: absolute;
  width: min(260px, 42vw);
  border-radius: 34px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  transform-origin: center;
  z-index: 1;
}

.phone-mockup img{
  width: 100%;
  height: auto;
  display: block;
}

.phone-mockup-1{
  left: 6%;
  transform: rotate(-10deg) translateY(18px);
}

.phone-mockup-2{
  right: 6%;
  transform: rotate(10deg) translateY(-18px);
}

/* Emojis floating effect */
.emoji-float{
  position: absolute;
  font-size: 2.2rem;
  z-index: 2;
  opacity: .9;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.45));
  animation: apolloFloat 3.2s ease-in-out infinite;
}

.emoji-1{ top: 10%; left: 2%; }
.emoji-2{ bottom: 16%; right: 4%; animation-delay: 1.4s; }

@keyframes apolloFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-14px); }
}

/* =============== Breaking News =============== */
.breaking-news-section{
  background: var(--dark-bg-secondary);
}

.breaking-news-content{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 3.5rem;
  align-items: center;
}

.breaking-news-text p{ font-size: 1.05rem; line-height: 1.8; }

.tv-mockup{
  position: relative;
  display: grid;
  place-items: center;
}

.tv-screen{
  width: min(520px, 92vw);
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 26px 70px rgba(0,0,0,.55);
  background: rgba(255,255,255,.03);
}

.tv-screen img{
  width: 100%;
  height: auto;
  display: block;
}

.tv-stand{
  position: absolute;
  bottom: -24px;
  left: 50%;
  transform: translateX(-50%);
  width: 160px;
  height: 26px;
  border-radius: 0 0 12px 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.14) 0%, rgba(255,255,255,.06) 100%);
  filter: blur(.2px);
}

.chat-bubble{
  position: absolute;
  padding: .7rem 1rem;
  border-radius: 999px;
  font-size: .86rem;
  font-weight: 600;
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  max-width: 260px;
}

.chat-bubble-green{ background: rgba(34,197,94,.95); color: #07110b; top: 16%; left: -6%; }
.chat-bubble-blue{ background: rgba(59,130,246,.95); color: #061021; bottom: 18%; right: -6%; }

/* =============== Movies showcase =============== */
.movies-section{ background: var(--dark-bg); }

.movies-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}

.movie-card{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.movie-card img{
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
}

/* =============== Responsive =============== */
@media (max-width: 1024px){
  .on-the-go-content,
  .breaking-news-content{
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .phone-mockups{ min-height: 480px; }
  .movies-grid{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px){
  .phone-mockups{ min-height: 420px; }
  .phone-mockup{ width: min(220px, 60vw); }
  .phone-mockup-1{ left: 0; }
  .phone-mockup-2{ right: 0; }
  .chat-bubble-green{ left: 0; }
  .chat-bubble-blue{ right: 0; }
  .movies-grid{ grid-template-columns: 1fr; }
  .movie-card img{ height: 240px; }
}

/* Split section (text + media) — competitor-like */
.split-section{
  padding: var(--section-padding) 0;
  position: relative;
}

.split-inner{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(2rem, 4vw, 4.5rem);
  align-items:center;
}

.split-inner.is-reverse{
  grid-template-columns: 1fr 1.05fr;
}

.split-text h2{
  font-size: clamp(2.1rem, 4vw, 3.1rem);
  margin-bottom: 1rem;
}

.split-text p{
  font-size: 1.05rem;
  line-height: 1.8;
  max-width: 58ch;
}

.split-media{
  position:relative;
  display:flex;
  justify-content:center;
}

.split-media__frame{
  width: min(520px, 100%);
  aspect-ratio: 16/11;
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
  transform: perspective(900px) rotateY(-10deg);
  transition: var(--transition-slow);
}

.split-inner.is-reverse .split-media__frame{
  transform: perspective(900px) rotateY(10deg);
}

.split-media__frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.split-media__float{
  position:absolute;
  width: min(220px, 42%);
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  box-shadow: 0 25px 70px rgba(0,0,0,.55);
  transform: translate(28%, 22%) rotate(8deg);
}

.split-inner.is-reverse .split-media__float{
  transform: translate(-28%, 22%) rotate(-8deg);
}

.split-media__float img{ width:100%; height:100%; object-fit:cover; }

.split-media:hover .split-media__frame{
  transform: perspective(900px) rotateY(0deg) translateY(-4px);
}

.split-media:hover .split-media__float{
  transform: translate(30%, 18%) rotate(5deg);
}

.split-inner.is-reverse .split-media:hover .split-media__float{
  transform: translate(-30%, 18%) rotate(-5deg);
}

@media(max-width: 1024px){
  .split-inner,
  .split-inner.is-reverse{
    grid-template-columns: 1fr;
  }
  .split-media__frame,
  .split-inner.is-reverse .split-media__frame{
    transform:none;
  }
  .split-media__float,
  .split-inner.is-reverse .split-media__float{
    position:absolute;
    transform: translate(18%, 18%) rotate(6deg);
  }
}