/* ============================================================
   Focusoft — rediseño full dark
   Gesto de marca: "enfocar" (blur → nítido, spotlight, visor)
   ============================================================ */
:root{
  --bg:#0A0E28;
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.09);
  --border-hover:rgba(69,215,184,.45);
  --ink:#F2F4FD;
  --muted:#98A0C6;
  --navy:#1D2560;
  --cyan:#0EA2DF;
  --mint:#45D7B8;
  --grad:linear-gradient(90deg,var(--cyan),var(--mint));
  --radius:18px;
  --maxw:1140px;
  --mono:'SF Mono',ui-monospace,Menlo,Consolas,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden;max-width:100%}
body{
  font-family:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono)}

/* ===== Wordmark (texto, sin ícono) ===== */
.brand-word{
  font-size:1.35rem;font-weight:800;letter-spacing:-.02em;color:#fff;line-height:1;
}
.brand-word span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== Eyebrow mono ===== */
.mono-eyebrow{
  font-family:var(--mono);font-size:.82rem;color:var(--mint);
  letter-spacing:.04em;margin-bottom:16px;
}
.cursor-block{color:var(--mint);animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* ===== Botones ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:12px;
  font-weight:700;font-size:15px;cursor:pointer;border:1.5px solid transparent;white-space:nowrap;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  background:linear-gradient(135deg,var(--cyan),var(--mint));color:#071030;
  box-shadow:0 10px 28px rgba(14,162,223,.35);
}
.btn-primary:hover{box-shadow:0 14px 34px rgba(69,215,184,.45)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--mint);color:var(--mint)}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,14,40,.72);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-weight:500;color:var(--muted);font-size:14.5px;transition:color .2s}
.nav a:hover{color:#fff}
.nav a.nav-cta{
  padding:9px 20px;background:var(--mint);color:#071030;font-weight:700;
  box-shadow:0 6px 18px rgba(69,215,184,.3);
}
.nav a.nav-cta:hover{background:#5ee6c9;color:#071030;box-shadow:0 8px 22px rgba(69,215,184,.45)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .3s ease,opacity .2s ease;transform-origin:center}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden}
/* retícula que solo se "enfoca" cerca del cursor */
.hero-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:radial-gradient(360px at var(--mx,62%) var(--my,38%),#000 0%,transparent 78%);
  -webkit-mask-image:radial-gradient(360px at var(--mx,62%) var(--my,38%),#000 0%,transparent 78%);
}
.hero-spot{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(620px at var(--mx,62%) var(--my,38%),rgba(14,162,223,.14),transparent 70%);
}
.hero-inner{
  position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center;
  padding:104px 24px 116px;
}
.hero h1{
  font-size:clamp(2.5rem,5.6vw,4.3rem);font-weight:800;line-height:1.06;letter-spacing:-.03em;
}
.hero h1 em,.hero h1 em .w{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero h1 .w{display:inline-block;animation:focus-in .7s cubic-bezier(.2,.7,.3,1) both}
@keyframes focus-in{
  from{opacity:0;filter:blur(14px);transform:translateY(14px)}
  to{opacity:1;filter:blur(0);transform:none}
}
.lead{font-size:1.12rem;color:var(--muted);margin:26px 0 34px;max-width:520px}
.lead strong{color:var(--ink)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{margin-top:42px;font-size:.82rem;color:var(--muted)}
.hero-trust strong{color:var(--ink);font-weight:600}

/* Terminal */
.hero-visual{display:flex;justify-content:center}
.term{
  width:min(460px,100%);background:#0D1233;border:1px solid var(--border);border-radius:14px;
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 90px rgba(14,162,223,.12);
}
.term-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--border)}
.term-bar span{width:10px;height:10px;border-radius:50%}
.term-bar span:nth-child(1){background:#ff6058}
.term-bar span:nth-child(2){background:#ffbd2e}
.term-bar span:nth-child(3){background:#28c840}
.term-bar b{margin-left:8px;font-size:.72rem;font-weight:500;color:var(--muted)}
.term-body{
  padding:20px 20px 24px;font-size:13.5px;line-height:1.9;min-height:172px;
  white-space:pre-wrap;word-break:break-word;color:var(--ink);text-align:left;
}
.term-body .t-cmd{color:#c7cdf0}
.term-body .t-ok{color:var(--mint)}
.term-body .t-out{color:var(--cyan);font-weight:600}
.term-body .t-caret{display:inline-block;width:8px;background:var(--mint);animation:blink 1s steps(1) infinite}

/* Marco de visor (esquinas) — gesto "foco" */
.frame{position:relative}
.frame::before,.frame::after{
  content:"";position:absolute;width:26px;height:26px;pointer-events:none;
  border:2px solid var(--mint);opacity:.85;
}
.frame::before{top:-9px;left:-9px;border-right:0;border-bottom:0;border-radius:6px 0 0 0}
.frame::after{bottom:-9px;right:-9px;border-left:0;border-top:0;border-radius:0 0 6px 0}

/* ===== Marquee ===== */
.marquee{
  overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:15px 0;background:rgba(255,255,255,.015);
}
.marquee-track{
  display:flex;align-items:center;gap:34px;width:max-content;
  animation:marq 30s linear infinite;
  font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}
.marquee-track i{color:var(--mint);font-style:normal;font-size:.7rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ===== Secciones ===== */
.section{padding:104px 0}
.section-line{border-top:1px solid rgba(255,255,255,.055)}
.section-head{max-width:620px;margin:0 auto 60px;text-align:center}
.section-head h2,.about-copy h2,.offer-detail h2,.cta-inner h2{
  font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:800;letter-spacing:-.025em;line-height:1.15;color:#fff;
}
.section-head p{color:var(--muted);margin-top:14px;font-size:1.03rem}

/* ===== Oferta ===== */
.offer{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center;
  background:var(--surface);border:1px solid var(--border);border-radius:24px;
  padding:64px 60px;max-width:calc(var(--maxw) - 48px);
}
.offer-price{text-align:center}
.offer-desde{color:var(--muted);font-size:.85rem;letter-spacing:.2em;text-transform:uppercase}
.offer-usd{
  font-size:clamp(3.6rem,8.5vw,6.2rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums;
}
.offer-plazo{color:var(--muted);font-size:1.05rem;margin-top:8px}
.offer-plazo strong{color:var(--mint)}
.offer-detail>p{color:var(--muted);margin:14px 0 24px;max-width:48ch}
.offer-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:28px}
.offer-note{font-size:.78rem;color:var(--muted)}

/* Checklist */
.checks{list-style:none;display:flex;flex-direction:column;gap:12px}
.checks li{position:relative;padding-left:32px;font-weight:500;color:var(--ink)}
.checks li::before{
  content:"✓";position:absolute;left:0;top:2px;width:21px;height:21px;border-radius:50%;
  background:rgba(69,215,184,.15);border:1px solid rgba(69,215,184,.4);color:var(--mint);
  font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center;
}

/* ===== Proceso ===== */
.steps{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
  counter-reset:step;position:relative;
}
.steps::before{
  content:"";position:absolute;top:17px;left:4%;right:4%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(69,215,184,.5),rgba(14,162,223,.5),transparent);
}
.step{position:relative;padding-top:52px}
.step::before{
  content:"";position:absolute;top:10px;left:0;width:15px;height:15px;border-radius:50%;
  background:var(--bg);border:2px solid var(--mint);box-shadow:0 0 0 5px rgba(69,215,184,.14);
}
.step-day{
  display:inline-block;font-size:.72rem;color:var(--cyan);letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:10px;
}
.step h3{font-size:1.12rem;font-weight:700;color:#fff;margin-bottom:8px}
.step p{color:var(--muted);font-size:.93rem}

/* ===== Bento servicios ===== */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cell{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 28px;transition:transform .22s ease,border-color .22s ease,background .22s ease;
}
.cell:hover{transform:translateY(-5px);border-color:var(--border-hover);background:var(--surface-2)}
.cell-web{grid-column:span 2;grid-row:span 2;display:flex;flex-direction:column;justify-content:center;padding:44px 40px}
.cell-web h3{font-size:1.6rem}
.cell-web p{font-size:1.02rem}
.bento .cell:nth-child(2){grid-column:span 2}
.cell-icon{width:30px;height:30px;color:var(--mint);margin-bottom:18px}
.cell h3{font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:8px}
.cell p{color:var(--muted);font-size:.95rem}
.chip{
  align-self:flex-start;margin-top:22px;font-size:.75rem;color:var(--mint);
  border:1px solid rgba(69,215,184,.4);background:rgba(69,215,184,.1);
  padding:6px 14px;border-radius:999px;
}

/* ===== Proyectos ===== */
.projects{display:flex;flex-direction:column;gap:24px}
.project{
  display:grid;grid-template-columns:1.1fr .9fr;align-items:stretch;overflow:hidden;
  background:var(--surface);border:1px solid var(--border);border-radius:22px;
  transition:transform .22s ease,border-color .22s ease;
}
.project:hover{transform:translateY(-4px);border-color:var(--border-hover)}
.project.reverse .project-shot{order:2}
.project-shot{background:#0D1233;display:flex;align-items:center;justify-content:center;padding:26px}
.project-shot img{width:100%;border-radius:10px;box-shadow:0 20px 44px rgba(0,0,0,.45);border:1px solid var(--border)}
.project-body{padding:42px;display:flex;flex-direction:column;justify-content:center}
.project-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.tag{
  font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;background:var(--surface-2);color:var(--muted);
}
.tag.green{background:rgba(69,215,184,.16);color:var(--mint)}
.tag.blue{background:rgba(14,162,223,.16);color:#5cc5f2}
.project-body h3{font-size:1.65rem;color:#fff;margin-bottom:10px}
.project-body p{color:var(--muted);margin-bottom:20px}
.project-status{
  align-self:flex-start;font-size:.78rem;color:var(--muted);
  border:1px solid var(--border);background:var(--surface);
  padding:8px 15px;border-radius:999px;
}
.projects-mini{display:grid;grid-template-columns:1fr 1fr;gap:24px}

/* ===== Nosotros ===== */
.about{display:grid;grid-template-columns:.75fr 1.25fr;gap:56px;align-items:center}
.about-visual{display:flex;justify-content:center}
.about-visual img{width:200px;filter:drop-shadow(0 20px 50px rgba(14,162,223,.25))}
.about-copy>p{color:var(--muted);font-size:1.04rem;margin:16px 0 22px}
.about-copy strong{color:var(--ink)}

/* ===== CTA ===== */
.cta-section{position:relative;overflow:hidden}
.cta-section::before{
  content:"";position:absolute;inset:auto -20% -60% -20%;height:120%;pointer-events:none;
  background:radial-gradient(50% 60% at 50% 100%,rgba(14,162,223,.18),transparent 70%);
}
.cta-inner{position:relative;text-align:center;max-width:660px}
.cta-inner>p{color:var(--muted);margin:16px 0 34px;font-size:1.1rem}
.cta-inner strong{color:var(--mint)}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--border);padding:56px 0 36px}
.footer-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.footer-tag{color:var(--muted);font-size:.8rem}
.footer-links{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;margin:8px 0}
.footer-links a{color:var(--muted);font-size:.92rem;transition:color .2s}
.footer-links a:hover{color:var(--mint)}
.copy{color:rgba(152,160,198,.55);font-size:.74rem;margin-top:10px}

/* ===== WhatsApp float ===== */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:90;
  width:58px;height:58px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#25D366;box-shadow:0 10px 26px rgba(37,211,102,.45);
  transition:transform .2s ease,box-shadow .2s ease;
  animation:wa-pulse 2.6s ease-in-out infinite;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 14px 32px rgba(37,211,102,.6)}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 10px 26px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.45)}
  50%{box-shadow:0 10px 26px rgba(37,211,102,.45),0 0 0 12px rgba(37,211,102,0)}
}

/* ===== Reveal (blur → nítido) ===== */
.reveal{opacity:0;filter:blur(10px);transform:translateY(20px);transition:opacity .65s ease,filter .65s ease,transform .65s ease}
.reveal.visible{opacity:1;filter:blur(0);transform:none}
.bento .reveal:nth-child(2){transition-delay:.07s}
.bento .reveal:nth-child(3){transition-delay:.12s}
.bento .reveal:nth-child(4){transition-delay:.17s}
.bento .reveal:nth-child(5){transition-delay:.22s}
.bento .reveal:nth-child(6){transition-delay:.27s}
.steps .reveal:nth-child(2){transition-delay:.1s}
.steps .reveal:nth-child(3){transition-delay:.2s}
.steps .reveal:nth-child(4){transition-delay:.3s}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .hero h1 .w{animation:none}
  .marquee-track{animation:none}
  .wa-float{animation:none}
  .cursor-block,.t-caret{animation:none}
  .reveal{opacity:1;filter:none;transform:none;transition:none}
}

/* ===== Responsive ===== */
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:72px 24px 80px;gap:44px}
  .hero-actions{justify-content:center}
  .lead{margin-left:auto;margin-right:auto}
  .offer{grid-template-columns:1fr;gap:36px;padding:48px 36px;text-align:center}
  .offer-detail>p,.offer .checks{text-align:left}
  .offer .checks{max-width:420px;margin:0 auto}
  .offer-actions{justify-content:center}
  .steps{grid-template-columns:repeat(2,1fr);gap:34px 22px}
  .steps::before{display:none}
  .bento{grid-template-columns:repeat(2,1fr)}
  .cell-web{grid-column:span 2;grid-row:auto}
  .bento .cell:nth-child(2){grid-column:span 2}
  .project,.project.reverse{grid-template-columns:1fr}
  .project.reverse .project-shot{order:0}
  .about{grid-template-columns:1fr;text-align:center;gap:36px}
  .about-visual img{width:150px}
  .about .checks{max-width:420px;margin:0 auto;text-align:left}
}
@media (max-width:640px){
  .nav{
    position:fixed;inset:70px 0 auto 0;flex-direction:column;gap:0;background:#0D1233;
    padding:8px 24px 22px;transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .32s cubic-bezier(.4,0,.2,1),opacity .28s ease,visibility .32s;
    box-shadow:0 20px 40px rgba(0,0,0,.5);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  }
  .nav.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
  .nav a{
    width:100%;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.08);
    opacity:0;transform:translateY(-6px);transition:opacity .3s ease,transform .3s ease;
  }
  .nav.open a{opacity:1;transform:none}
  .nav.open a:nth-child(1){transition-delay:.05s}
  .nav.open a:nth-child(2){transition-delay:.1s}
  .nav.open a:nth-child(3){transition-delay:.15s}
  .nav.open a:nth-child(4){transition-delay:.2s}
  .nav.open a:nth-child(5){transition-delay:.25s}
  .nav-cta{margin-top:14px;justify-content:center;border-bottom:0 !important}
  .nav-toggle{display:flex}

  .section{padding:72px 0}
  .hero-inner{padding:56px 24px 64px}
  .hero h1{font-size:2.15rem}
  .lead{font-size:1rem}
  .hero-actions .btn{padding:12px 20px;font-size:14px}
  .term-body{font-size:12.5px;min-height:150px}
  .frame::before,.frame::after{width:20px;height:20px}
  .offer{padding:40px 24px}
  .steps{grid-template-columns:1fr;gap:0;padding-left:26px}
  .steps .step{padding:0 0 34px 26px;border-left:1px solid rgba(69,215,184,.3)}
  .steps .step:last-child{border-left-color:transparent;padding-bottom:0}
  .step::before{top:2px;left:-8.5px}
  .bento{grid-template-columns:1fr}
  .cell-web{grid-column:span 1;padding:32px 28px}
  .bento .cell:nth-child(2){grid-column:span 1}
  .projects-mini{grid-template-columns:1fr}
  .project-body{padding:30px}
  .cta-actions .btn{width:100%;justify-content:center}
  .wa-float{width:54px;height:54px;right:16px;bottom:16px}
}
