:root{
  --bg:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --card:#f8fafc;
  --green:#22c55e;
  --green2:#16a34a;
  --shadow:0 18px 60px rgba(15,23,42,.10);
  --hero-bg:#f5f7fa;
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans","Liberation Sans",sans-serif;
  color:var(--text);
  background:var(--bg);
}

a{color:inherit; text-decoration:none;}

.container{width:min(1120px,100%); margin:0 auto; padding:0 20px;}

.header{
  position:sticky;
  top:0;
  z-index:20;
  background:#fff;
  border-bottom:1px solid var(--line);
}

.header__inner{
  height:64px;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:18px;
}

.brand{display:flex; align-items:center; gap:10px; font-weight:900; letter-spacing:.02em; justify-self:start;}
.brand__logo{height:26px; width:auto; display:block;}
.brand__text{color:#111; font-size:14px;}
.brand__mark{
  width:34px;
  height:34px;
  border-radius:10px;
  background:linear-gradient(180deg,var(--green),var(--green2));
  position:relative;
  box-shadow:0 10px 24px rgba(34,197,94,.18);
}
.brand__mark::after{
  content:"";
  position:absolute;
  inset:8px 10px 10px;
  border-radius:10px;
  background:rgba(255,255,255,.9);
  clip-path:polygon(50% 0%, 92% 18%, 92% 62%, 50% 100%, 8% 62%, 8% 18%);
}

.nav{display:flex; align-items:center; gap:22px; justify-self:center;}
.nav__link{font-weight:700; font-size:13px; color:#111827; opacity:.78;}
.nav__link:hover{opacity:1;}

.header__actions{display:flex; align-items:center; gap:12px; justify-self:end;}
.link{font-weight:700; font-size:12px; color:#111827; opacity:.65; padding:8px 10px; border-radius:10px; border:1px solid transparent;}
.link:hover{opacity:1; background:rgba(17,24,39,.04); border-color:rgba(17,24,39,.06);}
.link:hover{opacity:1;}
.lang{position:relative; font-weight:800; font-size:13px; color:#111827; opacity:.92;}

.lang__btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:34px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  cursor:pointer;
  font-weight:900;
  color:#111827;
}

.lang__btn:hover{background:rgba(17,24,39,.03);}

.lang__caret{
  width:0;
  height:0;
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  border-top:6px solid rgba(17,24,39,.55);
}

.lang__menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  width:180px;
  padding:8px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  box-shadow:0 18px 60px rgba(15,23,42,.18);
  z-index:30;
}

.lang__item{
  width:100%;
  text-align:left;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
  color:#111827;
}

.lang__item:hover{background:rgba(17,24,39,.04); border-color:rgba(17,24,39,.06);}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:34px;
  padding:0 14px;
  border-radius:10px;
  border:1px solid transparent;
  font-weight:800;
  font-size:12px;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  user-select:none;
}
.btn:hover{transform:translateY(-1px);}

.btn--primary{
  background:linear-gradient(180deg,var(--green),var(--green2));
  color:#fff;
  box-shadow:0 16px 44px rgba(34,197,94,.22);
}
.btn--primary:hover{box-shadow:0 18px 52px rgba(34,197,94,.28);}

.btn--block{width:100%; height:40px; border-radius:10px; font-size:12px;}

.hero{padding:44px 0 34px; background:var(--hero-bg); border-bottom:1px solid rgba(17,24,39,.06);}
.hero__inner{display:grid; grid-template-columns:1.05fr .95fr; gap:34px; align-items:flex-start;}

.hero__title{margin:0 0 16px; font-size:clamp(34px,4.2vw,50px); line-height:1.05; letter-spacing:-.03em;}
.hero__title span{display:block;}
.accent{color:var(--green2);}

.lead{max-width:420px;}
.lead__fields{display:grid; gap:9px; margin-bottom:10px;}

.field__sr{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden;}
.input{
  width:100%;
  height:36px;
  padding:0 12px;
  border-radius:4px;
  border:1px solid rgba(17,24,39,.16);
  background:#fff;
  outline:none;
  font-size:12px;
  font-weight:650;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.input:focus{border-color:rgba(34,197,94,.75); box-shadow:0 0 0 3px rgba(34,197,94,.14);}

.lead__note{margin:10px 0 0; font-size:13px; font-weight:700; color:var(--muted); min-height:18px;}


.hero__art{
  position:relative;
  height:340px;
  border-radius:22px;
  overflow:hidden;
  background:transparent;
}

.hero__ring{
  position:absolute;
  left:50%;
  top:50%;
  width:320px;
  height:320px;
  transform:translate(-44%,-52%);
  border-radius:999px;
  background:
    radial-gradient(closest-side, rgba(34,197,94,.14), transparent 62%),
    radial-gradient(closest-side, transparent 60%, rgba(17,24,39,.10) 61%, rgba(17,24,39,.10) 62%, transparent 63%),
    radial-gradient(closest-side, transparent 74%, rgba(17,24,39,.08) 75%, rgba(17,24,39,.08) 76%, transparent 77%);
  filter: blur(.0px);
  opacity:.95;
}

.hero__ring::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:999px;
  background:
    conic-gradient(from 180deg, rgba(34,197,94,.55), rgba(34,197,94,0) 45%, rgba(34,197,94,.35) 70%, rgba(34,197,94,0) 100%);
  -webkit-mask: radial-gradient(closest-side, transparent 71%, #000 72%);
  mask: radial-gradient(closest-side, transparent 71%, #000 72%);
  opacity:.35;
}

.hero__nodes{
  position:absolute;
  inset:0;
}

.node{
  position:absolute;
  left:var(--x);
  top:var(--y);
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(17,24,39,.38);
  transform:translate(-50%,-50%);
  box-shadow:0 0 0 7px rgba(17,24,39,.06);
}

.node--g{
  background:rgba(34,197,94,.95);
  box-shadow:0 0 0 7px rgba(34,197,94,.14);
}

.hero__photo{
  position:absolute;
  right:6px;
  bottom:-18px;
  width:min(360px, 92%);
  height:auto;
  display:block;
  pointer-events:none;
}

/* Keep the rest of the page white like the reference */
.section{background:#fff;}

.section{padding:56px 0;}

.title{margin:0 0 18px; font-size:clamp(22px,2.3vw,34px); letter-spacing:-.02em;}
.center{text-align:center;}

.text{margin:0; font-size:14px; line-height:1.75; font-weight:650;}
.muted{color:var(--muted);}

.why .title{ text-align:center; }

.why__grid{display:grid; grid-template-columns:1fr .9fr; gap:22px; align-items:center;}

.why__badge{
  position:relative;
  border:none;
  border-radius:0;
  padding:0;
  background:transparent;
  box-shadow:none;
  display:flex;
  align-items:center;
  justify-content:center;
  max-width:360px;
  justify-self:center;
}

.why__img{
  width:100%;
  height:auto;
  display:block;
}

.why__logo{display:flex; align-items:center; gap:10px; font-weight:900;}

.why__particles{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.p{position:absolute; width:8px; height:8px; border-radius:999px; background:rgba(17,24,39,.25);}
.p--g{background:rgba(34,197,94,.85);}
.why__particles .p:nth-child(1){left:18px; top:18px;}
.why__particles .p:nth-child(2){left:62px; top:42px;}
.why__particles .p:nth-child(3){left:140px; top:30px;}
.why__particles .p:nth-child(4){right:26px; top:22px;}
.why__particles .p:nth-child(5){right:64px; top:66px;}
.why__particles .p:nth-child(6){left:30px; bottom:34px;}
.why__particles .p:nth-child(7){left:90px; bottom:18px;}
.why__particles .p:nth-child(8){right:40px; bottom:26px;}
.why__particles .p:nth-child(9){right:90px; bottom:60px;}
.why__particles .p:nth-child(10){left:170px; bottom:44px;}

.license{
  display:flex;
  gap:14px;
  align-items:flex-start;
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--card);
  padding:16px;
  box-shadow:var(--shadow);
  margin-bottom:18px;
}
.license__icon{
  width:42px;
  height:42px;
  border-radius:12px;
  background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.22);
  background-image:url("./images/Licensia.png");
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
}
.license__title{font-weight:900; margin-bottom:4px;}
.license__text{font-size:13px; line-height:1.7; font-weight:650;}

.features{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:18px;}
.feature{border:1px solid var(--line); border-radius:18px; background:#fff; padding:16px; box-shadow:var(--shadow);}
.feature__icon{
  position:relative;
  width:34px;
  height:34px;
  border-radius:10px;
  margin-bottom:12px;
  background:var(--green2);
  border:1px solid rgba(22,163,74,.22);
  box-shadow:0 12px 26px rgba(34,197,94,.18);
}

.feature__icon::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--feature-icon);
  background-repeat:no-repeat;
  background-position:center;
  background-size:20px 20px;
  filter:brightness(0) invert(1);
}
.feature__text{font-size:13px; line-height:1.6; font-weight:650;}

.features .feature:nth-child(1) .feature__icon{--feature-icon:url("./images/icon-1.svg");}
.features .feature:nth-child(2) .feature__icon{--feature-icon:url("./images/icon-2.svg");}
.features .feature:nth-child(3) .feature__icon{--feature-icon:url("./images/icon-3.svg");}
.features .feature:nth-child(4) .feature__icon{--feature-icon:url("./images/icon-4.svg");}
.features .feature:nth-child(5) .feature__icon{--feature-icon:url("./images/icon-5.svg");}
.features .feature:nth-child(6) .feature__icon{--feature-icon:url("./images/icon-6.svg");}

.gallery{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:18px;}
.photo{
  width:100%;
  height:150px;
  object-fit:cover;
  display:block;
  border-radius:16px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.board{display:flex; gap:22px; justify-content:center; flex-wrap:wrap; margin-top:18px;}
.person{width:200px; text-align:center;}
.avatar{
  width:116px;
  height:116px;
  border-radius:999px;
  margin:0 auto 10px;
  border:1px solid var(--line);
  background:#fff;
  object-fit:cover;
  display:block;
  box-shadow:var(--shadow);
}
.person__name{font-weight:900;}

.footer{padding:56px 0 36px; border-top:1px solid var(--line); background:#fff;}
.footer__grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px;}
.footer__title{font-weight:900; font-size:12px; letter-spacing:.10em; color:var(--muted); opacity:.95; margin-bottom:12px;}
.footer__title--mt{margin-top:26px;}
.footer__link{display:block; padding:7px 0; color:#374151; font-weight:650; font-size:13px;}
.footer__link:hover{color:#111827;}

.store{display:grid; gap:10px;}
.store__badge{display:inline-flex; align-items:center; justify-content:center; height:40px; border-radius:10px; border:1px solid rgba(17,24,39,.10); background:#fff; font-weight:800; font-size:13px;}

.store__img{
  height:22px;
  width:auto;
  display:block;
}

.pay{display:flex; gap:10px; flex-wrap:wrap;}
.pay__badge{display:inline-flex; align-items:center; justify-content:center; height:34px; padding:0 12px; border-radius:10px; border:1px solid rgba(17,24,39,.10); background:#fff; font-weight:900; font-size:12px;}

.pay__img{
  height:18px;
  width:auto;
  display:block;
}

.awards{display:flex; gap:12px; flex-wrap:wrap; padding-top:10px;}
.award{width:clamp(140px, 16vw, 240px); height:clamp(78px, 9vw, 140px); border-radius:12px; border:1px solid rgba(17,24,39,.10); background:#fff; object-fit:contain; padding:12px;}

.footer__col--extras .store{display:flex; gap:10px; flex-wrap:wrap;}
.footer__col--extras .store__badge{height:38px; padding:0 10px;}

.footer__col--extras .pay{gap:10px;}

.footer__col--extras .awards{gap:12px;}

.footer__awards{margin-top:26px;}
.footer__awards .awards{flex-wrap:nowrap; overflow-x:auto; padding-bottom:8px;}
.footer__awards .award{flex:0 0 auto;}

.footer__bottom{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:26px;}
.disclaimer{font-size:12px; line-height:1.6; font-weight:650;}

.popup{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:50;
}

.popup.is-open{display:flex;}

.popup__overlay{
  position:absolute;
  inset:0;
  background:rgba(17,24,39,.55);
  backdrop-filter: blur(6px);
}

.popup__dialog{
  position:relative;
  width:min(520px, 100%);
  background:#fff;
  border-radius:18px;
  box-shadow:0 26px 90px rgba(0,0,0,.35);
  padding:18px 18px 18px;
  border:1px solid rgba(17,24,39,.08);
}

.popup__close{
  position:absolute;
  right:10px;
  top:10px;
  z-index:5;
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  font-size:20px;
  line-height:1;
  cursor:pointer;
  color:rgba(17,24,39,.70);
}

.popup__visual{
  position:relative;
  z-index:1;
  height:210px;
  margin:-6px -6px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:center;
}

.popup__paper{
  position:absolute;
  top:34px;
  left:50%;
  width:420px;
  height:170px;
  transform:translateX(-50%);
  border-radius:28px;
  background:radial-gradient(220px 90px at 40% 40%, rgba(17,24,39,.06), transparent 70%),
    radial-gradient(260px 120px at 80% 40%, rgba(17,24,39,.05), transparent 70%),
    rgba(17,24,39,.04);
  clip-path: polygon(4% 14%, 14% 6%, 28% 10%, 40% 0%, 54% 10%, 72% 6%, 88% 16%, 96% 8%, 100% 26%, 96% 44%, 100% 62%, 94% 76%, 82% 92%, 66% 84%, 54% 100%, 40% 88%, 26% 96%, 10% 86%, 2% 72%, 0% 56%, 4% 40%, 0% 26%);
}

.popup__phones{
  position:relative;
  width:320px;
  height:210px;
}

.phone{
  position:absolute;
  width:140px;
  height:210px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(17,24,39,.92), rgba(17,24,39,.80));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 22px 60px rgba(17,24,39,.22);
  top:8px;
}

.phone::before{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  top:12px;
  bottom:12px;
  border-radius:16px;
  background:
    radial-gradient(140px 70px at 30% 15%, rgba(34,197,94,.20), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}

.phone::after{
  content:"";
  position:absolute;
  left:18px;
  right:18px;
  top:26px;
  height:130px;
  border-radius:12px;
  background:
    linear-gradient(to right, rgba(255,255,255,.09) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.07) 1px, transparent 1px),
    radial-gradient(240px 140px at 35% 35%, rgba(34,197,94,.22), transparent 60%);
  background-size:22px 22px, 22px 22px, auto;
  opacity:.85;
}

.phone--back{left:44px; transform:rotate(-10deg); opacity:.92;}
.phone--front{left:132px; transform:rotate(8deg);}

.popup__title{
  margin:8px 0 10px;
  font-size:22px;
  line-height:1.15;
  letter-spacing:-.02em;
  text-align:center;
}

.popup__list{
  margin:0;
  padding:0 0 0 18px;
  color:#111827;
  font-size:13px;
  line-height:1.55;
  font-weight:650;
}

.popup__list li{margin:0 0 10px;}

.popup__footnote{
  margin:2px 0 12px;
  font-size:11px;
  line-height:1.45;
  color:rgba(17,24,39,.55);
  font-weight:650;
}

.popup__cta{display:flex; justify-content:center;}

@media (max-width: 980px){
  .nav{display:none;}
  .features{grid-template-columns:1fr 1fr;}
  .gallery{grid-template-columns:1fr 1fr;}
  .footer__grid{grid-template-columns:1fr 1fr;}
  .footer__bottom{grid-template-columns:1fr;}
}

@media (max-width: 760px){
  .hero__inner{grid-template-columns:1fr;}
  .hero__art{min-height:360px;}
}

@media (max-width: 560px){
  .header__inner{height:auto; padding:14px 0; flex-wrap:wrap;}
  .features{grid-template-columns:1fr;}
  .gallery{grid-template-columns:1fr;}
}
