:root{
    --bg:#FFFFFF;
    --bg-alt:#F3F5F7;
    --surface:#FFFFFF;
    --surface-2:#F7F8FA;
    --border:#E2E6EA;
    --text:#141A20;
    --text-dim:#57626C;
    --text-faint:#8A94A0;
    --green:#1C8F5A;
    --green-dim:#12643D;
    --green-soft:#E7F5EE;
    --amber:#A8670A;
    --blue:#2563A8;
    --danger:#C0392B;
    --radius:10px;
    --font-display:'Space Grotesk', sans-serif;
    --font-body:'Inter', sans-serif;
    --font-mono:'JetBrains Mono', monospace;
    --maxw:1140px;

    /* la terminal del hero se queda siempre oscura, como detalle acotado */
    --term-bg:#0B0F14;
    --term-bg-2:#141B24;
    --term-border:#232D3A;
    --term-text:#93A1B0;
    --term-green:#6EE7A8;
    --term-blue:#7FB0E0;
  }

  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--bg);
    color:var(--text);
    font-family:var(--font-body);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  body{
    background-image:
      radial-gradient(circle at 15% 0%, rgba(28,143,90,0.05), transparent 40%),
      radial-gradient(circle at 85% 15%, rgba(37,99,168,0.04), transparent 45%);
  }

  a{color:inherit; text-decoration:none;}
  ul{list-style:none;}
  img{max-width:100%; display:block;}

  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}

  ::selection{background:var(--green); color:#fff;}

  :focus-visible{
    outline:2px solid var(--green);
    outline-offset:3px;
    border-radius:4px;
  }

  h1,h2,h3{font-family:var(--font-display); font-weight:600; letter-spacing:-0.01em;}

  .eyebrow{
    font-family:var(--font-mono);
    font-size:0.8rem;
    color:var(--green);
    letter-spacing:0.02em;
    display:flex;
    align-items:center;
    gap:8px;
    margin-bottom:14px;
  }
  .eyebrow::before{content:"//"; color:var(--text-faint);}

  /* ---------- HEADER ---------- */
  header{
    position:sticky; top:0; z-index:50;
    background:rgba(255,255,255,0.85);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--border);
  }
  .nav{
    display:flex; align-items:center; justify-content:space-between;
    padding:16px 24px;
    max-width:var(--maxw); margin:0 auto;
  }
  .logo{
    display:flex;
    align-items:center;
  }
  .logo-img{height:30px; width:auto; display:block;}
  .nav-links{display:flex; gap:32px; align-items:center;}
  .nav-links a{
    font-family:var(--font-mono);
    font-size:0.85rem;
    color:var(--text-dim);
    transition:color .15s ease;
  }
  .nav-links a:hover{color:var(--green);}
  .nav-cta{
    font-family:var(--font-mono);
    font-size:0.82rem;
    padding:9px 16px;
    border:1px solid var(--green-dim);
    border-radius:6px;
    color:var(--green);
    transition:all .15s ease;
  }
  .nav-cta:hover{background:var(--green); color:#fff; border-color:var(--green);}
  .nav-toggle{display:none; background:none; border:none; color:var(--text); font-size:1.4rem; cursor:pointer;}

  @media (max-width:800px){
    .nav-links{
      position:fixed; top:64px; left:0; right:0;
      background:var(--bg-alt);
      border-bottom:1px solid var(--border);
      flex-direction:column;
      padding:20px 24px 28px;
      gap:20px;
      display:none;
    }
    .nav-links.open{display:flex;}
    .nav-toggle{display:block;}
  }

  /* ---------- HERO ---------- */
  .hero{
    padding:88px 0 72px;
    display:grid;
    grid-template-columns:1.05fr 0.95fr;
    gap:56px;
    align-items:center;
  }
  @media (max-width:900px){
    .hero{grid-template-columns:1fr; padding:56px 0 48px;}
  }
  .hero h1{
    font-size:clamp(2.1rem, 4.4vw, 3.4rem);
    line-height:1.12;
    margin-bottom:20px;
  }
  .hero h1 .accent{color:var(--green);}
  .hero p.lead{
    color:var(--text-dim);
    font-size:1.08rem;
    max-width:46ch;
    margin-bottom:32px;
  }
  .hero-ctas{display:flex; gap:14px; flex-wrap:wrap;}

  .btn{
    font-family:var(--font-mono);
    font-size:0.9rem;
    padding:13px 22px;
    border-radius:7px;
    display:inline-flex;
    align-items:center;
    gap:8px;
    transition:transform .12s ease, box-shadow .12s ease, background .15s ease;
    cursor:pointer;
    border:1px solid transparent;
  }
  .btn-primary{background:var(--green); color:#fff; font-weight:600;}
  .btn-primary:hover{transform:translateY(-1px); box-shadow:0 8px 22px rgba(28,143,90,0.22);}
  .btn-ghost{border-color:var(--border); color:var(--text);}
  .btn-ghost:hover{border-color:var(--text-dim);}

  /* terminal — se mantiene siempre oscura como detalle de código */
  .terminal{
    background:var(--term-bg);
    border:1px solid var(--term-border);
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:0 30px 60px -20px rgba(15,20,25,0.25);
  }
  .term-bar{
    display:flex; align-items:center; gap:8px;
    padding:11px 14px;
    background:var(--term-bg-2);
    border-bottom:1px solid var(--term-border);
  }
  .term-dot{width:10px; height:10px; border-radius:50%;}
  .term-bar .term-title{
    margin-left:8px;
    font-family:var(--font-mono);
    font-size:0.78rem;
    color:var(--text-faint);
  }
  .term-body{
    padding:20px 18px 24px;
    font-family:var(--font-mono);
    font-size:0.84rem;
    min-height:280px;
    color:var(--term-text);
    white-space:pre-wrap;
  }
  .term-body .prompt{color:var(--term-green);}
  .term-body .ok{color:var(--term-green);}
  .term-body .out{color:var(--term-text);}
  .term-cursor{
    display:inline-block; width:7px; height:1em;
    background:var(--term-green);
    vertical-align:text-bottom;
    animation:blink 1s step-end infinite;
  }
  @keyframes blink{50%{opacity:0;}}

  @media (prefers-reduced-motion: reduce){
    .term-cursor{animation:none;}
  }

  /* ---------- SECTIONS ---------- */
  section{padding:88px 0;}
  .section-head{max-width:640px; margin-bottom:48px;}
  .section-head h2{font-size:clamp(1.6rem, 3vw, 2.2rem); margin-bottom:14px;}
  .section-head p{color:var(--text-dim);}

  #servicios{border-top:1px solid var(--border); background:var(--bg-alt);}

  .services-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
    gap:1px;
    background:var(--border);
    border:1px solid var(--border);
    border-radius:var(--radius);
    overflow:hidden;
  }
  .service-card{
    background:var(--surface);
    padding:30px 26px;
    transition:background .15s ease;
    display:flex;
    flex-direction:column;
  }
  .service-card:hover{background:var(--surface-2);}
  .service-icon-badge{
    width:48px; height:48px;
    border-radius:12px;
    background:var(--green-soft);
    display:flex; align-items:center; justify-content:center;
    margin-bottom:18px;
  }
  .service-icon-badge svg{width:24px; height:24px; color:var(--green-dim);}
  .service-card h3{font-size:1.15rem; margin-bottom:8px;}
  .service-card p{color:var(--text-dim); font-size:0.94rem; flex-grow:1;}
  .service-cta{
    display:inline-block;
    margin-top:16px;
    font-family:var(--font-mono);
    font-size:0.82rem;
    color:var(--green);
    font-weight:600;
  }
  .service-cta:hover{text-decoration:underline;}

  /* ---------- CTA BAND ---------- */
  .cta-band{padding:0 0 88px;}
  .cta-card{
    background:var(--term-bg);
    border:1px solid var(--term-border);
    border-radius:var(--radius);
    padding:40px 36px;
    display:flex; align-items:center; justify-content:space-between;
    gap:28px; flex-wrap:wrap;
    box-shadow:0 30px 60px -30px rgba(15,20,25,0.35);
  }
  .cta-card .eyebrow{color:var(--term-green); margin-bottom:8px;}
  .cta-card .eyebrow::before{color:var(--term-text);}
  .cta-card h2{color:#fff; font-size:clamp(1.3rem, 2.6vw, 1.7rem); margin-bottom:6px;}
  .cta-card-text p:last-child{color:var(--term-text); font-size:0.96rem;}
  .cta-card .btn-primary{flex-shrink:0;}

  /* ---------- PRECIOS ---------- */
  #precios{background:var(--bg-alt); border-top:1px solid var(--border);}
  .pricing-note{
    font-family:var(--font-mono);
    font-size:0.8rem;
    color:var(--amber);
    background:#FBF3E7;
    border:1px solid #EED9B8;
    border-radius:8px;
    padding:12px 16px;
    margin-bottom:36px;
    max-width:640px;
  }
  .pricing-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap:18px;
  }
  .price-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:26px 24px;
    box-shadow:0 2px 10px rgba(20,26,32,0.04);
    display:flex;
    flex-direction:column;
  }
  .price-card .p-name{font-family:var(--font-mono); font-size:0.82rem; color:var(--text-dim); margin-bottom:6px;}
  .price-card .p-amount{font-family:var(--font-display); font-size:2rem; font-weight:600; margin-bottom:2px;}
  .price-card .p-amount span{font-family:var(--font-mono); font-size:0.85rem; color:var(--text-faint); font-weight:400;}
  .price-card .p-tagline{font-size:0.87rem; color:var(--text-dim); margin-top:8px; line-height:1.5;}
  .price-card ul{margin-top:16px; display:flex; flex-direction:column; gap:8px; flex-grow:1;}
  .price-card li{font-size:0.87rem; color:var(--text-dim); display:flex; gap:8px;}
  .price-card li::before{content:"✓"; color:var(--green);}
  .plan-cta{
    display:block; text-align:center;
    margin-top:20px; padding:11px 16px;
    border:1px solid var(--green); border-radius:7px;
    font-family:var(--font-mono); font-size:0.82rem; font-weight:600;
    color:var(--green);
    transition:all .15s ease;
  }
  .plan-cta:hover{background:var(--green); color:#fff;}

  .value-list{margin-bottom:24px; display:flex; flex-direction:column; gap:10px;}
  .value-list li{
    display:flex; gap:10px; align-items:flex-start;
    color:var(--text-dim); font-size:0.96rem;
  }
  .value-list li::before{content:"✓"; color:var(--green); font-weight:700; flex-shrink:0;}

  /* ---------- NOSOTROS ---------- */
  #nosotros{border-top:1px solid var(--border);}
  .nosotros-grid{display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;}
  @media (max-width:800px){.nosotros-grid{grid-template-columns:1fr; gap:32px;}}
  .stat-block{display:flex; gap:28px; flex-wrap:wrap; margin-top:28px;}
  .stat{font-family:var(--font-mono);}
  .stat .n{font-family:var(--font-display); font-size:1.6rem; color:var(--green); font-weight:600;}
  .stat .l{font-size:0.78rem; color:var(--text-faint);}

  .code-block{
    background:var(--term-bg);
    border:1px solid var(--term-border);
    border-radius:var(--radius);
    padding:22px;
    font-family:var(--font-mono);
    font-size:0.82rem;
    color:var(--term-text);
    line-height:1.9;
  }
  .code-block .k{color:var(--term-blue);}
  .code-block .s{color:var(--term-green);}

  /* ---------- CONTACTO ---------- */
  #contacto{border-top:1px solid var(--border); background:var(--bg-alt);}
  .contact-grid{display:grid; grid-template-columns:0.9fr 1.1fr; gap:48px;}
  @media (max-width:800px){.contact-grid{grid-template-columns:1fr;}}

  .contact-info-item{margin-bottom:24px;}
  .contact-info-item .l{font-family:var(--font-mono); font-size:0.78rem; color:var(--text-faint); margin-bottom:4px;}
  .contact-info-item .v{font-size:1rem;}
  .contact-info-item a:hover{color:var(--green);}

  form{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:30px;
    display:flex;
    flex-direction:column;
    gap:16px;
    box-shadow:0 2px 10px rgba(20,26,32,0.04);
  }
  .field{display:flex; flex-direction:column; gap:6px;}
  .field label{font-family:var(--font-mono); font-size:0.78rem; color:var(--text-dim);}
  .field input, .field select, .field textarea{
    background:var(--surface-2);
    border:1px solid var(--border);
    border-radius:6px;
    padding:11px 13px;
    color:var(--text);
    font-family:var(--font-body);
    font-size:0.92rem;
  }
  .field input:focus, .field select:focus, .field textarea:focus{
    outline:none; border-color:var(--green);
  }
  .field textarea{resize:vertical; min-height:100px;}
  .field-check{flex-direction:row; align-items:flex-start; gap:10px;}
  .field-check input{width:16px; height:16px; margin-top:3px; accent-color:var(--green);}
  .field-check label{color:var(--text-dim); font-size:0.85rem; font-family:var(--font-body);}
  .field-check a{color:var(--green);}
  .hp-field{position:absolute; left:-9999px; opacity:0;}

  .form-msg{
    font-family:var(--font-mono);
    font-size:0.84rem;
    padding:12px 14px;
    border-radius:6px;
    display:none;
  }
  .form-msg.ok{display:block; background:var(--green-soft); border:1px solid var(--green); color:var(--green-dim);}
  .form-msg.err{display:block; background:#FBEAEA; border:1px solid var(--danger); color:var(--danger);}

  /* ---------- LEGAL PAGES ---------- */
  .legal-page{padding:64px 0 96px;}
  .legal-page .back-link{
    font-family:var(--font-mono); font-size:0.82rem; color:var(--green);
    display:inline-flex; align-items:center; gap:6px; margin-bottom:28px;
  }
  .legal-page h1{font-size:clamp(1.6rem,3.4vw,2.3rem); margin-bottom:8px;}
  .legal-page .updated{font-family:var(--font-mono); font-size:0.78rem; color:var(--text-faint); margin-bottom:40px;}
  .legal-page h2{font-size:1.2rem; margin:36px 0 12px; color:var(--text);}
  .legal-page h3{font-size:1.02rem; margin:22px 0 8px; color:var(--text);}
  .legal-page p{color:var(--text-dim); margin-bottom:14px; max-width:74ch;}
  .legal-page ul{margin:0 0 14px 0; max-width:74ch;}
  .legal-page ul li{color:var(--text-dim); margin-bottom:10px; padding-left:20px; position:relative;}
  .legal-page ul li::before{content:"—"; position:absolute; left:0; color:var(--text-faint);}
  .legal-page strong{color:var(--text);}
  .legal-page a{color:var(--green);}
  .legal-page .note{
    font-family:var(--font-mono); font-size:0.8rem; color:var(--amber);
    background:#FBF3E7; border:1px solid #EED9B8;
    border-radius:8px; padding:12px 16px; margin-bottom:32px; max-width:74ch;
  }

  /* Ocultamos el badge flotante de reCAPTCHA porque ya mostramos el aviso
     legal requerido junto al formulario (Google permite ocultarlo en ese caso). */
  .grecaptcha-badge{ visibility:hidden; }

  /* Ocultamos el badge flotante de reCAPTCHA: Google permite ocultarlo
     siempre que se muestre el texto legal alternativo (ya está junto al
     botón de enviar, en el formulario de contacto). */
  .grecaptcha-badge{ visibility:hidden; }

  /* ---------- WHATSAPP FLOAT ---------- */
  .whatsapp-float{
    position:fixed; left:20px; bottom:20px; z-index:90;
    width:52px; height:52px; border-radius:50%;
    background:#25D366; color:#fff;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 18px rgba(37,211,102,0.35);
    transition:transform .15s ease;
  }
  .whatsapp-float:hover{transform:scale(1.06);}
  body.cookie-banner-visible .whatsapp-float{bottom:96px;}

  /* ---------- COOKIE BANNER ---------- */
  .cookie-banner{
    position:fixed; left:0; right:0; bottom:0; z-index:100;
    background:var(--surface);
    border-top:1px solid var(--border);
    box-shadow:0 -8px 30px rgba(20,26,32,0.08);
  }
  .cookie-banner-inner{
    padding:18px 24px;
    display:flex; align-items:center; justify-content:space-between;
    gap:24px; flex-wrap:wrap;
  }
  .cookie-banner-inner p{color:var(--text-dim); font-size:0.88rem; max-width:60ch;}
  .cookie-banner-inner a{color:var(--green);}
  .cookie-banner-actions{display:flex; gap:10px; flex-shrink:0;}
  .cookie-banner-actions .btn{padding:10px 18px; font-size:0.84rem;}

  /* ---------- FOOTER ---------- */
  footer{padding:40px 0; border-top:1px solid var(--border);}
  .footer-row{
    display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
  }
  .footer-links{display:flex; gap:22px; flex-wrap:wrap;}
  .footer-links a{font-size:0.85rem; color:var(--text-dim);}
  .footer-links a:hover{color:var(--green);}
  .footer-copy{font-family:var(--font-mono); font-size:0.78rem; color:var(--text-faint);}
