/* ── NAV ACTIVE ── */
.nav-active { color: var(--white) !important; }
.nav-active::after { width: 100% !important; }

/* ── HERO SERVICIOS ── */
#svc-hero {
  position: relative; min-height: 85vh;
  display: flex; align-items: center; justify-content: center;
  padding: 8rem 5rem 5rem; overflow: hidden;
  background: var(--bg);
}
#svc-video {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center center;
  opacity: .28;
  filter: brightness(1.4) contrast(1.3);
}
.svc-video-overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to bottom, rgba(6,10,18,.75) 0%, rgba(6,10,18,.45) 40%, rgba(6,10,18,.85) 100%),
    linear-gradient(to right,  rgba(6,10,18,.6)  0%, transparent         60%);
}
.svc-hero-inner {
  position: relative; z-index: 3;
  max-width: 900px; text-align: center;
}
.svc-hero-title {
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  font-weight: 900; line-height: 1.05;
  letter-spacing: -.03em; margin-bottom: 1.5rem;
}
.svc-grad {
  display: block;
  background: linear-gradient(90deg, var(--blue) 0%, var(--cyan) 60%, #a5f3fc 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.svc-hero-sub {
  font-size: 1.05rem; color: var(--muted);
  max-width: 580px; margin: 0 auto 2.5rem;
  line-height: 1.75; font-weight: 300;
}

/* Tab navigation */
.svc-hero-tabs {
  display: flex; gap: .75rem;
  justify-content: center; flex-wrap: wrap;
}
.stab {
  background: transparent;
  border: 1px solid var(--border2);
  color: var(--muted); padding: .6rem 1.4rem;
  font-family: 'Outfit', sans-serif; font-size: .82rem;
  font-weight: 600; letter-spacing: .06em;
  cursor: pointer; transition: all .25s;
}
.stab:hover { border-color: var(--blue); color: var(--white); }
.stab.active {
  background: rgba(14,165,233,.12);
  border-color: var(--blue); color: var(--cyan);
}

/* ── SERVICE SECTIONS ── */
.svc-section { padding: 7rem 5rem; }
.svc-wrap { max-width: 1200px; margin: 0 auto; }
.svc-section-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 6rem; align-items: start;
}
.svc-section-grid.reverse { direction: rtl; }
.svc-section-grid.reverse > * { direction: ltr; }

.svc-desc {
  color: var(--muted); font-size: .97rem;
  line-height: 1.82; margin-bottom: 1.2rem;
}

/* Features list */
.svc-features {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: .6rem; margin-top: 1.8rem;
}
.svc-feat {
  display: flex; align-items: center; gap: .6rem;
  font-size: .85rem; color: var(--muted);
}
.svc-feat-dot {
  width: 6px; height: 6px; min-width: 6px;
  background: var(--cyan); border-radius: 50%;
  box-shadow: 0 0 8px var(--glow-c);
}

/* Visual column */
.svc-visual { display: flex; flex-direction: column; gap: 1.5rem; }
.svc-tech-stack, .svc-process {
  background: rgba(14,165,233,.04);
  border: 1px solid var(--border2);
  padding: 1.8rem 2rem;
}
.svc-stack-label {
  font-family: 'DM Mono', monospace; font-size: .62rem;
  color: var(--cyan); letter-spacing: .15em;
  text-transform: uppercase; margin-bottom: 1rem;
}
.svc-stack-tags {
  display: flex; flex-wrap: wrap; gap: .5rem;
}
.svc-stack-tags span {
  font-family: 'DM Mono', monospace; font-size: .7rem;
  padding: .3rem .8rem; border: 1px solid rgba(14,165,233,.25);
  color: rgba(14,165,233,.8); letter-spacing: .08em;
}

/* Steps */
.svc-steps { display: flex; flex-direction: column; gap: .8rem; }
.svc-step {
  display: flex; align-items: center; gap: 1rem;
  font-size: .88rem;
}
.svc-step span {
  font-family: 'DM Mono', monospace; font-size: .65rem;
  color: var(--cyan); min-width: 24px;
  letter-spacing: .1em;
}
.svc-step p { color: var(--muted); line-height: 1.5; }

/* Benefits grid */
.svc-benefits {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: var(--border2); outline: 1px solid var(--border2);
}
.svc-benefit {
  background: var(--bg2); padding: 1.5rem;
  text-align: center; transition: background .3s;
}
.svc-benefit:hover { background: var(--bg3); }
.sb-num {
  font-family: 'DM Mono', monospace; font-size: 1.8rem; font-weight: 500;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; line-height: 1; margin-bottom: .4rem;
}
.svc-benefit p { font-size: .75rem; color: var(--muted); line-height: 1.4; }

/* ── PORTAFOLIO ── */
.port-sub {
  font-size: 1rem; color: var(--muted);
  max-width: 500px; margin: 0 auto;
  line-height: 1.7;
}
.port-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}

/* Browser mockup card */
.port-card { display: flex; flex-direction: column; gap: 0; }
.port-browser {
  border: 1px solid var(--border2);
  overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.port-card:hover .port-browser {
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(14,165,233,.15);
}

/* Browser bar */
.port-browser-bar {
  background: var(--bg3);
  border-bottom: 1px solid var(--border2);
  padding: .6rem 1rem;
  display: flex; align-items: center; gap: .75rem;
}
.port-dots { display: flex; gap: .35rem; }
.port-dots span {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,.1);
}
.port-dots span:nth-child(1) { background: #ff5f57; }
.port-dots span:nth-child(2) { background: #febc2e; }
.port-dots span:nth-child(3) { background: #28c840; }
.port-url {
  flex: 1; font-family: 'DM Mono', monospace;
  font-size: .65rem; color: var(--muted);
  background: rgba(255,255,255,.05);
  padding: .25rem .75rem; letter-spacing: .04em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.port-browser-actions { display: flex; align-items: center; }
.port-visit {
  color: var(--muted); display: flex; align-items: center;
  transition: color .2s; cursor: pointer;
}
.port-visit svg { width: 14px; height: 14px; }
.port-visit:hover { color: var(--cyan); }

/* Screen */
.port-screen {
  position: relative; overflow: hidden;
  aspect-ratio: 16/9;
}
.port-screen img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top center;
  display: block;
  transition: transform .5s ease;
}
.port-card:hover .port-screen img { transform: scale(1.03); }
.port-screen-overlay {
  position: absolute; inset: 0;
  background: rgba(6,10,18,.7);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s;
}
.port-card:hover .port-screen-overlay { opacity: 1; }
.port-cta {
  color: var(--white); text-decoration: none;
  font-size: .88rem; font-weight: 700;
  letter-spacing: .08em; padding: .8rem 1.8rem;
  border: 1px solid rgba(34,211,238,.6);
  background: rgba(14,165,233,.15);
  transition: background .2s, box-shadow .2s;
}
.port-cta:hover {
  background: rgba(14,165,233,.3);
  box-shadow: 0 0 20px rgba(14,165,233,.3);
}

/* Card info */
.port-info {
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-top: none;
  padding: 1.2rem 1.4rem;
  display: flex; align-items: center;
  justify-content: space-between; gap: 1rem;
}
.port-info-left h3 {
  font-size: .95rem; font-weight: 700; margin-bottom: .2rem;
}
.port-info-left p {
  font-size: .75rem; color: var(--muted);
}
.port-tags { display: flex; gap: .4rem; flex-wrap: wrap; justify-content: flex-end; }
.port-tags span {
  font-family: 'DM Mono', monospace; font-size: .6rem;
  padding: .2rem .55rem; border: 1px solid rgba(14,165,233,.2);
  color: rgba(14,165,233,.6); letter-spacing: .08em;
  white-space: nowrap;
}


/* ══════════════════════════════════════════
   RESPONSIVE — SERVICIOS
══════════════════════════════════════════ */
@media (max-width: 1024px) {
  #svc-hero { padding: 7rem 2rem 4rem; min-height: 70vh; }
  .svc-hero-title { font-size: clamp(2rem, 5vw, 3.5rem); }
  .svc-section { padding: 5rem 2rem; }
  .svc-section-grid { grid-template-columns: 1fr; gap: 3rem; }
  .svc-section-grid.reverse { direction: ltr; }
  .svc-features { grid-template-columns: 1fr; }
  .svc-benefits { grid-template-columns: 1fr 1fr; }
  #svc-portfolio { padding: 5rem 2rem; }
  .port-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

@media (max-width: 768px) {
  #svc-hero { padding: 6rem 1.25rem 4rem; min-height: 75vh; }
  .svc-hero-title { font-size: clamp(1.9rem, 8vw, 3rem); }
  .svc-hero-sub { font-size: .95rem; }
  .svc-hero-tabs { flex-direction: column; align-items: center; }
  .stab { width: 100%; max-width: 300px; text-align: center; }
  .svc-section { padding: 4rem 1.25rem; }
  .svc-tech-stack, .svc-process { padding: 1.4rem; }
  #svc-portfolio { padding: 4rem 1.25rem; }
  .port-grid { grid-template-columns: 1fr; }
  .port-info { flex-direction: column; gap: .5rem; }
  .port-tags { justify-content: flex-start; }
  .svc-benefits { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 480px) {
  .svc-benefits { grid-template-columns: 1fr 1fr; }
  .sb-num { font-size: 1.4rem; }
  .port-grid { grid-template-columns: 1fr; }
}
