* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body, html {
  scroll-behavior: smooth;
  background: #050010;
  font-family: 'Segoe UI', sans-serif;
  overflow-x: hidden ;
}
/* Scrollbar para navegadores WebKit (Chrome, Edge, Safari) */
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: #0a001f;
  border-left: 1px solid #00f5ff11;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(to bottom, #00f5ff, #a033ff);
  border-radius: 20px;
  box-shadow: 0 0 10px #00f5ff;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(to bottom, #0ff, #c77dff);
}

/* Navbar */
/* Navbar base */
.navbar {
  position: fixed;
  top: 0;
  width: 100%;
  height: 70px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  box-shadow: 0 0 20px rgba(0, 245, 255, 0.3);
}
.navbar-container {
  width: 90%;
  max-width: 1300px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo {
  width:4.5rem;
  border-radius: 50%;
  color: #00f5ff;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-shadow: 0 0 10px #00f5ff;
}

/* Nav links desktop */
.nav-links {
  display: flex;
  gap: 35px;
}

.nav-links a {
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  font-size: 1rem;
  position: relative;
  padding: 6px 8px;
  transition: color 0.3s ease;
}

.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 100%;
  height: 2px;
  background: #00f5ff;
  box-shadow: 0 0 6px #00f5ff;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.3s ease;
}

.nav-links a:hover {
  color: #00f5ff;
}

.nav-links a:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* Hamburger button */
.menu-toggle {
  display: none;
  flex-direction: column;
  cursor: pointer;
  gap: 5px;
}

.menu-toggle span {
  width: 25px;
  height: 3px;
  background: #00f5ff;
  box-shadow: 0 0 6px #00f5ff;
  border-radius: 2px;
}

/* Responsive */
@media (max-width: 768px) {
  .menu-toggle {
    display: flex;
  }

  .nav-links {
    position: absolute;
    top: 70px;
    right: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.9);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 30px 0;
    transform: translateY(-200%);
    transition: transform 0.3s ease;
  }

  .nav-links.active {
    transform: translateY(0);
  }
}


.hero {
    padding-top: 80px;
  height: 100vh;
  width: 100%;
  background: radial-gradient(circle at center, #0a001f 10%, #000 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.moriah-circle {
  width: 100vmin;
  height: 100vmin;
  min-width: 120%;
  min-height: 120%;
  position: absolute;
  top: 54%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  background-color: transparent;
}

/* Animaciones ajustadas con transform-origin en % */
.circle-mid {
  animation: rotateCW 20s linear infinite;
  transform-origin: 50% 50%;
}

.circle-outer {
  animation: rotateCCW 30s linear infinite;
  transform-origin: 50% 50%;
}

.circle-lines {
  animation: rotateCW 28s linear infinite;
  transform-origin: 50% 50%;
}

@keyframes rotateCW {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes rotateCCW {
  from { transform: rotate(360deg); }
  to   { transform: rotate(0deg); }
}
/* TEXTO */
.hero-text {
  position: relative;
  text-align: center;
  z-index: 2;
  animation: fadeInText 1.2s ease-out forwards;
  opacity: 0;
}

@keyframes fadeInText {
  to { opacity: 1; }
}

.hero-text h1 {
  font-size: 4.6rem;
  letter-spacing: 3px;
  color: #00f5ff;
  text-shadow: 0 0 20px #00f5ff;
}

.hero-text p {
  font-size: 1.6rem;
  color: #aaf7ff;
  margin-top: 5px;
  text-shadow: 0 0 12px #aaf7ff;
}

.cta {
  font-size: 1rem;
  display: inline-block;
  margin-top: 25px;
  padding: 10px 25px;
  background: #00f5ff;
  color: #000;
  font-weight: bold;
  border-radius: 30px;
  box-shadow: 0 0 20px #00f5ff;
  text-decoration: none;
  transition: 0.3s ease;
}

.cta:hover {
  background: #0ff;
  box-shadow: 0 0 30px #00f5ff;
}
#circuitCanvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
  background: transparent;
}

@media (max-width: 600px) {
  .hero-text h1 {
    font-size: 2.8rem;
  }

  .hero-text p {
    font-size: 1.2rem;
  }

  .cta {
    font-size: 0.9rem;
    padding: 10px 25px;
    
  }
}
.team-info {
  background: linear-gradient(180deg, #050014, #000);
  color: #fff;
  padding: 120px 20px;
  text-align: center;
  position: relative;
  z-index: 1;
  overflow: hidden;
  font-family: 'Orbitron', sans-serif;
}

.team-info h2 {
  font-size: 3rem;
  color: #00f5ff;
  text-shadow: 0 0 16px #00f5ff;
  margin-bottom: 30px;
  opacity: 0;
  transform: translateY(40px);
  transition: all 0.8s ease;
  position: relative;
}

/* Glitch effect */
.glitch-title::before,
.glitch-title::after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  color: #00f5ff;
  width: 100%;
  overflow: hidden;
  clip: rect(0, 900px, 0, 0);
  animation: glitch 2s infinite linear alternate-reverse;
}

.glitch-title::before {
  text-shadow: -2px 0 magenta;
  animation-delay: 0.2s;
}

.glitch-title::after {
  text-shadow: 2px 0 cyan;
  animation-delay: 0.4s;
}

@keyframes glitch {
  0% { clip: rect(42px, 9999px, 44px, 0); }
  20% { clip: rect(12px, 9999px, 56px, 0); }
  40% { clip: rect(60px, 9999px, 72px, 0); }
  60% { clip: rect(30px, 9999px, 40px, 0); }
  80% { clip: rect(15px, 9999px, 28px, 0); }
  100% { clip: rect(72px, 9999px, 80px, 0); }
}

.team-info p {
  max-width: 720px;
  margin: 0 auto;
  font-size: 1.1rem;
  line-height: 2;
  opacity: 0;
  transform: translateY(40px);
  transition: all 1.2s ease 0.2s;
  color: #d0d0d0;
}

.team-info .highlight {
  color: #00f5ff;
  text-shadow: 0 0 5px #00f5ff;
}

.glow-block {
  display: inline-block;
  padding: 10px;
  border: 1px solid #a033ff;
  border-radius: 10px;
  margin: 20px 0;
  box-shadow: 0 0 18px #a033ff66;
  background: rgba(160, 51, 255, 0.1);
}

.glow-punch {
  display: block;
  margin-top: 20px;
  font-size: 1.2rem;
  color: #fff;
  text-shadow: 0 0 10px #a033ff, 0 0 30px #00f5ff;
}

.glow-punch span {
  color: #ff00ff;
  text-shadow: 0 0 10px #ff00ff;
}

/* Scroll animations */
.scroll-animate.show {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

.scroll-animate.delay {
  transition-delay: 0.3s;
}

@media (max-width: 600px) {
  .team-info h2 {
    font-size: 2.3rem;
  }

  .team-info p {
    font-size: 0.95rem;
  }

  .glow-punch {
    font-size: 1rem;
  }
}
.svg-lines {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

.svg-lines line {
  stroke: #00f5ff;
  stroke-width: 0.6;
  stroke-dasharray: 6 12;
  animation: dashFlow 4s linear infinite;
  opacity: 0.3;
}

@keyframes dashFlow {
  to {
    stroke-dashoffset: -100;
  }
}

/* Animación de entrada */
.fade-in-up {
  opacity: 0;
  transform: translateY(40px);
  transition: all 0.8s ease-out;
}

.fade-in-up.show {
  opacity: 1;
  transform: translateY(0);
}
.projects {
  background: linear-gradient(180deg, #0a001f, #000);
  padding: 100px 20px;
  text-align: center;
  color: #fff;
  position: relative;
  z-index: 1;
}

.projects .section-title {
  font-size: 3rem;
  margin-bottom: 10px;
  color: #00f5ff;
  text-shadow: 0 0 10px #00f5ff;
}

.projects .section-title span {
  color: #a033ff;
}

.projects .section-subtitle {
  font-size: 1.2rem;
  color: #ccc;
  margin-bottom: 60px;
}

.project-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  justify-content: center;
}

.project-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  backdrop-filter: blur(10px);
  box-shadow: 0 0 25px rgba(0,245,255,0.08);
  padding: 20px;
  width: 340px;
  transition: 0.4s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.project-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 0 30px rgba(0,245,255,0.3);
}

.project-card iframe {
  width: 100%;
  height: 280px;
  border: none;
  border-radius: 10px;
  margin-bottom: 15px;
  filter: drop-shadow(0 0 6px rgba(0, 245, 255, 0.2));
  transition: 0.3s ease;
  pointer-events: auto; /* permite interactuar */
}

.project-card h3 {
  font-size: 1.4rem;
  color: #00f5ff;
  margin-bottom: 5px;
}

.project-card p {
  font-size: 0.95rem;
  color: #ccc;
  text-align: center;
  margin-bottom: 15px;
}

.visit-btn {
  display: inline-block;
  padding: 10px 20px;
  background: #00f5ff;
  color: #000;
  font-weight: bold;
  border-radius: 30px;
  box-shadow: 0 0 15px #00f5ff;
  text-decoration: none;
  transition: 0.3s ease;
}

.visit-btn:hover {
  background: #0ff;
  box-shadow: 0 0 25px #00f5ff;
}


.preview-card iframe {
  width: 100%;
  height: 180px;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px 10px 0 0;
  filter: drop-shadow(0 0 6px rgba(0, 245, 255, 0.15));
  transition: filter 0.4s ease;
  pointer-events: none;
}

.preview-card:hover iframe {
  filter: drop-shadow(0 0 12px rgba(0, 245, 255, 0.4));
}
/* Fondo ahora ESTÁTICO (sin animación) */
.neon-projects::before,
.neon-projects::after{ animation: none !important; }

/* Carrusel */
.prj-viewport{ position:relative; max-width:1200px; margin:0 auto; z-index:1; }
.prj-track{
  display:flex; gap:32px;
  overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
  padding:6px 6px 12px;
}
.prj-track::-webkit-scrollbar{ height:10px; }
.prj-track::-webkit-scrollbar-thumb{
  background:linear-gradient(90deg,#00f5ff,#a033ff); border-radius:10px;
}

.prj-card{
  flex:0 0 86%;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  backdrop-filter: blur(10px);
  box-shadow: 0 0 22px rgba(0,245,255,0.08);
  padding: 18px; scroll-snap-align: center;
  transition: transform .3s ease, box-shadow .3s ease;
}
.prj-card:hover{ transform:translateY(-6px); box-shadow:0 0 30px rgba(0,245,255,0.28); }

.prj-preview{
  position:relative; border-radius:10px; overflow:hidden;
  background:#0a0016; cursor:pointer;
}
.prj-thumb{
  width:100%; height:220px; object-fit:cover; display:block;
  filter: drop-shadow(0 0 6px rgba(0,245,255,0.15));
}
.prj-zoom-ico{
  position:absolute; right:10px; top:10px;
  display:grid; place-items:center; width:40px; height:40px;
  background:rgba(0,0,0,.55); color:#00f5ff; font-size:20px;
  border-radius:50%; box-shadow:0 0 12px rgba(0,245,255,.6);
}

.prj-card h3{ font-size:1.25rem; color:#00f5ff; margin:.8rem 0 .3rem; }
.prj-card p{ color:#cfcfcf; font-size:.95rem; margin-bottom:.7rem; }

.visit-btn{
  display:inline-block; padding:10px 20px; border-radius:30px; font-weight:700;
  background:#00f5ff; color:#000; text-decoration:none;
  box-shadow:0 0 15px #00f5ff; transition:.25s ease;
}
.visit-btn:hover{ background:#0ff; box-shadow:0 0 25px #00f5ff; }

/* Flechas: ocultas en desktop, visibles en mobile */
.prj-arrow{
  position:absolute; top:42%; transform:translateY(-50%);
  background:rgba(0,0,0,.6); border:none; color:#00f5ff;
  font-size:2rem; cursor:pointer; z-index:2; padding:10px 16px;
  border-radius:50%; box-shadow:0 0 12px rgba(0,245,255,.6);
}
.prj-prev{ left:-6px; } .prj-next{ right:-6px; }
@media (min-width: 900px){ .prj-arrow{ display:none; } }
@media (min-width: 900px){ .prj-card{ flex:0 0 calc(33.333% - 22px); } }
button.visit-btn{
  border: 0;
  cursor: pointer;
}
button.visit-btn:focus-visible,
.prj-preview:focus-visible{
  outline: 2px solid #00f5ff;
  outline-offset: 3px;
  box-shadow: 0 0 12px #00f5ff88;
}

/* Modal */
.prj-modal{ position:fixed; inset:0; display:none; z-index:9999; }
.prj-modal.is-open{ display:block; }
.prj-modal__backdrop{
  position:absolute; inset:0; backdrop-filter: blur(4px);
  background:rgba(0,0,0,.65);
}
.prj-modal__dialog{
  position:absolute; inset:5% 3%; border-radius:14px; overflow:hidden;
  background:#060312; border:1px solid rgba(255,255,255,.1);
  box-shadow: 0 0 40px rgba(0,245,255,.25);
  display:flex; flex-direction:column;
}
.prj-close{
  position:absolute; top:10px; right:12px; z-index:3;
  width:42px; height:42px; border:none; border-radius:50%;
  background:rgba(0,0,0,.55); color:#00f5ff; font-size:20px; cursor:pointer;
  box-shadow:0 0 12px rgba(0,245,255,.6);
}
#prjIframe{ flex:1 1 auto; width:100%; border:none; background:#0a0016; z-index:2; }

/* Spinner de carga */
.prj-spinner{
  position:absolute; inset:0; z-index:1; display:grid; place-items:center;
  background:linear-gradient(180deg,#050014,#000000);
}
.prj-spinner::after{
  content:""; width:56px; height:56px; border-radius:50%;
  border:4px solid #00f5ff55; border-top-color:#00f5ff; animation:spin 1s linear infinite;
  box-shadow:0 0 18px #00f5ff66;
}
@keyframes spin{ to{ transform:rotate(360deg);} }

body.prj-modal-open{ overflow:hidden; }

.fade-in-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s ease, transform 1s ease;
}

.fade-in-up.in-view {
  opacity: 1;
  transform: translateY(0);
}
.quote-section {
  background: linear-gradient(180deg, #0a001f, #000010);
  padding: 100px 20px;
  text-align: center;
  color: #fff;
  position: relative;
  z-index: 1;
}

.quote-title {
  font-size: 2.8rem;
  color: #00f5ff;
  margin-bottom: 10px;
  text-shadow: 0 0 12px #00f5ff;
}

.quote-title span {
  color: #a033ff;
}

.quote-desc {
  color: #aaa;
  font-size: 1.1rem;
  margin-bottom: 40px;
  max-width: 600px;
  margin-inline: auto;
}

.quote-form {
  max-width: 600px;
  margin: auto;
  display: grid;
  gap: 20px;
}
.quote-form select {
  width: 100%;
  padding: 14px 16px;
  padding-right: 40px;
  background-color: #0a001f;
  color: #fff;
  border: 1px solid #00f5ff;
  border-radius: 8px;
  font-size: 1rem;
  font-family: 'Segoe UI', sans-serif;
  box-shadow: 0 0 8px rgba(0, 245, 255, 0.5);
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg fill='cyan' height='20' viewBox='0 0 24 24' width='20' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 16px 16px;
  cursor: pointer;
}

.quote-form select:focus {
  outline: none;
  border-color: #00f5ff;
  box-shadow: 0 0 12px #00f5ff;
}

.quote-form option {
  background-color: #0a001f;
  color: #fff;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 14px 18px;
  border-radius: 10px;
  border: 1px solid rgba(0,245,255,0.15);
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(10px);
  color: #fff;
  font-size: 1rem;
  outline: none;
  transition: border 0.3s ease;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: #00f5ff;
  box-shadow: 0 0 10px #00f5ff77;
}

.submit-btn {
  padding: 14px 25px;
  border: none;
  border-radius: 30px;
  background: #00f5ff;
  color: #000;
  font-weight: bold;
  font-size: 1rem;
  cursor: pointer;
  transition: 0.3s ease;
  box-shadow: 0 0 20px #00f5ff99;
}

.submit-btn:hover {
  background: #0ff;
  box-shadow: 0 0 30px #00f5ff;
}

/* Responsive */
@media (max-width: 600px) {
  .quote-title {
    font-size: 2.2rem;
  }
  .quote-desc {
    font-size: 1rem;
  }
}
/* SVG input styles */
.icon-input {
  position: relative;
}

.icon-input svg {
  width: 22px;
  height: 22px;
  position: absolute;
  top: 14px;
  left: 14px;
  animation: glow 2s infinite alternate;
  z-index: 100000;
}

.icon-input input,
.icon-input textarea,
.icon-input select {
  padding-left: 45px !important;
}

/* MODAL */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.modal-content {
  background: #111;
  padding: 40px;
  border-radius: 12px;
  text-align: center;
  color: #00f5ff;
  box-shadow: 0 0 30px #00f5ff88;
  animation: fadeInScale 0.5s ease forwards;
}

@keyframes fadeInScale {
  0% {
    opacity: 0;
    transform: scale(0.85);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes glow {
  from { filter: drop-shadow(0 0 2px #00f5ff); }
  to   { filter: drop-shadow(0 0 6px #a033ff); }
}

.pricing-plans-section {
  background: linear-gradient(180deg, #000010, #0a001f);
  color: #fff;
  padding: 100px 20px;
  text-align: center;
}

.section-title {
  font-size: 3rem;
  color: #00f5ff;
  margin-bottom: 10px;
  text-shadow: 0 0 10px #00f5ff;
}

.section-desc {
  max-width: 700px;
  margin: 0 auto 50px;
  font-size: 1.1rem;
  color: #aaa;
}

.plan-group {
  margin-bottom: 60px;
}

.plan-category {
  font-size: 2rem;
  margin-bottom: 20px;
  color: #a033ff;
  text-shadow: 0 0 6px #a033ff;
}

.plans-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}

.plan-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 30px 20px;
  width: 300px;
  box-shadow: 0 0 20px rgba(0,245,255,0.05);
  transition: 0.3s ease;
}

.plan-card.popular {
  border-color: #00f5ff;
  box-shadow: 0 0 30px rgba(0,245,255,0.2);
}

.plan-card h4 {
  font-size: 1.4rem;
  margin-bottom: 10px;
  color: #00f5ff;
}

.plan-card .price {
  font-size: 1.2rem;
  margin-bottom: 15px;
  color: #aaf7ff;
}

.plan-card .price span {
  font-size: 0.9rem;
  color: #bbb;
}

.plan-card ul {
  list-style: none;
  padding: 0;
  color: #ccc;
  font-size: 0.95rem;
}

.plan-card li {
  margin-bottom: 8px;
}

.note, .final-note {
  font-size: 0.85rem;
  color: #888;
  margin-top: 10px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.footer {
  background: radial-gradient(ellipse at top, #0a001f 0%, #000 100%);
  color: #aaf7ff;
  padding: 60px 20px 30px;
  font-size: 0.95rem;
  text-shadow: 0 0 4px #00f5ff20;
}

.footer-container {
  max-width: 1200px;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 40px;
}

.footer img {
  width: 5rem;
  border-radius: 50%;
  font-size: 2rem;
  color: #00f5ff;
  text-shadow: 0 0 12px #00f5ff;
}
.footer h2{
  font-size: 2rem;
  color: #00f5ff;
  text-shadow: 0 0 12px #00f5ff;
}

.footer h4 {
  color: #a033ff;
  margin-bottom: 15px;
  font-size: 1.1rem;
}

.footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer ul li {
  margin-bottom: 8px;
}

.footer a {
  color: #aaf7ff;
  text-decoration: none;
  transition: 0.3s;
}

.footer a:hover {
  color: #00f5ff;
  text-shadow: 0 0 6px #00f5ff;
}

.footer-brand {
  max-width: 280px;
}

.footer-socials {
  display: flex;
  justify-content: center;
  gap: 30px;
}

.footer-socials a svg {
  width: 30px;
  height: 30px;
  transition: transform 0.3s ease, filter 0.3s ease;
  filter: drop-shadow(0 0 5px #00f5ff);
}

.footer-socials a:hover svg {
  transform: scale(1.2);
  filter: drop-shadow(0 0 15px #00f5ff);
}

.footer-bottom {
  margin-top: 40px;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 20px;
  color: #777;
}
/* ====== Servicios v2 (mobile-first, sin scroll-snap) ====== */
.svc2-section{
  padding:100px 20px;
  background:linear-gradient(to bottom,#0a001f,#000010);
  color:#fff; text-align:center; position:relative; overflow:hidden;
}

.svc2-title h2{font-size:2.6rem;margin-bottom:15px;color:#00f5ff;text-shadow:0 0 12px #00f5ff;}
.svc2-title h2 span{color:#a033ff;}
.svc2-title p{max-width:800px;margin:0 auto 50px;font-size:1.1rem;color:#ccc;line-height:1.6;}

.svc2-viewport{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  overflow:hidden;               /* móvil: ocultamos lo que sale */
}

.svc2-glow{
  position:absolute; top:20%; left:50%; width:800px; height:400px;
  transform:translateX(-50%); opacity:.35; pointer-events:none; z-index:0;
}

/* Móvil: slider controlado por --svc2x */
.svc2-track{
  display:flex; align-items:stretch;
  transform: translateX(var(--svc2x, 0%));
  transition: transform .4s ease;
  will-change: transform;
  position:relative; z-index:1;
  gap:0;
}

.svc2-slide{
  flex: 0 0 100%;
  min-width:100%;
  padding:28px 22px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:16px;
  backdrop-filter:blur(10px);
  box-shadow:0 0 25px rgba(0,245,255,0.08);
}

.svc2-slide img{width:64px; margin-bottom:16px; filter:drop-shadow(0 0 6px #00f5ff);}
.svc2-slide h3{font-size:1.25rem; margin-bottom:10px; color:#00f5ff;}
.svc2-slide p{font-size:.95rem; color:#aaa;}

/* Flechas (solo visibles en móvil) */
.svc2-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(0,0,0,.6); border:none; color:#00f5ff;
  font-size:1.8rem; cursor:pointer; z-index:2; padding:8px 14px;
  border-radius:50%; box-shadow:0 0 12px rgba(0,245,255,.6);
}
.svc2-prev{ left:8px; }
.svc2-next{ right:8px; }
.svc2-arrow:disabled{ opacity:.35; pointer-events:none; box-shadow:none; }

/* Semánticas (por si querés diferenciar inicio/fin) */
.svc2-slide.svc2-first{ outline:0; }
.svc2-slide.svc2-last{  outline:0; }

/* Seguridad: evita “scroll anchoring” */
.svc2-track, .svc2-track * { overflow-anchor: none; }

/* ===== Desktop (>=769px): grilla fluida sin recortes ===== */
@media (min-width:769px){
  .svc2-viewport{ overflow: visible; } /* ya no ocultamos nada */

  .svc2-track{
    transform:none !important;
    transition:none !important;
    display:grid !important;
    gap:40px;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    align-items:stretch;
    justify-items:stretch;
  }
  /* Si preferís 4 fijas:  grid-template-columns: repeat(4, minmax(260px, 1fr)); */

  .svc2-slide{
    flex:unset;
    min-width:0;   /* evita overflow por textos largos */
    width:auto;
  }

  .svc2-arrow{ display:none !important; } /* flechas fuera en desktop */
}
/* ===== Desktop (>=769px): filas centradas ===== */
@media (min-width:769px){
  .svc2-viewport{ overflow: visible; }

  .svc2-track{
    transform:none !important;
    transition:none !important;
    display:flex !important;
    flex-wrap:wrap;
    gap:40px;
    justify-content:center; /* <- centra la última fila */
    align-items:stretch;
  }

  .svc2-slide{
    /* ancho flexible por card */
    flex: 1 1 clamp(260px, 22vw, 320px);
    min-width:260px;
    max-width:360px; /* opcional, tope */
  }

  .svc2-arrow{ display:none !important; }
}
/* === Presupuesto: layout con robot === */
.quote-layout{
  display:grid;
  grid-template-columns: 360px 1fr;   /* robot | formulario */
  gap: 32px;
  align-items: start;
  margin-top: 10px;
}
.quote-robot{
  justify-self:center;
  position: sticky;
  top: 110px;               /* visible mientras se completa */
  z-index: 2;
  filter: drop-shadow(0 0 12px rgba(0,245,255,.35));
  transition: transform .35s ease;
}
.quote-robot:hover{ transform: translateY(-3px); }

/* Robot flotando más feliz durante el “cheer” */
.quote-robot.is-cheering #robotFloat{
  animation: robot-bounce .5s ease-in-out infinite alternate;
}
@keyframes robot-bounce{
  from{ transform: translateY(-6px); }
  to  { transform: translateY( 6px); }
}

/* Cuando se abre el modal, traigo el robot al frente (esquina) */
body.modal-open .quote-robot{
  position: fixed;
  right: 24px;
  bottom: 24px;
  top: auto;
  transform: scale(.9);
  z-index: 10001;
}

/* Responsive */
@media (max-width: 900px){
  .quote-layout{ grid-template-columns: 1fr; }
  .quote-robot{ order: 2; position: static; margin-top: 26px; }
  body.modal-open .quote-robot{ right: 8px; bottom: 8px; transform: scale(.8); }
}
/* === Presupuesto: inputs más largos y altos === */

/* La columna del formulario ahora es más ancha */
.quote-layout{
  grid-template-columns: 360px minmax(720px, 1fr);
  gap: 36px;
}
@media (min-width: 1200px){
  .quote-layout{
    grid-template-columns: 360px minmax(820px, 1fr);
  }
}

/* El formulario usa todo el ancho de su columna */
.quote-form{
  max-width: none !important;
  width: 100%;
}

/* Altura y tipografía de los campos */
.form-group input,
.form-group select,
.form-group textarea{
  padding: 16px 22px 16px 48px;   /* deja espacio al ícono */
  font-size: 1.05rem;
  min-height: 56px;               /* +alto */
  border-radius: 12px;
}

/* Ajusto la posición del ícono */
.icon-input svg{
  top: 16px;                      /* acompaña la nueva altura */
}

/* Select con la misma altura visual */
.quote-form select{
  padding: 16px 48px 16px 48px;   /* mismo padding que inputs */
}

/* Textarea un poco más alto por defecto */
.form-group textarea{
  min-height: 160px;
}

/* Botón más grande y ancho */
.submit-btn{
  height: 56px;
  font-size: 1.1rem;
  padding: 0 28px;
  border-radius: 40px;
  width: 100%;                    /* que ocupe el ancho del form */
  max-width: 480px;               /* si lo querés limitar, cambiá este valor */
  justify-self: start;            /* alineado a la izquierda del form */
}

/* En móvil mantenemos la pila normal */
@media (max-width: 900px){
  .quote-layout{ grid-template-columns: 1fr; gap: 24px; }
  .submit-btn{ max-width: 100%; }
}
/* === Presupuesto: limitar el largo de los campos (solo desktop) === */
:root{
  /* Cambiá este número para más/menos ancho (700–820px suele verse bien) */
  --quote-field-max: 760px;
}

@media (min-width: 992px){
  /* el form no ocupa toda la columna */
  .quote-form{
    max-width: var(--quote-field-max);
    width: 100%;
    justify-self: start;   /* por si estás usando grid, lo alinea a la izquierda */
  }

  /* que el botón siga el mismo ancho que los campos */
  .submit-btn{
    width: 100%;
    max-width: var(--quote-field-max);
  }
}
/* ===== Testimonios (prefijo rvw-) ===== */
.rvw-section{
  background: linear-gradient(180deg,#000010,#0a001f);
  color:#fff; padding:90px 20px; position:relative; overflow:hidden;
}
.rvw-title{font-size:2.4rem; color:#00f5ff; text-shadow:0 0 12px #00f5ff; margin:0;}
.rvw-title span{color:#a033ff;}
.rvw-header{display:flex; align-items:center; justify-content:space-between; gap:20px; margin:0 auto 30px; max-width:1200px;}
.rvw-add-btn{
  padding:12px 18px; border-radius:999px; border:0; cursor:pointer; font-weight:700;
  background:#00f5ff; color:#000; box-shadow:0 0 18px #00f5ff88; transition:transform .15s ease, box-shadow .2s ease;
}
.rvw-add-btn:hover{ transform:translateY(-1px); box-shadow:0 0 26px #00f5ffcc; }
.rvw-add-btn:focus-visible{ outline:2px solid #00f5ff; outline-offset:3px; }

.rvw-list{
  max-width:1200px; margin:0 auto;
  display:grid; gap:28px;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}

.rvw-card{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px; padding:18px; backdrop-filter: blur(10px);
  box-shadow:0 0 22px rgba(0,245,255,0.08); transition:.25s ease;
  display:flex; flex-direction:column; gap:12px; min-height:220px;
}
.rvw-card:hover{ transform:translateY(-4px); box-shadow:0 0 26px rgba(0,245,255,0.22); }

.rvw-head{ display:flex; align-items:center; gap:12px; }
.rvw-avatar{
  width:54px; height:54px; border-radius:50%; object-fit:cover; display:block;
  border:2px solid #00f5ff66; box-shadow:0 0 12px #00f5ff55;
  background: radial-gradient(circle at 30% 20%, #e9f7ff, #cfe3f3 70%);
}
.rvw-name{ font-weight:700; color:#aaf7ff; }
.rvw-date{ font-size:.8rem; color:#8abbd0; }

.rvw-stars-read{ letter-spacing:2px; color:#21d0ff; text-shadow:0 0 10px #00f5ff88; }

.rvw-text{ color:#d7e7ef; line-height:1.6; }

/* Modal */
.rvw-modal{ position:fixed; inset:0; display:none; z-index:9999; }
.rvw-modal.show{ display:block; }
.rvw-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.6); backdrop-filter: blur(2px); }
.rvw-dialog{
  position:relative; margin:8vh auto; max-width:640px; width:92%;
  background:#0c0f1a; border:1px solid #1b2a3b; border-radius:16px; padding:22px;
  box-shadow:0 0 32px #00f5ff55;
}
.rvw-close{
  position:absolute; top:10px; right:12px; width:36px; height:36px; border-radius:50%;
  border:1px solid #00f5ff66; background:#07101a; color:#aaf7ff; font-size:22px; cursor:pointer;
}
.rvw-close:hover{ box-shadow:0 0 14px #00f5ffbb; }

.rvw-form{ display:grid; gap:16px; }
.rvw-field span{ display:block; color:#aaf7ff; margin-bottom:8px; }
.rvw-field input[type="text"], .rvw-field textarea{
  width:100%; padding:14px 16px; border-radius:10px; border:1px solid rgba(0,245,255,.15);
  background: rgba(255,255,255,0.05); color:#fff; outline:none; transition:border .2s ease;
}
.rvw-field input:focus, .rvw-field textarea:focus{ border-color:#00f5ff; box-shadow:0 0 10px #00f5ff77; }

.rvw-stars{ display:flex; gap:6px; }
.rvw-star{
  font-size:26px; line-height:1; background:transparent; border:0; cursor:pointer; color:#406b7a;
  text-shadow:0 0 4px #0cf2ff22;
}
.rvw-star.is-on{ color:#19d8ff; text-shadow:0 0 10px #00f5ffcc; }

.rvw-photo-row{ display:flex; gap:16px; align-items:flex-end; }
.rvw-photo-field input{ display:block; }
.rvw-avatar-preview{
  width:70px; height:70px; border-radius:50%; border:2px solid #00f5ff77; box-shadow:0 0 12px #00f5ff66;
  display:grid; place-items:center; overflow:hidden; background:#0b1a27;
}
.rvw-avatar-preview img{ width:100%; height:100%; object-fit:cover; display:none; }
.rvw-avatar-fallback{ color:#9feaff; font-size:28px; }

.rvw-actions{ display:flex; justify-content:flex-end; }
.rvw-submit{
  padding:12px 18px; border-radius:999px; border:0; background:#00f5ff; color:#000; font-weight:800; cursor:pointer;
  box-shadow:0 0 18px #00f5ff99;
}
.rvw-submit:hover{ box-shadow:0 0 24px #00f5ffdd; }

@media (max-width:640px){
  .rvw-header{ flex-direction:column; align-items:flex-start; }
  .rvw-photo-row{ align-items:center; }
}
/* --- cabecera botones --- */
.rvw-cta-row{ display:flex; gap:12px; align-items:center; }
.rvw-admin-btn{
  padding:10px 14px; border-radius:999px; border:1px solid #00f5ff66;
  background:#08131e; color:#aaf7ff; font-weight:700; cursor:pointer;
  box-shadow:0 0 10px #00f5ff44; transition:box-shadow .2s, transform .15s;
}
.rvw-admin-btn[aria-pressed="true"]{ color:#000; background:#00f5ff; border-color:#00f5ff; }
.rvw-admin-btn:hover{ transform:translateY(-1px); box-shadow:0 0 18px #00f5ff99; }

/* --- slider --- */
.rvw-slider{ position:relative; max-width:1200px; margin:10px auto 0; }
.rvw-track{
  display:flex; gap:24px; align-items:stretch;
  overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
  padding:6px 6px 12px;
}
.rvw-track::-webkit-scrollbar{ height:8px; }
.rvw-track::-webkit-scrollbar-thumb{ background:linear-gradient(90deg,#00f5ff,#a033ff); border-radius:8px; }
.rvw-card{ scroll-snap-align:start; min-width:340px; max-width:380px; }

/* responsive: 1 tarjeta en móviles, 2 en tablets */
@media (max-width:900px){ .rvw-card{ min-width:70vw; max-width:70vw; } }
@media (max-width:600px){ .rvw-card{ min-width:86vw; max-width:86vw; } }

/* flechas */
.rvw-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border-radius:50%; border:1px solid #00f5ff77;
  background:#07101a; color:#aaf7ff; font-size:26px; cursor:pointer; z-index:2;
  box-shadow:0 0 14px #00f5ff66;
  display:none;  /* solo si hay overflow */
}
.rvw-prev{ left:-4px; }
.rvw-next{ right:-4px; }
.rvw-nav:hover{ box-shadow:0 0 20px #00f5ffdd; }

/* botón borrar en modo admin */
.rvw-del{
  margin-left:auto; border:1px solid #ff5c5c88; color:#ffbbbb;
  background:#2a0b12; width:34px; height:34px; border-radius:10px;
  display:none; place-items:center; cursor:pointer;
}
.rvw-del:hover{ box-shadow:0 0 12px #ff6b6b; }

/* cuando admin ON, mostrar borrar */
.rvw-admin-on .rvw-del{ display:grid; }
/* Ocultar el botón admin si quedó en tu HTML */
.rvw-admin-btn{ display:none !important; }

/* Toast chiquito para avisos Admin ON/OFF */
.rvw-toast{
  position:fixed; top:16px; right:16px; z-index:9999;
  background:#04121d; color:#aaf7ff; border:1px solid #00f5ff55;
  padding:10px 14px; border-radius:10px; box-shadow:0 0 14px #00f5ff66;
  opacity:0; transform:translateY(-6px); transition:opacity .2s, transform .2s;
}
.rvw-toast.show{ opacity:1; transform:translateY(0); }
/* ==== Reviews – estilos mínimos ==== */
.reviews{background:linear-gradient(180deg,#000010,#0a001f);color:#fff;padding:90px 20px;position:relative;z-index:1}
.rvw-head{max-width:1200px;margin:0 auto 24px;display:flex;align-items:center;justify-content:space-between}
.rvw-title{font-size:2.4rem;color:#00f5ff;text-shadow:0 0 12px #00f5ff}
.rvw-title span{color:#a033ff}
.rvw-add{padding:10px 16px;border-radius:999px;border:1px solid #00f5ff;background:#001018;color:#00f5ff;font-weight:700;box-shadow:0 0 14px #00f5ff66}
.rvw-add:hover{background:#00222a}

.rvw-slider{max-width:1200px;margin:0 auto;position:relative}
.rvw-track{display:flex;gap:28px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 12px;-webkit-overflow-scrolling:touch}
.rvw-track::-webkit-scrollbar{height:8px}
.rvw-track::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#00f5ff,#a033ff);border-radius:8px}

.rvw-card{flex:0 0 clamp(280px,32vw,380px);scroll-snap-align:start;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;backdrop-filter:blur(10px);box-shadow:0 0 25px rgba(0,245,255,.08)}
.rvw-card-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.rvw-avatar{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#e6f9ff,#bde7ff);display:grid;place-items:center;box-shadow:0 0 12px #00f5ff33;flex:0 0 56px}
.rvw-avatar>span{font-weight:800;color:#07384a;letter-spacing:.5px}
.rvw-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.rvw-has-photo{background:none;box-shadow:none}

.rvw-meta .rvw-name{font-weight:800;color:#aaf7ff}
.rvw-meta .rvw-date{font-size:.85rem;color:#7aa8b8}
.rvw-text{color:#d6e8ef;margin-top:8px}

.rvw-stars{color:#00f5ff;letter-spacing:2px}
.rvw-del{margin-left:auto;background:transparent;border:0;color:#ff6b6b;font-size:1.1rem;cursor:pointer;display:inline-flex}
.rvw-admin-on .rvw-del[hidden]{display:inline-flex !important}

.rvw-arrow{display:none;position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.55);border:0;color:#00f5ff;font-size:1.8rem;padding:8px 12px;border-radius:50%;box-shadow:0 0 12px #00f5ff88}
#rvwPrev{left:-18px} #rvwNext{right:-18px}

/* Modal */
.rvw-modal{position:fixed;inset:0;display:none}
.rvw-modal.open{display:block}
.rvw-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7)}
.rvw-modal-dialog{position:relative;max-width:520px;margin:6vh auto;background:#0b0f18;border:1px solid #0ff3;box-shadow:0 0 24px #00f5ff55;border-radius:14px;padding:20px;color:#eaf7ff}
.rvw-modal-close{position:absolute;top:8px;right:10px;background:transparent;border:0;color:#aaf7ff;font-size:24px;cursor:pointer}
.rvw-form label{display:block;margin:12px 0;color:#aaf7ff}
.rvw-form input[type="text"], .rvw-form textarea, .rvw-form input[type="file"]{width:100%;padding:12px;border-radius:10px;border:1px solid #00f5ff33;background:#0c1520;color:#fff}
.rvw-stars-input{display:flex;gap:6px}
.rvw-stars-input button{background:transparent;border:0;font-size:22px;color:#7aa8b8;cursor:pointer}
.rvw-stars-input[data-value] button{opacity:.6}
.rvw-stars-input[data-value] button:nth-child(-n+attr(data-value number)){opacity:1;color:#00f5ff}
.rvw-photo-preview{display:flex;align-items:center;gap:10px;margin-top:8px}
.rvw-photo-preview img{width:64px;height:64px;object-fit:cover;border-radius:8px;border:1px solid #00f5ff44}
.rvw-photo-remove{background:#240020;border:1px solid #ff4d8a;color:#ffb6d1;padding:6px 10px;border-radius:8px;cursor:pointer}
.rvw-submit{margin-top:12px;background:#00f5ff;color:#001018;border:0;border-radius:999px;padding:10px 16px;font-weight:800;box-shadow:0 0 16px #00f5ff88;cursor:pointer}
.tst-modal.hidden{display:none;}
.tst-modal{position:fixed;inset:0;z-index:99999;}
.tst-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(2px);}
.tst-modal__panel{position:relative;margin:clamp(32px,8vh,80px) auto;width:min(720px,92%);background:#0b0d1a;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 0 24px rgba(0,245,255,.25);display:flex;flex-direction:column;max-height:90vh;overflow:hidden;}
#tstForm{padding:22px;display:flex;flex-direction:column;gap:14px;overflow:auto;}
.tst-modal__footer{position:sticky;bottom:0;display:flex;gap:10px;justify-content:flex-end;padding:14px 22px;background:linear-gradient(180deg, rgba(10,0,31,.3), rgba(10,0,31,.9));border-top:1px solid rgba(255,255,255,.08);}
.tst-modal__close{position:absolute;top:10px;right:12px;background:transparent;border:0;font-size:22px;color:#aef;cursor:pointer;}
/* opcional: ocultar flechas en desktop */
@media (min-width:769px){ #rvwPrev,#rvwNext{display:none;} }
/* ==== TESTIMONIOS ==== */
.rvw-section{
  background: linear-gradient(180deg,#050014,#000010);
  color:#fff;
  padding:100px 20px;
  position:relative;
  z-index:1;
}
.rvw-title{
  font-size:2.6rem;
  margin-bottom:10px;
  color:#00f5ff;
  text-shadow:0 0 12px #00f5ff;
}
.rvw-title span{ color:#a033ff; }

.rvw-cta-row{
  display:flex; gap:14px; align-items:center; justify-content:flex-end;
  margin:12px 0 28px;
}
.rvw-add-btn, .rvw-admin-btn{
  padding:10px 16px; border:none; border-radius:999px; font-weight:700;
  background:#00f5ff; color:#000; box-shadow:0 0 16px #00f5ff80; cursor:pointer;
}
.rvw-admin-btn{ background:#18223a; color:#aee8ff; box-shadow:0 0 12px #00f5ff40; }
.rvw-admin-btn[aria-pressed="true"]{ outline:2px solid #00f5ff; }

.rvw-slider{ position:relative; max-width:1200px; margin-inline:auto; }
.rvw-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%;
  display:grid; place-items:center; border:none; cursor:pointer;
  color:#00f5ff; background:#07101f; box-shadow:0 0 16px #00f5ff80;
  z-index:2;
}
.rvw-prev{ left:-10px; } .rvw-next{ right:-10px; }
@media (max-width:900px){ .rvw-prev{ left:-4px } .rvw-next{ right:-4px } }

.rvw-track{
  display:flex; gap:28px; overflow:hidden;
  will-change: transform; transition: transform .45s ease;
}

.tst-card{
  flex:0 0 360px; max-width:360px; min-height:220px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px; padding:18px; position:relative;
  box-shadow:0 0 24px rgba(0,245,255,.08);
  backdrop-filter: blur(10px);
}
@media (max-width:700px){ .tst-card{ flex-basis:86vw; max-width:86vw; } }

.tst-card__head{ display:flex; align-items:center; gap:12px; margin-bottom:8px; }
.tst-avatar{
  width:48px; height:48px; border-radius:50%; flex:0 0 48px;
  display:grid; place-items:center; font-weight:800;
  color:#07101f; background: radial-gradient(circle at 30% 30%, #e7f5ff, #bcd7ef);
  user-select:none;
  position:relative;
  overflow:hidden;
}
.tst-avatar[data-has-img="1"]{
  color:transparent;
  background-size:cover; background-position:center;
  pointer-events:none; /* no clic */
}
.tst-meta h4{ font-size:1.05rem; margin:0; color:#cfefff; }
.tst-date{ font-size:.85rem; color:#8fb6cc; }

.tst-stars-read{ color:#00e6ff; letter-spacing:1px; margin:6px 0 8px; }

.tst-text{ color:#cdd9e6; line-height:1.6; margin:0; }

/* Badges / admin */
.tst-badge{
  position:absolute; top:12px; right:12px; font-size:.75rem; padding:4px 8px;
  border-radius:999px; background:#332040; color:#ffb0ff; box-shadow:0 0 10px #a033ff60;
}
.tst-actions{ position:absolute; top:12px; right:12px; display:flex; gap:8px; }
.tst-actions button{
  width:34px; height:34px; border-radius:50%; border:1px solid #00f5ff55;
  background:#07101f; color:#9ee9ff; cursor:pointer; box-shadow:0 0 10px #00f5ff50;
}

/* Modal base (usa tus clases actuales) */
.tst-modal.hidden{ display:none; }
.tst-modal{ position:fixed; inset:0; z-index:9999; }
.tst-modal__backdrop{ position:absolute; inset:0; background:#000a; backdrop-filter: blur(2px); }
.tst-modal__panel{
  position:relative; max-width:760px; margin:6vh auto; background:#0b0f1c;
  border:1px solid #1b2a42; border-radius:16px; box-shadow:0 0 24px #00f5ff60;
  padding:0 22px 20px;
}
.tst-modal__panel form label{ display:block; margin:14px 0 6px; color:#cde; }
.tst-modal__panel input[type="text"],
.tst-modal__panel textarea{
  width:100%; background:#0f1730; border:1px solid #163056; color:#dff;
  padding:12px 14px; border-radius:10px; outline:none;
}
.tst-stars button{
  background:none; border:none; font-size:1.4rem; cursor:pointer; color:#335a73;
}
.tst-stars button.is-on{ color:#00f5ff; text-shadow:0 0 10px #00f5ff; }

.tst-modal__footer{ display:flex; justify-content:flex-end; gap:10px; margin-top:14px; }

/* Util */
.hidden{ display:none !important; }
/* === Selector de idioma fijo debajo del navbar === */
.lang-selector {
  position: fixed;
  top: 70px; /* debajo del navbar */
  right: 20px;
  z-index: 9999;
}

/* Botón principal */
.lang-selector button {
  background: transparent;
  border: none;
  cursor: pointer;
  transition: transform 0.2s ease;
}

.lang-selector button:hover {
  transform: scale(1.05);
}

/* Imagen bandera */
.lang-selector img {
  width: 40px;
  height: 30px;
  border-radius: 4px;
  border: 1px solid #00f5ff;
  box-shadow: 0 0 8px rgba(0,245,255,0.4);
  transition: all 0.25s ease;
}

/* === Dropdown === */
.lang-menu {
  display: flex;
  flex-direction: column;
  background: rgba(10,0,30,0.95);
  border: 1px solid #00f5ff;
  border-radius: 10px;
  padding: 6px;
  margin-top: 6px;
  position: absolute;
  right: 0;
  box-shadow: 0 8px 20px rgba(0,245,255,0.15);
  backdrop-filter: blur(6px);

  /* Animación inicial */
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

/* Estado oculto con fade */
.lang-menu.hidden {
  opacity: 0;
  transform: translateY(-10px);
  pointer-events: none;
}

/* Botones internos */
.lang-menu button {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  color: #e8eeff;
  cursor: pointer;
  font-size: 14px;
  padding: 6px 10px;
  border-radius: 8px;
  transition: background 0.2s ease, transform 0.2s ease;
}

.lang-menu button:hover {
  background: rgba(0,245,255,0.12);
  transform: translateX(3px);
}

.lang-menu button img {
  width: 22px;
  height: 16px;
  border-radius: 3px;
  border: 1px solid rgba(0,245,255,0.4);
}

/* === Responsivo === */

/* Tablets */
@media (max-width: 1024px) {
  .lang-selector {
    top: 80px;
    right: 18px;
  }
  .lang-selector img {
    width: 36px;
    height: 26px;
  }
}

/* Móviles medianos */
@media (max-width: 768px) {
  .lang-selector {
    top: 70px;
    right: 30px;
  }
  .lang-selector img {
    width: 32px;
    height: 22px;
  }
  .lang-menu {
    padding: 4px;
    border-radius: 8px;
  }
  .lang-menu button {
    font-size: 13px;
    padding: 5px 8px;
  }
}

/* Móviles pequeños */
@media (max-width: 480px) {
  .lang-selector {
    top: 70px;
    right: 12px;
  }
  .lang-selector img {
    width: 28px;
    height: 20px;
  }
  .lang-menu button img {
    width: 18px;
    height: 12px;
  }
}

/* WhatsApp FAB */
.wsp-fab{
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 9997;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #001319;
  background: radial-gradient(circle at 30% 30%, #00f5ff 0%, #00bcd4 70%, #00aac4 100%);
  box-shadow: 0 10px 30px rgba(0,245,255,.35), 0 0 12px rgba(0,245,255,.6) inset;
  text-decoration: none;
  transform: translateY(10px) scale(.9);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  border: 1px solid rgba(0,245,255,.45);
}
.wsp-fab.show{
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.wsp-fab:hover{
  filter: drop-shadow(0 0 10px #00f5ff);
}
@media (max-width: 520px){
  .wsp-fab{ right: 14px; bottom: 14px; width: 52px; height: 52px; }
}
/* Alturas del navbar (puedes ajustar) */
:root{
  --nav-h: 72px;
  --nav-h-shrink: 52px;
}

/* Navbar base */
.navbar{
  position: fixed; inset: 0 0 auto 0;
  height: var(--nav-h);
  display: flex; align-items: center;
  background: rgba(7, 10, 18, 0.70);
  border-bottom: 1px solid rgba(0,245,255,0.12);
  backdrop-filter: blur(6px);
  transition: height .25s ease, background .25s ease, box-shadow .25s ease;
  z-index: 1000;
}

/* Estado reducido al hacer scroll */
.navbar.shrink{
  height: var(--nav-h-shrink);
  background: rgba(7, 10, 18, 0.86);
  box-shadow: 0 8px 24px rgba(0,0,0,.35), 0 0 16px rgba(0,245,255,.15);
}

/* Logo y links se ajustan suavemente */
.navbar .logo{
  height: 60px;
  transition: transform .25s ease, opacity .25s ease;
}
.navbar.shrink .logo{
  transform: scale(.86);
  opacity: .95;
}

.navbar .nav-links a{
  padding: 16px 14px;
  transition: padding .25s ease, font-size .25s ease, opacity .25s ease;
}
.navbar.shrink .nav-links a{
  padding: 10px 14px;
  font-size: .95rem;
  opacity: .95;
}

/* === Selector de idioma: se posiciona según la altura del navbar === */
.lang-selector{
  position: fixed;
  right: 20px;
  top: calc(var(--nav-h) + 8px);
  z-index: 9999;
  transition: top .25s ease;
}
/* Cuando el navbar se reduce, movemos el selector hacia arriba */
body.nav-shrink .lang-selector{
  top: calc(var(--nav-h-shrink) + 8px);
}
