/* Gestor Internet — Brand overrides on top of Boono base */

:root{
  --gi-orange:#ff6c0a;
  --gi-orange-dark:#e85d00;
  --gi-dark:#0e0e0f;
  --gi-soft:#f6f4ee;
  --gi-text:#1a1a1a;
  --gi-muted:#6b6b6b;
}

html,body{ background:var(--gi-soft); color:var(--gi-text); }
body{ font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; }

/* ==== HERO (faithful to Boono with image cross-fade slideshow) ==== */
.gi-hero{
  position:relative;
  min-height:100vh;
  width:100%;
  overflow:hidden;
  background:#000;
  color:#fff;
  isolation:isolate;
}
.gi-hero-bg{
  position:absolute; inset:0;
  z-index:0;
}
.gi-hero-bg .slide{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0;
  transform:scale(1.08);
  animation: giHeroSlideshow 24s infinite;
  filter:brightness(0.55) saturate(1.05);
  will-change:opacity, transform;
}
.gi-hero-bg .slide:nth-child(1){ animation-delay: 0s; }
.gi-hero-bg .slide:nth-child(2){ animation-delay: 6s; }
.gi-hero-bg .slide:nth-child(3){ animation-delay: 12s; }
.gi-hero-bg .slide:nth-child(4){ animation-delay: 18s; }

@keyframes giHeroSlideshow{
  0%   { opacity:0; transform:scale(1.12); }
  4%   { opacity:1; transform:scale(1.08); }
  25%  { opacity:1; transform:scale(1.0); }
  29%  { opacity:0; transform:scale(1.0); }
  100% { opacity:0; }
}

.gi-hero-video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  z-index:1;
  opacity:.55;
  mix-blend-mode:screen;
  pointer-events:none;
}

.gi-hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,108,10,0.30) 0%, transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.85) 100%);
  z-index:2;
}

/* navbar */
.gi-nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 40px;
  color:#fff;
  transition: background .35s ease, padding .35s ease;
}
.gi-nav.scrolled{ background:rgba(14,14,15,0.85); backdrop-filter: blur(12px); padding:14px 40px; }
.gi-nav .brand{
  display:flex; align-items:center; gap:10px;
  text-decoration:none;
}
.gi-nav .brand-logo{
  display:block; height:64px; width:auto;
  transition: height .35s ease;
}
.gi-nav.scrolled .brand-logo{ height:52px; }
.gi-nav ul{
  display:flex; gap:32px; list-style:none; margin:0; padding:0;
  font-size:.92rem; letter-spacing:.04em;
}
.gi-nav ul a{ color:#fff; text-decoration:none; opacity:.85; transition:opacity .2s; }
.gi-nav ul a:hover{ opacity:1; color:var(--gi-orange); }
.gi-nav .cta{
  display:inline-block; padding:10px 22px;
  background:var(--gi-orange); color:#fff; border-radius:999px;
  font-weight:600; font-size:.9rem; text-decoration:none;
  transition: background .2s, transform .2s;
}
.gi-nav .cta:hover{ background:#fff; color:var(--gi-orange); transform:translateY(-2px); }

/* hero content */
.gi-hero-content{
  position:relative; z-index:3;
  display:flex; flex-direction:column; justify-content:flex-end;
  min-height:100vh; padding:140px 40px 60px;
  max-width:1400px; margin:0 auto;
}
.gi-hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.85rem; letter-spacing:.18em; text-transform:uppercase;
  color:#fff; opacity:.85; margin-bottom:24px;
}
.gi-hero-eyebrow::before{
  content:""; width:36px; height:1px; background:var(--gi-orange);
}
.gi-hero-title{
  font-size: clamp(3rem, 9vw, 8.5rem);
  font-weight:800;
  line-height:.95; letter-spacing:-.02em;
  text-transform:uppercase;
  margin:0 0 24px;
  font-family: "Inter Tight", "Inter", sans-serif;
}
.gi-hero-title .accent{ color:var(--gi-orange); font-style:italic; font-weight:500; }
.gi-hero-sub{
  max-width:620px;
  font-size:1.1rem; line-height:1.55; opacity:.85;
  margin-bottom:40px;
}
.gi-hero-actions{ display:flex; gap:16px; flex-wrap:wrap; }
.gi-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 30px; border-radius:999px;
  font-weight:600; font-size:.95rem;
  text-decoration:none; transition: all .25s ease;
  border:1px solid transparent;
}
.gi-btn-primary{ background:var(--gi-orange); color:#fff; }
.gi-btn-primary:hover{ background:#fff; color:var(--gi-orange); transform:translateY(-3px); }
.gi-btn-ghost{ border-color:rgba(255,255,255,0.4); color:#fff; }
.gi-btn-ghost:hover{ background:#fff; color:var(--gi-dark); border-color:#fff; }

/* hero bottom strip */
.gi-hero-strip{
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-top:60px; gap:30px; flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,0.2);
  padding-top:22px;
}
.gi-hero-strip .stat .num{ font-size:2rem; font-weight:700; color:var(--gi-orange); line-height:1; }
.gi-hero-strip .stat .lbl{ font-size:.8rem; opacity:.75; text-transform:uppercase; letter-spacing:.1em; margin-top:6px; }
/* Scroll indicator — pill estilo Boono */
.gi-hero-strip .scroll{
  display:inline-flex; align-items:center; gap:14px;
  padding:8px 8px 8px 22px;
  border-radius:999px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(8px);
  color:#fff;
  font-family:"Inter Tight","Inter",sans-serif;
  font-size:.8rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.18em;
  text-decoration:none;
  transition: background .3s ease, border-color .3s ease, transform .3s ease, color .3s ease;
}
.gi-hero-strip .scroll:hover{
  background:var(--gi-orange);
  border-color:var(--gi-orange);
  transform:translateY(-2px);
  color:#fff;
}
.gi-hero-strip .scroll .arrow{
  width:40px; height:40px; border-radius:50%;
  background:var(--gi-orange);
  display:grid; place-items:center;
  color:#fff;
  transition: background .3s ease, color .3s ease, transform .3s ease;
}
.gi-hero-strip .scroll .arrow svg{
  animation: giBob 2.2s ease-in-out infinite;
}
.gi-hero-strip .scroll:hover .arrow{
  background:#fff;
  color:var(--gi-orange);
}
@keyframes giBob{
  0%, 100% { transform:translateY(0); }
  50%      { transform:translateY(5px); }
}

/* ==== SECTIONS ==== */
.gi-section{ padding:120px 40px; }
.gi-container{ max-width:1280px; margin:0 auto; }
.gi-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.78rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gi-orange); margin-bottom:18px;
}
.gi-eyebrow::before{ content:""; width:30px; height:1px; background:var(--gi-orange); }
.gi-h2{
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight:800; line-height:1.05; letter-spacing:-.02em;
  margin:0 0 24px; font-family:"Inter Tight","Inter",sans-serif;
}
.gi-h2 .ital{ font-style:italic; font-weight:400; color:var(--gi-orange); }
.gi-lead{ font-size:1.1rem; line-height:1.6; color:var(--gi-muted); max-width:720px; }

/* About strip */
.gi-about{ background:#fff; }
.gi-about-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:80px; align-items:center;
}
.gi-about-img{
  position:relative; aspect-ratio: 4/5; overflow:hidden; border-radius:18px;
  box-shadow: 0 30px 60px -25px rgba(0,0,0,0.25);
}
.gi-about-img img{
  width:100%; height:100%; object-fit:cover;
  transition: transform .8s ease;
}
.gi-about-img:hover img{ transform: scale(1.04); }
.gi-about-img::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,0.55) 100%);
  pointer-events:none;
}
.gi-about-img-badge{
  position:absolute; left:22px; bottom:22px; z-index:2;
  display:flex; flex-direction:column;
  padding:14px 20px; border-radius:14px;
  background:rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
  border-left:4px solid var(--gi-orange);
}
.gi-about-img-badge strong{
  font-family:"Inter Tight","Inter",sans-serif;
  font-size:1.05rem; font-weight:700; color:var(--gi-text);
}
.gi-about-img-badge span{
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gi-muted); margin-top:2px;
}
.gi-pill-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.gi-pill{
  padding:8px 16px; border-radius:999px;
  background:var(--gi-soft); color:var(--gi-text);
  font-size:.82rem; font-weight:500;
}

/* Services */
.gi-services{ background:var(--gi-dark); color:#fff; }
.gi-services .gi-h2{ color:#fff; }
.gi-services .gi-lead{ color:rgba(255,255,255,.7); }
.gi-service-grid{
  margin-top:60px;
  display:grid; grid-template-columns: repeat(3, 1fr); gap:20px;
}
.gi-service{
  position:relative;
  padding:40px 32px 32px;
  border-radius:18px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  transition: transform .35s ease, background .35s ease, border-color .35s ease;
  overflow:hidden;
  cursor:pointer;
}
.gi-service:hover{ background:var(--gi-orange); border-color:var(--gi-orange); transform:translateY(-6px); }
.gi-service .num{ display:none; }

/* Decorative themed background per service */
.gi-service::before{
  content:"";
  position:absolute;
  right:-20px; bottom:-20px;
  width:230px; height:230px;
  background-repeat:no-repeat;
  background-position: bottom right;
  background-size: contain;
  opacity:0.10;
  transition: opacity .4s ease, transform .5s ease;
  pointer-events:none;
  z-index:0;
}
.gi-service:hover::before{
  opacity:0.28;
  transform: translate(-6px,-6px) scale(1.04);
}
.gi-service > *{ position:relative; z-index:1; }

.gi-service:nth-child(1)::before{ background-image:url('../img/service-bg/web.svg'); }
.gi-service:nth-child(2)::before{ background-image:url('../img/service-bg/business.svg'); }
.gi-service:nth-child(3)::before{ background-image:url('../img/service-bg/marketing.svg'); }
.gi-service:nth-child(4)::before{ background-image:url('../img/service-bg/consulting.svg'); }
.gi-service:nth-child(5)::before{ background-image:url('../img/service-bg/visual.svg'); }
.gi-service:nth-child(6)::before{ background-image:url('../img/service-bg/mobile.svg'); }
.gi-service:nth-child(7)::before{ background-image:url('../img/service-bg/ai.svg'); }
.gi-service:nth-child(8)::before{ background-image:url('../img/service-bg/social.svg'); }
.gi-service:nth-child(9)::before{ background-image:url('../img/service-bg/saas.svg'); }
.gi-service h3{
  font-size:1.6rem; margin:18px 0 12px; font-weight:700;
}
.gi-service p{ color:rgba(255,255,255,.7); line-height:1.55; font-size:.96rem; }
.gi-service:hover p{ color:rgba(255,255,255,.95); }
.gi-service .icon{
  width:54px; height:54px; border-radius:14px;
  background:var(--gi-orange); display:grid; place-items:center; color:#fff;
  transition: background .3s;
}
.gi-service:hover .icon{ background:#fff; color:var(--gi-orange); }
.gi-service .icon svg{ width:26px; height:26px; }

/* Marquee */
.gi-marquee{
  background:var(--gi-orange); color:#fff; padding:24px 0; overflow:hidden;
  border-top:1px solid rgba(255,255,255,0.15);
  border-bottom:1px solid rgba(255,255,255,0.15);
}
.gi-marquee-track{
  display:flex; gap:60px; white-space:nowrap;
  animation: giMarquee 28s linear infinite;
  font-family:"Inter Tight","Inter",sans-serif;
  font-size:2.4rem; font-weight:700; letter-spacing:-.01em;
  text-transform:uppercase;
}
.gi-marquee-track span{ display:inline-flex; align-items:center; gap:60px; }
.gi-marquee-track .star{ color:#fff; }
@keyframes giMarquee{ to { transform:translateX(-50%); } }

/* Stats */
.gi-stats{ background:#fff; padding:80px 40px; }
.gi-stats-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:30px;
  text-align:center;
}
.gi-stat .n{ font-size:3.4rem; font-weight:800; color:var(--gi-orange); line-height:1; }
.gi-stat .l{ margin-top:10px; font-size:.9rem; color:var(--gi-muted); text-transform:uppercase; letter-spacing:.12em; }

/* Testimonials */
.gi-testi{ background:var(--gi-soft); }
.gi-testi-grid{
  margin-top:60px;
  display:grid; grid-template-columns: repeat(2, 1fr); gap:24px;
}
.gi-card{
  background:#fff; border-radius:18px; padding:34px;
  display:flex; flex-direction:column; gap:18px;
  border:1px solid rgba(0,0,0,0.06);
}
.gi-card p{ font-size:1.05rem; line-height:1.6; color:var(--gi-text); margin:0; }
.gi-card .who{ display:flex; align-items:center; gap:14px; margin-top:auto; }
.gi-card .who .av{
  width:46px; height:46px; border-radius:50%;
  background:var(--gi-orange); color:#fff; display:grid; place-items:center; font-weight:700;
}
.gi-card .who .meta strong{ display:block; font-size:.95rem; }
.gi-card .who .meta small{ color:var(--gi-muted); font-size:.82rem; }

/* Clientes */
.gi-clients{
  background:#fff; padding:100px 40px;
  border-top:1px solid rgba(0,0,0,0.06);
}
.gi-clients-head{ text-align:center; max-width:720px; margin:0 auto 60px; }
.gi-clients-head .gi-eyebrow{ justify-content:center; }
.gi-clients-head .gi-h2{ font-size: clamp(1.8rem, 4vw, 3rem); }
.gi-clients-head .gi-lead{ margin:0 auto; }
.gi-clients-grid{
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns: repeat(6, 1fr);
  gap:0;
  border-top:1px solid rgba(0,0,0,0.08);
  border-left:1px solid rgba(0,0,0,0.08);
}
.gi-client{
  display:grid; place-items:center;
  padding:32px 24px; min-height:160px;
  border-right:1px solid rgba(0,0,0,0.08);
  border-bottom:1px solid rgba(0,0,0,0.08);
  transition: background .3s ease;
  background:#fff;
}
.gi-client:hover{ background:var(--gi-soft); }
.gi-client img{
  max-width:80%;
  max-height:80px;
  width:auto; height:auto;
  object-fit: contain;
  filter: grayscale(1); opacity:.55;
  transition: filter .3s ease, opacity .3s ease, transform .3s ease;
}
.gi-client:hover img{
  filter: grayscale(0); opacity:1; transform:scale(1.05);
}
@media (max-width: 980px){
  .gi-clients{ padding:70px 22px; }
  .gi-clients-grid{ grid-template-columns: repeat(2, 1fr); }
}

/* CTA */
.gi-cta{
  background:var(--gi-dark); color:#fff;
  text-align:center; padding:140px 40px;
  position:relative; overflow:hidden;
}
.gi-cta-bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter: grayscale(0.2) brightness(0.45) saturate(1.05);
  transform:scale(1.04);
}
.gi-cta::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(70% 70% at 50% 0%, rgba(255,108,10,0.35), transparent 60%),
    linear-gradient(180deg, rgba(14,14,15,0.55) 0%, rgba(14,14,15,0.85) 100%);
}
.gi-cta-inner{ position:relative; z-index:2; max-width:880px; margin:0 auto; }
.gi-cta h2{
  font-size: clamp(2.2rem, 6vw, 5rem);
  font-weight:800; line-height:1; margin:0 0 30px;
  font-family:"Inter Tight","Inter",sans-serif;
}
.gi-cta h2 em{ color:var(--gi-orange); font-style:italic; font-weight:400; }
.gi-cta p{ color:rgba(255,255,255,0.75); font-size:1.1rem; line-height:1.6; margin:0 0 36px; }

/* Footer */
.gi-footer{
  background:#0a0a0b; color:#fff; padding:80px 40px 30px;
}
.gi-footer-grid{
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,0.1);
}
.gi-footer h4{
  font-size:.85rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,0.55); margin:0 0 18px; font-weight:600;
}
.gi-footer ul{ list-style:none; margin:0; padding:0; }
.gi-footer ul li{ margin-bottom:10px; }
.gi-footer a{ color:rgba(255,255,255,0.85); text-decoration:none; transition:color .2s; }
.gi-footer a:hover{ color:var(--gi-orange); }
.gi-footer .brand-block .brand{
  display:flex; align-items:center; margin-bottom:18px;
}
.gi-footer .brand-block .brand-logo{
  display:block; height:84px; width:auto;
}
.gi-footer .brand-block p{ color:rgba(255,255,255,0.65); line-height:1.6; font-size:.95rem; max-width:320px; }
.gi-footer-bottom{
  max-width:1280px; margin:30px auto 0;
  display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
  font-size:.85rem; color:rgba(255,255,255,0.5);
}

/* ==== Responsive ==== */
@media (max-width: 980px){
  .gi-nav{ padding:16px 22px; }
  .gi-nav ul{ display:none; }
  .gi-hero-content{ padding:120px 22px 50px; }
  .gi-section{ padding:80px 22px; }
  .gi-about-grid{ grid-template-columns:1fr; gap:40px; }
  .gi-service-grid{ grid-template-columns:1fr; }
  .gi-stats-grid{ grid-template-columns: repeat(2, 1fr); }
  .gi-testi-grid{ grid-template-columns:1fr; }
  .gi-footer-grid{ grid-template-columns: 1fr 1fr; }
  .gi-marquee-track{ font-size:1.6rem; gap:40px; }
}

/* Reveal on scroll */
.reveal{ opacity:0; transform:translateY(30px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity:1; transform:none; }
